我只是安排三个 ggplots 以便它们在保存的 png 中并排显示。因此,我遵循了这个答案的有用线索。为了更清楚,我只显示最右边的图例。从逻辑上讲,由于图例,现在必须为最右边的图指定更大的宽度。有了scales::arrangeGrob()
我们可以实现这一点,例如c(600, 600, 750)
。
library(ggplot2)
economics$long <- with(economics, ifelse(uempmed > 8.61, 1, 0))
p <- ggplot(economics[economics$date < "1979-01-01", ],
aes(date, unemploy, color = long)) +
geom_line() + theme(legend.position="none")
q <- ggplot(economics[economics$date < "1991-01-01", ],
aes(date, unemploy, color = long)) +
geom_line() + theme(legend.position="none")
r <- ggplot(economics[economics$date < "2003-01-01", ],
aes(date, unemploy, color = long)) +
geom_line()
l <- list(p, q, r)
library(gridExtra)
ggsave("test.png",
arrangeGrob(grobs = l, nrow = 1, ncol = 3,
widths = c(600, 600, 750), heights = NULL,
padding = unit(0.5, "line")),
width = 18, height = 9, units = "cm", dpi = 600,
scale = 1.5)
我确信通过反复试验,我可以调整最右边的情节直到它适合。实际的问题是,尽管 的值相同,但中间和最左边的图的宽度并不匹配600
,这真的很烦人:
有人知道如何使所有地块的宽度相同吗?