3

我只是安排三个 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,这真的很烦人:

在此处输入图像描述

有人知道如何使所有地块的宽度相同吗?

4

1 回答 1

3

一种可能的解决方案是使用egg@baptise 的

# Using OPs data/plots
# Add aligned plots into a single object 
figure <- egg::ggarrange(p, q, r, nrow = 1)
# Save into a pdf
ggsave("~/myStocks.pdf", figure, width = 22, height = 9, units = "cm", dpi = 600)

对齐的结果如下所示:

在此处输入图像描述

于 2018-01-25T08:56:36.673 回答