align_plots
Special thanks to the patchwork
project—many core codes
of the plot composer process were adapted from patchwork
.
We have added new features to better implement ggalign
’s
layout functions (ggheatmap()
and ggstack()
),
including:
These features have not been pushed to patchwork
because
they required significant modification of core code. We attempted to
merge them, but the author of patchwork
decided to
implement some of these features independently. The latest version of
patchwork now includes free_align()
,
free_lab()
, and free_space()
functionality
under a single function: patchwork::free()
. For more
details, see: https://www.tidyverse.org/blog/2024/09/patchwork-1-3-0/.
The plot composer function in ggalign
is
align_plots()
, which behaves similarly to
cowplot::align_plots()
and
patchwork::wrap_plots()
. However, you can directly use
align_plots()
with
quad_layout()
/ggheatmap()
and
ggstack()
, ensuring that they align correctly by plot
panel. Additionally, align_plots()
can align
pheatmap
and ComplexHeatmap
objects, although
they won’t align by panel area with ggplot2.
Plot Assembly
We’ll start with a few well-known example plots:
p1 <- ggplot(mtcars) +
geom_point(aes(mpg, disp))
p2 <- ggplot(mtcars) +
geom_boxplot(aes(gear, disp, group = gear))
p3 <- ggplot(mtcars) +
geom_bar(aes(gear)) +
facet_wrap(~cyl)
p4 <- ggplot(mtcars) +
geom_bar(aes(carb))
p5 <- ggplot(mtcars) +
geom_violin(aes(cyl, mpg, group = cyl))
Either add the plots as single arguments
align_plots(p1, p2, p3, p4, p5)
Or use bang-bang-bang to add a list of plots
align_plots(!!!list(p1, p2, p3), p4, p5)
Controlling the grid
Like patchwork
, if no specific layout is provided,
align_plots()
will attempt to create a grid that is as
square as possible, with each column and row taking up equal space:
align_plots(p1, p2, p3, p4, ncol = 3)
To adjust the widths of columns, use:
align_plots(p1, p2, p3, p4, widths = c(2, 1))
Guide legends
By default, align_plots()
won’t collect any guide
legends. You can use the guides
argument to control which
side of the guide legends should be collected. They will be collected to
their original side. Here, we use patch_titles()
to
indicate the guide legend position (instead of using
ggtitle()
). patch_titles()
can add titles on
four sides, and the title will be placed between the plot panel and the
guide legend.
p_right <- ggplot(mtcars) +
geom_point(aes(hp, wt, colour = mpg)) +
patch_titles("right") +
labs(color = "right")
p_top <- p_right +
patch_titles("top") +
scale_color_continuous(
name = "top",
guide = guide_colorbar(position = "top")
)
p_left <- p_right +
patch_titles("left") +
scale_color_continuous(
name = "left",
guide = guide_colorbar(position = "left")
)
p_bottom <- p_right +
patch_titles("bottom") +
scale_color_continuous(
name = "bottom",
guide = guide_colorbar(position = "bottom")
)
align_plots(p_right, p_bottom, p_top, p_left, guides = "tlbr")
If align_plots()
is nested in another
align_plots()
, the nested align_plots()
will
inherit the guides
argument from the upper-level
align_plots()
. And the top-level align_plots()
won’t collect guide legends from plots within the nested
align_plots()
unless the nested align_plots()
collects them first.
free_guide
The free_guide()
function allows you to override the
guides
argument for a single plot.
align_plots(
free_guide(p_right, NULL),
free_guide(p_bottom, NULL),
free_guide(p_top, NULL),
free_guide(p_left, NULL),
guides = "tlbr"
)
You can also specify which guide positions to be collected for individual plots.
align_plots(
free_guide(p_right, "r"),
free_guide(p_bottom, "b"),
free_guide(p_top, "t"),
free_guide(p_left, "l")
)
Session information
sessionInfo()
#> R version 4.4.2 (2024-10-31)
#> Platform: x86_64-pc-linux-gnu
#> Running under: Ubuntu 22.04.5 LTS
#>
#> Matrix products: default
#> BLAS: /usr/lib/x86_64-linux-gnu/openblas-pthread/libblas.so.3
#> LAPACK: /usr/lib/x86_64-linux-gnu/openblas-pthread/libopenblasp-r0.3.20.so; LAPACK version 3.10.0
#>
#> locale:
#> [1] LC_CTYPE=C.UTF-8 LC_NUMERIC=C LC_TIME=C.UTF-8
#> [4] LC_COLLATE=C.UTF-8 LC_MONETARY=C.UTF-8 LC_MESSAGES=C.UTF-8
#> [7] LC_PAPER=C.UTF-8 LC_NAME=C LC_ADDRESS=C
#> [10] LC_TELEPHONE=C LC_MEASUREMENT=C.UTF-8 LC_IDENTIFICATION=C
#>
#> time zone: UTC
#> tzcode source: system (glibc)
#>
#> attached base packages:
#> [1] stats graphics grDevices utils datasets methods base
#>
#> other attached packages:
#> [1] ggalign_0.0.5 ggplot2_3.5.1
#>
#> loaded via a namespace (and not attached):
#> [1] vctrs_0.6.5 cli_3.6.3 knitr_1.49 rlang_1.1.4
#> [5] xfun_0.49 generics_0.1.3 textshaping_0.4.0 jsonlite_1.8.9
#> [9] labeling_0.4.3 glue_1.8.0 colorspace_2.1-1 htmltools_0.5.8.1
#> [13] ragg_1.3.3 sass_0.4.9 fansi_1.0.6 scales_1.3.0
#> [17] rmarkdown_2.29 grid_4.4.2 tibble_3.2.1 evaluate_1.0.1
#> [21] munsell_0.5.1 jquerylib_0.1.4 fastmap_1.2.0 yaml_2.3.10
#> [25] lifecycle_1.0.4 compiler_4.4.2 dplyr_1.1.4 fs_1.6.5
#> [29] pkgconfig_2.0.3 farver_2.1.2 systemfonts_1.1.0 digest_0.6.37
#> [33] R6_2.5.1 tidyselect_1.2.1 utf8_1.2.4 pillar_1.9.0
#> [37] magrittr_2.0.3 bslib_0.8.0 withr_3.0.2 tools_4.4.2
#> [41] gtable_0.3.6 pkgdown_2.1.1 cachem_1.1.0 desc_1.4.3