r语言同时画两张图(如何用布局和视口出图)

​01—图形组合布局par(mfrow=c(2,2))par(mfrow=c(2,2)),可以理解将绘图区域分割为2×2的矩阵区域,另可参照《R语言实战》3.5图形的组合##################par(mfrow=c(2,2))####################attach(iris)opar<-par(no.readonly=TRUE)#data(iris)#head(iris)#>head(iri…

大家好,又见面了,我是你们的朋友全栈君。

r语言同时画两张图(如何用布局和视口出图)

 

01

图形组合布局

par(mfrow=c(2,2))

 

par(mfrow=c(2,2)),可以理解将绘图区域分割为2×2的矩阵区域,另可参照《R语言实战》3.5图形的组合

##################par(mfrow=c(2,2))####################

attach(iris)

opar <- par(no.readonly = TRUE)

# data(iris)

# head(iris)

# > head(iris)

# Sepal.Length Sepal.Width Petal.Length Petal.Width Species

# 1          5.1         3.5          1.4         0.2  setosa

# 2          4.9         3.0          1.4         0.2  setosa

# 3          4.7         3.2          1.3         0.2  setosa

# 4          4.6         3.1          1.5         0.2  setosa

# 5          5.0         3.6          1.4         0.2  setosa

# 6          5.4         3.9          1.7         0.4  setosa

 

​par(mfrow=c(2,2)) # 设置2×2的布局

plot(Sepal.Length,Sepal.Width, main = “第一张图”)

boxplot(Sepal.Length, horizontal = TRUE, main = “第二张图”)

boxplot(Sepal.Width, main = “第三张图”)

hist(Petal.Length, main = “第四张图”)​

par(opar)

detach(iris)

 

r语言同时画两张图(如何用布局和视口出图)

 

02

图形组合布局

par(fig=c(x1, x2, y1, y2), new = TRUE)

 

par(fig=c(x1, x2, y1, y2), new = TRUE),取x1,x2,y1,y2四条线圈住的位置绘图图形,另可参照《R语言实战》3.5图形的组合

 

r语言同时画两张图(如何用布局和视口出图)

 

opar <- par(no.readonly = TRUE)

 

par(fig=c(0,0.8,0,0.8)) # 设置散点图的布局参数

plot(iris$Sepal.Length,iris$Sepal.Width) #绘制散点图​

 

par(fig=c(0,0.8,0.65,1),new = TRUE) #设置上方箱型图的布局参数

boxplot(iris$Sepal.Length, horizontal = TRUE, axes=FALSE) # 绘制上方箱型图​

 

par(fig=c(0.65,1,0,0.8),new = TRUE) #设置右侧箱型图的布局参数

boxplot(iris$Sepal.Width, axes=FALSE) # 绘制右侧箱型图​

 

mtext(“par(fig=c(x1, x2, y1, y2), new = TRUE)”,side = 3, outer=TRUE, line=-3)

par(opar)

 

r语言同时画两张图(如何用布局和视口出图)

 

03

图形组合布局

grid.layout & vplayout

library(ggplot2)

 

​#绘制基本ggplot图

base <- ggplot(mpg, aes(displ, hwy)) + geom_point()

p1 <- base + geom_smooth() + labs(title=”图1″) #如图1

 

​#用%+%调整映射关系中的数据

base <- ggplot(mpg, aes(displ, hwy)) + geom_point()

 

p2 <- base %+% subset(mpg, fl == “p”) + labs(title=”图2″) #图2​#第二种调整数据的方法list

p3 <- base + list(subset(mpg, fl == “p”), geom_smooth(), labs(title=”图3″)) #图3​

 

###########一页多图########

library(grid)

grid.newpage()  ##新建页面

pushViewport(viewport(layout = grid.layout(2,2))) #将页面分成2*2矩阵

vplayout <- function(x,y){ viewport(layout.pos.row = x, layout.pos.col = y)}​

 

print(p1, vp = vplayout(1,1))   #(1,1)的位置画图1

print(p2, vp = vplayout(1,2))   #(1,2)的位置画图2

print(p3, vp = vplayout(2,1:2))  #(2,:)的位置画图

