R-拼图系列-ggplot2之patchwork

相比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)
p1 / p2   #上下
wrap_plots(p1, p2, ncol = 1)

1.2 复杂布局

(1)符号连接方式可以通过()调整优先级
(p1 | p2) / p3 #先左右再上下
p1 | (p2 / p3) #先上下再左右 
(2)函数调用方式可通过设置design=参数,进行复杂布局
  • 有点类似基础绘图拼图的layout()函数
design <- "AB
           CC"
wrap_plots(A = p1, B = p2, C = p3, 
           design = design)
design <- "AAD
           BCE"
wrap_plots(B = p1, A = p2, C = p3, D = p4, E = p5,
           design = design)
  • 与上图等价的符号连接方式拼图代码如下。可见在更加复杂拼图需求时,还是使用函数调用方式更方便一点。
((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))
(((p1 / p2) + plot_layout(heights = c(1,2))) | p3) + plot_layout(widths = c(2,1))

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')

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')

2.4 plot_annotation 设置子图的tag标签

(p1 | (p2 / p3)) + 
  plot_annotation(tag_levels = 'A')
# tag_levels : 'a', 'A', '1', 'i, or 'I'
# 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)

3.2 ggplot对象 + 基础绘图

p1 + ~plot(mtcars$mpg, mtcars$disp, main = 'Plot 2')
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容