我想以某种方式指出,多面板图形中的某些行应该一起比较。例如,我想制作这个图:

如下图所示(用PowerPoint制作的面板周围有方框):

这是我使用第一个图所做的代码。我使用了ggplot和cowplot:
require(cowplot)
theme_set(theme_cowplot(font_size=12)) # reduce default font size
plot.mpg <- ggplot(mpg, aes(x = cty, y = hwy, colour = factor(cyl))) +
geom_point(size=2.5)
plot.diamonds <- ggplot(diamonds, aes(clarity, fill = cut)) + geom_bar() +
theme(axis.text.x = element_text(angle=70, vjust=0.5))
plot.mpg2 <- ggplot(mpg, aes(x = cty, y = hwy, colour = factor(cyl))) +
geom_point(size=2.5)
plot.diamonds2 <- ggplot(diamonds, aes(clarity, fill = cut)) + geom_bar() +
theme(axis.text.x = element_text(angle=70, vjust=0.5))
plot_grid(plot.mpg, plot.diamonds,plot.mpg2, plot.diamonds2, nrow=2,labels = c('A', 'B','C','D'))是否可以对此代码进行更改以获得我想要的边框?或者我甚至可以使面板A和B的颜色与面板C和D的背景颜色略有不同?这可能会更好。
发布于 2018-09-05 13:20:45
由于plot_grid()的结果是一个ggplot对象,因此一种方法是使用嵌套的绘图网格:每行一个plot_grid(),并通过theme()添加适当的边框。
plot_grid(
# row 1
plot_grid(plot.mpg, plot.diamonds, nrow = 1, labels = c('A', 'B')) +
theme(plot.background = element_rect(color = "black")),
# row 2
plot_grid(plot.mpg2, plot.diamonds2, nrow = 1, labels = c('C', 'D')) +
theme(plot.background = element_rect(color = "black")),
nrow = 2)

https://stackoverflow.com/questions/52175766
复制相似问题