r语言同时画两张图(如何用布局和视口出图)

 

04

图形组合布局

plot_grid {cowplot}

 

install.packages(“cowplot”) #安装cowplot包

library(cowplot) # 加载

?plot_grid  #帮助函数查看具体usage

 

示例

library(ggplot2)​

df <- data.frame(  x = 1:10, y1 = 1:10, y2 = (1:10)^2, y3 = (1:10)^3, y4 = (1:10)^4)

​p1 <- ggplot(df, aes(x, y1)) + geom_point()

p2 <- ggplot(df, aes(x, y2)) + geom_point()

p3 <- ggplot(df, aes(x, y3)) + geom_point()

p4 <- ggplot(df, aes(x, y4)) + geom_point()

 

gridplot_grid(p1, p2, p3, p4)

r语言同时画两张图(如何用布局和视口出图)

 

05

图形组合布局

multiplot{Rmisc}

 

############################# multiplot{Rmisc} ##################################

library(Rmisc)

library(ggplot2)​

 

df <- data.frame(  x = 1:10, y1 = 1:10, y2 = (1:10)^2, y3 = (1:10)^3, y4 = (1:10)^4)​

p1 <- ggplot(df, aes(x, y1)) + geom_point()

p2 <- ggplot(df, aes(x, y2)) + geom_point()

p3 <- ggplot(df, aes(x, y3)) + geom_point()

p5 <- ggplot(mpg, aes(as.factor(year), hwy)) +  geom_boxplot() +  facet_wrap(~class, scales = “free_y”)​

 

multiplot(p1, p2, p3, p5, cols=2)​

r语言同时画两张图(如何用布局和视口出图)

 

 获取源代码请至“数据驱动实践”公众号后台回复:一页多图

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/127525.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 用GVIM/VIM写Verilog——VIM配置分享「建议收藏」

    用GVIM/VIM写Verilog——VIM配置分享「建议收藏」使用VIM或GVIM最基本的配置,不包含任何插件相关的设置,VIM用于写verilog,非常欢迎大家在评论区分享讨论。本文不进行插件的配置,不进行基本使用方式与使用技巧的说明,仅作为基本配置的分享交流用GVIM/VIM写Verilog——VIM配置分享基本配置几点说明1,禁用方向键,使用jk代替ESC2,自动补全命令配置3,进行版权声明的设置4,一些其他映射基本配置setnocompatible”不兼容visyntaxon”语法高亮度显示setnoerrorbells”.

    2022年9月30日
    4
  • jmeter进阶-webservice接口「建议收藏」

    jmeter进阶-webservice接口「建议收藏」常用的接口类型http、webservice(soap)、websocket、dabbo如何判断接口是否为webservice:(1)询问开发可知;(2)通过地址查看可知(结尾是wsdl);

    2022年7月4日
    24
  • 均匀分布的均值及方差

    均匀分布的均值及方差

    2022年9月18日
    2
  • 推荐下载使用:金山词霸2009官方牛津版 + 激活成功教程补丁

    推荐下载使用:金山词霸2009官方牛津版 + 激活成功教程补丁2008-03-2909:04推荐下载使用:金山词霸2009官方牛津版+激活成功教程补丁《金山词霸2009牛津版》收词总量5,000,000,例句2,000,000余条,涉及语种包括中、日、英、韩

    2022年7月1日
    36
  • datagrip激活码2021_最新在线免费激活

    (datagrip激活码2021)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月26日
    131
  • 如何理解95%置信区间_95的置信区间和90的置信区间

    如何理解95%置信区间_95的置信区间和90的置信区间1.点估计与区间估计首先我们看看点估计的含义:是用样本统计量来估计总体参数,因为样本统计量为数轴上某一点值,估计的结果也以一个点的数值表示,所以称为点估计。点估计虽然给出了未知参数的估计值,但是未给出估计值的可靠程度,即估计值偏离未知参数真实值的程度。接下来看下区间估计:给定置信水平,根据估计值确定真实值可能出现的区间范围,该区间通常以估计值为中心,该区间则为置信区间。2.中心…

    2022年9月23日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号