-
Notifications
You must be signed in to change notification settings - Fork 71
/
Copy pathdiscrete-frontiers.R
103 lines (97 loc) · 2.95 KB
/
discrete-frontiers.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
#' Frontiers journal color palettes
#'
#' Color palettes inspired by the colors used in _Frontiers_ journals.
#'
#' @param palette Palette type.
#' Currently there is one available option: `"default"`
#' (10-color palette).
#' @param alpha Transparency level, a real number in (0, 1].
#' See `alpha` in [grDevices::rgb()] for details.
#'
#' @export pal_frontiers
#'
#' @importFrom grDevices col2rgb rgb
#' @importFrom scales manual_pal
#'
#' @author Clara Jégousse | \email{[email protected]}
#'
#' @examples
#' library("scales")
#' show_col(pal_frontiers("default")(7))
#' show_col(pal_frontiers("default", alpha = 0.6)(7))
pal_frontiers <- function(palette = c("default"), alpha = 1) {
palette <- match.arg(palette)
if (alpha > 1L || alpha <= 0L) stop("alpha must be in (0, 1]")
raw_cols <- ggsci_db$"frontiers"[[palette]]
raw_cols_rgb <- col2rgb(raw_cols)
alpha_cols <- rgb(
raw_cols_rgb[1L, ], raw_cols_rgb[2L, ], raw_cols_rgb[3L, ],
alpha = alpha * 255L, names = names(raw_cols),
maxColorValue = 255L
)
manual_pal(unname(alpha_cols))
}
#' Frontiers journal color scales
#'
#' See [pal_frontiers()] for details.
#'
#' @inheritParams pal_frontiers
#' @param ... Additional parameters for [ggplot2::discrete_scale()].
#'
#' @export scale_color_frontiers
#'
#' @importFrom ggplot2 discrete_scale
#'
#' @author Clara Jégousse | \email{[email protected]}
#'
#' @rdname scale_frontiers
#'
#' @examples
#' library("ggplot2")
#' data("diamonds")
#'
#' ggplot(
#' subset(diamonds, carat >= 2.2),
#' aes(x = table, y = price, colour = cut)
#' ) +
#' geom_point(alpha = 0.7) +
#' geom_smooth(method = "loess", alpha = 0.1, size = 1, span = 1) +
#' theme_dark() +
#' theme(
#' panel.background = element_rect(fill = "#2D2D2D"),
#' legend.key = element_rect(fill = "#2D2D2D")
#' ) +
#' scale_color_frontiers()
#'
#' ggplot(
#' subset(diamonds, carat > 2.2 & depth > 55 & depth < 70),
#' aes(x = depth, fill = cut)
#' ) +
#' geom_histogram(colour = "black", binwidth = 1, position = "dodge") +
#' theme_dark() +
#' theme(
#' panel.background = element_rect(fill = "#2D2D2D")
#' ) +
#' scale_fill_frontiers()
scale_color_frontiers <- function(palette = c("default"), alpha = 1, ...) {
palette <- match.arg(palette)
if (is_ggplot2_350()) {
discrete_scale("colour", palette = pal_frontiers(palette, alpha), ...)
} else {
discrete_scale("colour", scale_name = "frontiers", palette = pal_frontiers(palette, alpha), ...)
}
}
#' @export scale_colour_frontiers
#' @rdname scale_frontiers
scale_colour_frontiers <- scale_color_frontiers
#' @export scale_fill_frontiers
#' @importFrom ggplot2 discrete_scale
#' @rdname scale_frontiers
scale_fill_frontiers <- function(palette = c("default"), alpha = 1, ...) {
palette <- match.arg(palette)
if (is_ggplot2_350()) {
discrete_scale("fill", palette = pal_frontiers(palette, alpha), ...)
} else {
discrete_scale("fill", scale_name = "frontiers", palette = pal_frontiers(palette, alpha), ...)
}
}