相比R语言基础绘图函数,我更喜欢使用ggplot绘制的图形。而
patchwork
包是一个非常友好的,支持ggplot2对象拼图的工具包。操作简单,高效,nice~
参考官方教程:https://patchwork.data-imaginist.com/index.html
0、安装包以及绘制示例图
# #install.packages("devtools")
# devtools::install_github("thomasp85/patchwork")
library(ggplot2)
library(patchwork)
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))
1、直接拼图方法
patchwork
包提供有两种方式可供选择
(1)符号连接:+
或者|
均表示左右拼接,/
表示上下拼接,()
可以用于调整优先级
(2)函数调用:wrap_plots()
1.1 简单两张图
p1 + p2 #左右
wrap_plots(p1, p2)
data:image/s3,"s3://crabby-images/3662b/3662b5fd5e962d23a669fcef8f740f978a7c99af" alt=""
p1 / p2 #上下
wrap_plots(p1, p2, ncol = 1)
1.2 复杂布局
(1)符号连接方式可以通过()
调整优先级
(p1 | p2) / p3 #先左右再上下
data:image/s3,"s3://crabby-images/cf32f/cf32f49dae77052fbd4319b0b82914a1602bcc1f" alt=""
p1 | (p2 / p3) #先上下再左右
(2)函数调用方式可通过设置design=
参数,进行复杂布局
- 有点类似基础绘图拼图的
layout()
函数
design <- "AB
CC"
wrap_plots(A = p1, B = p2, C = p3,
design = design)
data:image/s3,"s3://crabby-images/f7e4c/f7e4c5bde35a5bf71f7dbe8c5bf4abaa01061c66" alt=""
design <- "AAD
BCE"
wrap_plots(B = p1, A = p2, C = p3, D = p4, E = p5,
design = design)
data:image/s3,"s3://crabby-images/ae66c/ae66c75b405ae186ab1a5ecca625b6e955c84185" alt=""
- 与上图等价的符号连接方式拼图代码如下。可见在更加复杂拼图需求时,还是使用函数调用方式更方便一点。
((p2 + p4) + plot_layout(widths = c(2, 1))) / (p1 + p3 + p5)
2、拼图细节调整
2.1 plot_layout
调整长宽比例
p1 + p2 + plot_layout(widths = c(3,2))
wrap_plots(p1, p2) + plot_layout(widths = c(3,2))
data:image/s3,"s3://crabby-images/3d119/3d119de6658474f332aa33c7bc8aef264187a0ab" alt=""
(((p1 / p2) + plot_layout(heights = c(1,2))) | p3) + plot_layout(widths = c(2,1))
data:image/s3,"s3://crabby-images/c4890/c48905031e148bbd73a2d955b43b51bfad05483a" alt=""
2.2 plot_layout
公用图形legend
data(Salaries, package="carData")
p11 <- ggplot(Salaries, aes(x=rank, fill=sex)) +
geom_bar(position="stack") + labs(title='position="stack"')
p22 <- ggplot(Salaries, aes(x=rank, fill=sex)) +
geom_bar(position="dodge") + labs(title='position="dodge"')
p33 <- ggplot(Salaries, aes(x=rank, fill=sex)) +
geom_bar(position="fill") + labs(title='position="fill"')
p11 + p22 + p33 + plot_layout(guides = 'collect')
data:image/s3,"s3://crabby-images/d30c4/d30c478278034512c4211e6b0469f94b58367d36" alt=""
2.3 plot_annotation
设置总图的title
(p1 | (p2 / p3)) + plot_annotation(
title = 'The surprising truth about mtcars',
subtitle = 'These 3 plots will reveal yet-untold secrets about our beloved data-set',
caption = 'Disclaimer: None of these plots are insightful')
data:image/s3,"s3://crabby-images/20f31/20f3114e4f5d7cf895bae14c0816bd28aa7cd9f2" alt=""
2.4 plot_annotation
设置子图的tag标签
(p1 | (p2 / p3)) +
plot_annotation(tag_levels = 'A')
# tag_levels : 'a', 'A', '1', 'i, or 'I'
data:image/s3,"s3://crabby-images/adaa9/adaa9e3ef91f87191e29a01004131a6c6b651617" alt=""
# tag标签加前缀
((p1 | p2) / p3) +
plot_annotation(tag_levels = 'A', tag_prefix = 'Fig. ')
# tag标签加后缀
((p1 | p2) / p3) +
plot_annotation(tag_levels = 'A', tag_suffix = ':')
- 此外如果想要加个性化的标签,可以在绘制子图时单独添加tag
p1 + labs(tag = "any")
3、ggplot对象与其它对象的拼图
3.1 ggplot对象 + 表格
df = mtcars[1:10, c('mpg', 'disp')]
p1 + gridExtra::tableGrob(df)
data:image/s3,"s3://crabby-images/f8de2/f8de20e7f99034b3f03a70e6b574347c165aa5bc" alt=""
3.2 ggplot对象 + 基础绘图
p1 + ~plot(mtcars$mpg, mtcars$disp, main = 'Plot 2')
data:image/s3,"s3://crabby-images/02d60/02d602e236b39ffc30907f1a4d12e01c59a3e6c1" alt=""
网友评论