[英]ggarrange: Make plots (excluding titles, axis titles, axis labels) the same size
我正在尝试使用单独的图和ggarrange
重新创建facet_grid
的样式。 使用ggarrange
函数的高度和宽度参数允许我使所有绘图的大小相同,但这包括标题、轴标题等。 有没有办法使绘图本身具有相同的大小(其他试错宽度相对于高度和宽度)?
例子
library(ggplot2)
library(ggpubr)
df <- data.frame(x=runif(100), y=runif(100))
p1 <- ggplot(df) + geom_point(aes(x=x, y=y)) + theme(axis.title = element_text(size=100))
p2 <- p1 + xlab(NULL)
p3 <- p1 + ylab(NULL)
p4 <- p1 + xlab(NULL) + ylab(NULL)
p <- ggarrange(p2, p4, p1, p3, nrow=2, ncol=2)
print(p)
这使得下面的图,其中右上角的图看起来比其他图大(尽管包括轴标题,它们的大小都相同)。
这样的事情似乎更接近预期的结果:
p_fixed <- ggarrange(p2, p4, p1, p3, nrow=2, ncol=2,
heights = c(1, 1.3, 1, 1.3),
widths=c(1.1, 1, 1.1, 1))
或者,我这样做的原因是因为每个图表上的色阶需要不同,所以如果有办法使用facet_grid
来做到这一点也会有所帮助。 一个更普遍的问题可能是用单个图复制facet_grid
布局的最佳方法是什么。
试试这个patchwork
解决方案。 在列表中设置你的图并使用wrap_plots()
函数包装成一个组合图:
library(ggplot2)
library(ggpubr)
library(patchwork)
#Data
df <- data.frame(x=runif(100), y=runif(100))
#Plots
p1 <- ggplot(df) + geom_point(aes(x=x, y=y)) + theme(axis.title = element_text(size=100))
p2 <- p1 + xlab(NULL)
p3 <- p1 + ylab(NULL)
p4 <- p1 + xlab(NULL) + ylab(NULL)
#List
List <- list(p2,p4,p1,p3)
#Plot
Plot <- wrap_plots(List,ncol = 2,nrow = 2)
输出将被调整以保持相同的尺寸:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.