我想将四个图放在一个页面上。轴标签应仅打印在最边缘,即仅用于底部图表的x轴标签,仅用于左侧图表的y轴标签。这既适用于整个轴的名称,也适用于各个刻度线。我可以使用以下代码生成这些内容:
pdf(file = "ExampleOutput.pdf",
width = 6.61,
height = 6.61,
pointsize = 10
)
set.seed(42)
catA <- factor(c("m100", "m500", "m1000", "m2000", "m3000", "m5000"))
catB <- factor(20:28)
samples <- 100
rsample <- function(v) v[ceiling(runif(samples, max=length(v)))]
Tab <- data.frame(catA = rsample(catA),
catB = rsample(catB),
valA = rnorm(samples, 150, 8),
valB = pmin(1,pmax(0,rnorm(samples, 0.5, 0.3))))
par(mfrow = c(2,2))
for (i in 0:3) {
x <- Tab[[1 + i %% 2]]
plot(x, Tab[[3 + i %/% 2]],
xlab = if (i %/% 2 == 1) "Some Categories" else NULL,
ylab = if (i %% 2 == 0) "Some Values" else NULL,
axes = FALSE
)
axis(side = 1,
at=1:nlevels(x),
labels = if (i %/% 2 == 1) levels(x) else FALSE)
axis(side = 2, labels = (i %% 2 == 0))
box(which = "plot", bty = "l")
}
par(mfrow = c(1,1))
dev.off()
我会欢迎有关如何改进我的绘图命令的建议,也许可以避免手动耗尽左下角的轴和 L。但这只是一个补充。
此序列的结果如下所示:
这里的问题是大量浪费的空白。我的印象是 R 为轴和刻度标签保留空间,即使它们没有被使用。由于浪费了空间,对于左下图,实际上只有每秒x刻度被标记,这在这里真的很糟糕。
我想生成一个没有那么多空白的类似情节。实际的地块应该是相同的大小,所以它们排列正确,但标签的空间应该只在外面。我想像这样的布局(在 GIMP 中创建的模型):
我怎样才能实现这样的布局?