Я создал настраиваемую шкалу заливки / цвета ggplot2 в качестве оболочки для discrete_scale
, единственный параметр в функции шкалы ggplot2, которая охватывает discrete_scale
, - это shade
. На самом деле у меня есть 4 разные цветовые палитры, которые выбираются на основе этого параметра: светлая, полутоновая, темная, контурная.
Проблема, с которой я столкнулся, заключается в том, что когда я вызываю эти разные оттенки в функциях оболочки шкалы (заливка и цвет), порядок этих цветов меняется. Как я могу обеспечить постоянный порядок?
palette_light_custom <- c("#FF61c3", "#53c1e8", "#82FF73", "#FFFA5C", "#FFA200", "#FF6D5C", "#C478FF", "#C478FF", "#C478FF")
palette_midtone_custom <- c("#f84eb7", "#f3413a", "#f48c00", "#fffa5c", "#56dc5b", "#219ed4", "#b86ef4", "#b86ef4", "#b86ef4")
palette_dark_custom <- c("#e0008a", "#eb0008", "#f48c00", "#fffa5c", "#15a736", "#0085cf", "#8745c6", "#8745c6", "#8745c6")
palette_outline_custom <- c("#a30059", "#005ba1", "#6729a7", "#FFFA5C", "#FFA200", "#FF6D5C", "#C478FF", "#C478FF", "#C478FF")
pal_light <- function() { scales::manual_pal(palette_light_custom) }
pal_midtone <- function() { scales::manual_pal(palette_midtone_custom) }
pal_dark <- function() { scales::manual_pal(palette_dark_custom) }
pal_outline <- function() { scales::manual_pal(palette_outline_custom) }
scale_colour_custom <- function(shade, ...) {
if (shade == "light") {
discrete_scale("colour", "custom", pal_light_custom(), ...)
} else if (shade == "midtone") {
discrete_scale("colour", "custom", pal_midtone_custom(), ...)
} else if (shade == "dark") {
discrete_scale("colour", "custom", pal_dark_custom(), ...)
} else if (shade == "outline") {
discrete_scale("colour", "custom", pal_outline_custom(), ...)
} else {
stop("Incorrect or missing shade parameter in scale_color_custom()")
}
}
scale_color_custom <- scale_colour_custom
scale_fill_custom <- function(shade, ...) {
if (shade == "light") {
discrete_scale("fill", "custom", pal_light_custom(), ...)
} else if (shade == "midtone") {
discrete_scale("fill", "custom", pal_midtone_custom(), ...)
} else if (shade == "dark") {
discrete_scale("fill", "custom", pal_dark_custom(), ...)
} else if (shade == "outline") {
discrete_scale("fill", "custom", pal_outline_custom(), ...)
} else {
stop("Incorrect or missing shade parameter in scale_color_custom()")
}
}
ggplot(data=iris,
aes(x = Sepal.Length,
color = Species,
fill = Spcies)) +
geom_density() +
scale_colour_custom("outline") +
scale_fill_custom("midtone") +
theme_minimal()
Обратите внимание на изображение, что заливка и цвет не совпадают. Как я могу заставить discrete_scale()
выбирать порядок, в котором указывается цветовая палитра?