Skip to content

Commit

Permalink
Fixes #245 allow transparency for lines and points (#250)
Browse files Browse the repository at this point in the history
* Fixes #245 allow transparency for lines and points

* Document option show.legend=NA used after vertical and horizontal lines
  • Loading branch information
pchelle authored Apr 29, 2022
1 parent 7602df3 commit aa82c2e
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 10 deletions.
29 changes: 19 additions & 10 deletions R/atom-plots.R
Original file line number Diff line number Diff line change
Expand Up @@ -157,12 +157,14 @@ addScatter <- function(data = NULL,
ggplot2::geom_point(
data = mapData,
mapping = ggplot2::aes_string(x = mapLabels$x, y = mapLabels$y, shape = "legendLabels", color = "legendLabels", size = "legendLabels"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$points$alpha, aesthetic = "alpha"),
show.legend = TRUE,
na.rm = TRUE
) +
ggplot2::geom_path(
data = mapData,
mapping = ggplot2::aes_string(x = mapLabels$x, y = mapLabels$y, linetype = "legendLabels", color = "legendLabels", size = "legendLabels"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$points$alpha, aesthetic = "alpha"),
show.legend = TRUE,
na.rm = TRUE
) +
Expand Down Expand Up @@ -249,9 +251,8 @@ addLine <- function(data = NULL,
validateIsOfType(plotConfiguration, PlotConfiguration, nullAllowed = TRUE)

# If data is not input, creates new data and its mapping from x and y input
if (isOfLength(data, 0)) {
if (isEmpty(data)) {
data <- as.data.frame(cbind(x = x, y = y))

dataMapping <- dataMapping %||% XYGDataMapping$new(x = ifNotNull(x, "x"), y = ifNotNull(y, "y"), data = data)
}

Expand All @@ -269,7 +270,7 @@ addLine <- function(data = NULL,
plotObject <- plotObject %||% initializePlot(plotConfiguration)

# If no mapping, return plot
if (all(isOfLength(dataMapping$x, 0), isOfLength(dataMapping$y, 0))) {
if (all(isEmpty(dataMapping$x), isEmpty(dataMapping$y))) {
warning("No mapping found for both x and y, line layer was not added")
return(plotObject)
}
Expand All @@ -286,11 +287,12 @@ addLine <- function(data = NULL,
# y-intercept
# geom_blank is used to fill the missing aes properties
# This prevents messing up the legend
if (isOfLength(dataMapping$x, 0) && !isOfLength(dataMapping$y, 0)) {
if (isEmpty(dataMapping$x) && !isEmpty(dataMapping$y)) {
plotObject <- plotObject +
ggplot2::geom_hline(
data = mapData,
mapping = ggplot2::aes_string(yintercept = mapLabels$y, linetype = "legendLabels", color = "legendLabels", size = "legendLabels"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$lines$alpha, aesthetic = "alpha"),
show.legend = TRUE
) +
ggplot2::geom_blank(
Expand All @@ -299,16 +301,18 @@ addLine <- function(data = NULL,
shape = "legendLabels",
fill = "legendLabels"
),
show.legend = TRUE
# Use NA instead of TRUE to prevent having an unwanted point in the legend key
show.legend = NA
)
}

# x-intercept
if (isOfLength(dataMapping$y, 0) && !isOfLength(dataMapping$x, 0)) {
if (isEmpty(dataMapping$y) && !isEmpty(dataMapping$x)) {
plotObject <- plotObject +
ggplot2::geom_vline(
data = mapData,
mapping = ggplot2::aes_string(xintercept = mapLabels$x, linetype = "legendLabels", color = "legendLabels", size = "legendLabels"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$lines$alpha, aesthetic = "alpha"),
show.legend = TRUE
) +
ggplot2::geom_blank(
Expand All @@ -317,24 +321,27 @@ addLine <- function(data = NULL,
shape = "legendLabels",
fill = "legendLabels"
),
show.legend = TRUE
# Use NA instead of TRUE to prevent having an unwanted point in the legend key
show.legend = NA
)
}

# Case of a line defined by x and y
# geom_path is used instead of geom_line,
# consequently values are connected by their order of appearance and not according to x values
if (all(!isOfLength(dataMapping$x, 0), !isOfLength(dataMapping$y, 0))) {
if (all(!isEmpty(dataMapping$x), !isEmpty(dataMapping$y))) {
plotObject <- plotObject +
ggplot2::geom_point(
data = mapData,
mapping = ggplot2::aes_string(x = mapLabels$x, y = mapLabels$y, shape = "legendLabels", color = "legendLabels", size = "legendLabels"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$lines$alpha, aesthetic = "alpha"),
show.legend = TRUE,
na.rm = TRUE
) +
ggplot2::geom_path(
data = mapData,
mapping = ggplot2::aes_string(x = mapLabels$x, y = mapLabels$y, linetype = "legendLabels", color = "legendLabels", size = "legendLabels"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$lines$alpha, aesthetic = "alpha"),
show.legend = TRUE,
na.rm = TRUE
) +
Expand Down Expand Up @@ -561,7 +568,7 @@ addErrorbar <- function(data = NULL,
# validateIsIncluded(barLinetype, Linetypes, nullAllowed = TRUE)

# If data is not input, creates data and its mapping from x, ymin and ymax input
if (isOfLength(data, 0)) {
if (isEmpty(data)) {
data <- as.data.frame(cbind(x = x, ymin = ymin %||% 0, ymax = ymax %||% 0))
dataMapping <- dataMapping %||% RangeDataMapping$new(x = "x", ymin = "ymin", ymax = "ymax", data = data)
}
Expand All @@ -579,7 +586,7 @@ addErrorbar <- function(data = NULL,
plotObject <- plotObject %||% initializePlot(plotConfiguration)

# If no mapping, return plot
if (all(isOfLength(dataMapping$x, 0), isOfLength(dataMapping$ymin, 0), isOfLength(dataMapping$ymax, 0))) {
if (all(isEmpty(dataMapping$x), isEmpty(dataMapping$ymin), isEmpty(dataMapping$ymax))) {
warning("No mapping found for x, ymin and ymax, error bar layer was not added")
return(plotObject)
}
Expand Down Expand Up @@ -609,6 +616,7 @@ addErrorbar <- function(data = NULL,
show.legend = FALSE,
size = size %||% getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$size, aesthetic = "size"),
linetype = linetype %||% getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$linetype, aesthetic = "linetype"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$alpha, aesthetic = "alpha"),
color = color %||% getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$color, aesthetic = "color")
)
}
Expand All @@ -626,6 +634,7 @@ addErrorbar <- function(data = NULL,
show.legend = FALSE,
size = size %||% getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$size, aesthetic = "size"),
linetype = linetype %||% getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$linetype, aesthetic = "linetype"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$alpha, aesthetic = "alpha"),
color = color %||% getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$color, aesthetic = "color")
)
}
Expand Down
4 changes: 4 additions & 0 deletions R/plot-timeprofile.R
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,7 @@ plotTimeProfile <- function(data = NULL,
linetype = mapLabels$linetype
),
size = getAestheticValues(n = 1, selectionKey = plotConfiguration$lines$size, position = 0, aesthetic = "size"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$lines$alpha, position = 0, aesthetic = "alpha"),
show.legend = TRUE
)
}
Expand Down Expand Up @@ -122,6 +123,7 @@ plotTimeProfile <- function(data = NULL,
),
size = getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$size, position = 0, aesthetic = "size"),
linetype = getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$linetype, position = 0, aesthetic = "linetype"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$alpha, position = 0, aesthetic = "alpha"),
show.legend = FALSE
) +
ggplot2::geom_linerange(
Expand All @@ -134,6 +136,7 @@ plotTimeProfile <- function(data = NULL,
),
size = getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$size, position = 0, aesthetic = "size"),
linetype = getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$linetype, position = 0, aesthetic = "linetype"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$errorbars$alpha, position = 0, aesthetic = "alpha"),
show.legend = FALSE
)
}
Expand All @@ -147,6 +150,7 @@ plotTimeProfile <- function(data = NULL,
shape = observedMapLabels$shape
),
size = getAestheticValues(n = 1, selectionKey = plotConfiguration$points$size, position = 0, aesthetic = "size"),
alpha = getAestheticValues(n = 1, selectionKey = plotConfiguration$points$alpha, position = 0, aesthetic = "alpha"),
show.legend = TRUE
)

Expand Down
4 changes: 4 additions & 0 deletions vignettes/atom-plots.Rmd
Original file line number Diff line number Diff line change
Expand Up @@ -281,6 +281,10 @@ addLine(
)
```

**Caution**: It is possible to define the transparency of the points and lines using `PlotConfiguration` objects using the field `alpha` in `lines` or `points`.
Lines with transparency in legend may disappear when the plot is displayed within the viewport for older versions of RStudio (for more details, see https://github.com/tidyverse/ggplot2/issues/4351). However, this does not affect exported plots.


## `addRibbon`

The function `addRibbon` returns a ribbon plot.
Expand Down

0 comments on commit aa82c2e

Please sign in to comment.