--- title: "Trace points" date: '`r format(Sys.Date(), "%B %d %Y")`' output: rmarkdown::html_vignette: vignette: > %\VignetteIndexEntry{Trace points} %\VignetteEncoding{UTF-8} %\VignetteEngine{knitr::rmarkdown} --- ## Basic Usage `geom_point_trace()` is similar to `ggplot2::geom_point()`, but also includes the ability to outline points of interest. This is particularly useful when working with dense datasets that are prone to overplotting. This geom accepts normal ggplot2 graphical parameters with some modifications. `fill` controls the color of each point, `color` controls the outline color, and `stroke` controls outline width, similar to how filled shapes are modified for other ggplot2 geoms. Additional parameters including `size`, `linetype`, and `alpha` are also accepted. ```{r} library(ggplot2) library(ggtrace) p <- ggplot( clusters, aes(UMAP_1, UMAP_2, fill = cluster) ) + theme_minimal() p + geom_point_trace( color = "black", size = 1, linetype = 1, alpha = 1 ) ```
## Aesthetics Like other ggplot2 geoms, variables can be mapped to aesthetic attributes to modify the outline appearance. ```{r} ggplot( clusters, aes(UMAP_1, UMAP_2, color = cluster) ) + geom_point_trace( fill = "black", stroke = 2 ) + theme_minimal() ```
By specifying `group` within `aes()`, outlines can also be added when coloring with a continuous variable. This is useful for visualizing points that are lightly colored. ```{r} p <- ggplot( clusters, aes(UMAP_1, UMAP_2, fill = signal, group = cluster) ) + theme_minimal() p + geom_point_trace(stroke = 0.5) + scale_fill_gradient(low = "white", high = "red") ```
Aesthetics can be further modified using the ggplot2 `scale_*()` functions. ```{r} p <- ggplot( clusters, aes(UMAP_1, UMAP_2, color = sample) ) + theme_minimal() p + geom_point_trace(fill = "white") + scale_color_manual(values = c("red", "#0072B2")) ```
## Position The "position" of the outline can be modified with the `trace_position` argument. This can be "all", "bottom", or a predicate selecting the points to outline. By default all groups are outlined. To only add a single outline around all points plotted, set `trace_position` to "bottom". ```{r} p <- ggplot( clusters, aes(UMAP_1, UMAP_2, fill = cluster) ) + theme_minimal() p + geom_point_trace(trace_position = "bottom") ```
A subset of data points can be highlighted by passing a predicate to `trace_position`. This must evaluate to `TRUE` or `FALSE` within the context of the input data. ```{r} p + geom_point_trace(trace_position = signal < 0) ```
The appearance of background points can be modified by passing a named list of parameters to `background_params`. ```{r} p + geom_point_trace( trace_position = signal < 0, background_params = list(color = NA, fill = "grey85") ) ```
Outlines can be removed by setting `color` to `NA`. ```{r} p + geom_point_trace( trace_position = signal < 0, color = NA, background_params = list(color = NA, fill = "grey85") ) ```