前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >R语言绘图|patchwork拼图

R语言绘图|patchwork拼图

原创
作者头像
顾卿岚
发布2023-02-09 23:48:09
1.6K0
发布2023-02-09 23:48:09
举报

一、安装patchwork包

install.packages("patchwork")

library(patchwork)

二、简单运算符拼图

代码语言:javascript
复制
p1<-ggplot(data = diamonds) +  geom_bar(mapping = aes(x = cut,fill=clarity))


p2<-ggplot(data = diamonds) +  geom_bar(mapping = aes(x = cut, fill = clarity), position = "dodge")




p3<-ggplot(data = diamonds) +  geom_bar(mapping = aes(x = cut))




p4<-ggplot(data = iris,mapping = aes(x = Species, y = Sepal.Width,
 fill = Species)) +geom_boxplot()+  geom_jitter()

p5<-ggplot(data = mpg, mapping = aes(x = class, y = hwy)) + 
  geom_boxplot() +
  coord_flip()

(先任意绘制五张图分别命名为p1,p2,p3,p4,p5)

1)按➕排列图片

代码语言:javascript
复制
p1+p2+p3+p4
按图片输入顺序排列
按图片输入顺序排列

2)“|”对画布进行分割

代码语言:javascript
复制
p1|p2+p3 #p1占50%,p2和p3一共占50%

3) "/" 按行拼图

代码语言:javascript
复制
p1/p2/p3
代码语言:javascript
复制
(p1+p2)/p3 #可以把多个图合并成一行

4)plot_layout()调整行数和列数

代码语言:javascript
复制
p1+p2-p3+plot_layout(ncol = 1)  #p1和p2都在第一行,p3在第二行,一共一列,p1和p2看成一列
代码语言:javascript
复制
p1+p3-p2+plot_layout(ncol = 2) #效果和(p1+p3)|p2一样

5)plot_layout() 调节行列的宽度和高度

代码语言:javascript
复制
p1+p2+p3+p4+p5+plot_layout(ncol = 2,heights = c(1,2,3)) 
#ncol设置两列,而且height是每行高度分别是1/2/3
代码语言:javascript
复制
p1+p2+(p3+p4+plot_layout(ncol = 2))+p5+plot_layout(widths = c(2,1))
#p3和p4组合,并设置以两列方式组合,总体布局的宽度分别是2,1

6) theme函数修改主题

a) *theme_参数()设置局部主题

代码语言:javascript
复制
(p1*theme_bw())+(p2+p3)+p4+plot_layout(ncol = 1)
#对p1使用theme_bw() 主题,p3和p2合并成一张图,并且拼成一列

b)()& theme_参数 设置所有图片的主题

代码语言:javascript
复制
(p1+(p2+p3)+p4+plot_layout(ncol = 1))&theme_bw()

总结:

theme_ 的参数有很多,可以设置不同主题,根据需要选择

三、进阶拼图

(1)坐标法

代码语言:javascript
复制
areas<-c(area(1,1,2,1),area(2,3,3,3))
plot(areas)

说明:有两个area函数说明绘制了两个区域,第一区域的开始位置坐标是(1,1),结束位置是(2,1)

第二个区域开始坐标是(2,3),结束位置是(3,3)

再看一个例子

代码语言:javascript
复制
layout<-c(area(1,1,1,1),area(1,3,3,3),area(3,1,3,2))
plot(layout)

说明:有三个area函数说明绘制了三个区域,第一区域的开始位置坐标是(1,1),结束位置是(1,1)

第二个区域开始坐标是(1,3),结束位置是(3,3)

第三个区域开始坐标是(3,1),结束位置是(3,2)

(2)字母法(字母代表绘图区,#代表空白)

代码语言:javascript
复制
areas<-"A#B
         
        ##B
     
        CCB"


p1+p2+p3+plot_layout(design = areas)

四、调整图例

代码语言:javascript
复制
p1+p2+p4+guide_area()+plot_layout(guides = "auto")
#一共是四个区域p1,p2,p3和图例区
guides="auto" 会显示相同的图例
guides="auto" 会显示相同的图例
代码语言:javascript
复制
p1+p2+p4+guide_area()+plot_layout(guides = "collect")
使用“collect“参数,相同的图例只会显示出一个
使用“collect“参数,相同的图例只会显示出一个

⚠️⚠️ guides的参数 "auto" , "collect" , "keep"

五、插入元素

代码语言:javascript
复制
p1+inset_element(p2,0.6,0.6,1,1)
#图中的坐标同样表示插入图片的位置,(0.6,0.6)是图片的左下角点,(1,1)是图片右上角的点
代码语言:javascript
复制
p1+inset_element(p2,0,0.6,0.4,1)
更改坐标位置,可以把图片放到前面
更改坐标位置,可以把图片放到前面

六、插入空白 plot_spacer()

代码语言:javascript
复制
p1+plot_spacer()+p2
#在p1和p2之间插入一个空白

七、插入图片标签

代码语言:javascript
复制
(p1|p2)/(p3|p4)+plot_annotation(tag_levels = "A")&theme(plot.tag=element_text(color="blue",size=16))

tag_levels的参数:“A”大写字母 ;“a”小写字母 ;“i”小写罗马字母 ;“I”大写字母罗马字母 ;“1”数字排序

theme设置标签参数,包括颜色和大小

‼️自定义标签名称

代码语言:javascript
复制
(p1|p2)/(p3|p4)+plot_layout(tag_level = "new")
+plot_annotation(tag_levels = list(c("A1","A2","A3","A4")))
&theme(plot.tag = element_text(color = "grey",size = 16))

plot_layout(tag_level ="new") 设定自定义标签

tag_levels =list(c("A1","A2","A3","A4"))设置标签名称

⚠️文章参考于b站视频——R语言搬运工

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、安装patchwork包
  • 二、简单运算符拼图
    • 1)按➕排列图片
      • 2)“|”对画布进行分割
        • 3) "/" 按行拼图
          • 4)plot_layout()调整行数和列数
            • 5)plot_layout() 调节行列的宽度和高度
              • 6) theme函数修改主题
                • 总结:
                • 三、进阶拼图
                  • (1)坐标法
                    • (2)字母法(字母代表绘图区,#代表空白)
                    • 四、调整图例
                    • 五、插入元素
                    • 六、插入空白 plot_spacer()
                    • 七、插入图片标签
                      • ⚠️文章参考于b站视频——R语言搬运工
                      相关产品与服务
                      内容识别
                      内容识别(Content Recognition,CR)是腾讯云数据万象推出的对图片内容进行识别、理解的服务,集成腾讯云 AI 的多种强大功能,对存储在腾讯云对象存储 COS 的数据提供图片标签、图片修复、二维码识别、语音识别、质量评估等增值服务。
                      领券
                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档