我是R的新手,更不用说ggplot了,所以我提前为下面的例子中的任何问题道歉.
使用现有问题中的示例,我尝试将代码组合在一起以组合两个单独的ggplots.我想知道如何将最终绘图的图例移动到图表上方.我已经尝试将legend.postion更改为单个ggplots的"top",但它似乎不起作用.
(请注意,我已经省略了第二个y轴的创建,以使示例中的代码保持在我认为解释我的问题所需的最小值)
library(ggplot2)
library(gtable)
library(reshape2)
library(grid)
library(scales)
df.test <- data.frame(
x_cat = factor(c(1, 2, 3, 4)),
count = seq(1:4),
line1 = seq(from = 1, to = 4, length.out = 4),
line2 = seq(from = 0, to = 3, length.out = 4)
)
p1 <- ggplot( data = df.test , aes(x=x_cat, y=count) ) +
geom_bar( stat="identity" ) +
xlab( "X Label" ) +
ylab( "Y Label 1" ) +
theme(panel.background = element_rect(colour = "white"),
panel.grid.major = element_blank(),
panel.grid.minor = element_blank(),
legend.position = "bottom")
g1 <- ggplotGrob( p1 )
df.test2 <- melt( df.test[-2] )
p2 <- ggplot( data = df.test2 , aes(x=x_cat, y=value, colour=variable ) ) +
geom_line( aes(group=variable) ) +
ylab( "Y Label 2" ) +
theme(panel.background = element_rect(fill = NA, colour = "white"),
panel.grid.major = element_blank(),
panel.grid.minor = element_blank(),
legend.position = "bottom")
g2 <- ggplotGrob(p2)
pp <- c(subset(g1$layout, name == "panel", se = t:r))
g <- gtable_add_grob(g1, g2$grobs[[which(g2$layout$name == "panel")]], pp$t, pp$l, pp$b, pp$l)
pp <- c(subset(g2$layout, name == "guide-box", se = t:r))
g <- gtable_add_grob(g, g2$grobs[[which(g2$layout$name == "guide-box")]], t=pp$t, l=pp$l, b=pp$b, r=pp$r)
grid.draw(g)
Run Code Online (Sandbox Code Playgroud)
您不需要合并两个单独的图。ggplot 方法是将其视为具有两层(条形层和线条层)的单个图。所以我们只需要弄清楚如何将这些图层放在一个图上。例如:
library(ggplot2)
library(reshape2)
df.test <- data.frame(
x_cat = factor(c(1, 2, 3, 4)),
count = seq(1:4),
line1 = seq(from = 1, to = 4, length.out = 4),
line2 = seq(from = 0, to = 3, length.out = 4)
)
df.test2 = melt(df.test, id.var=c("x_cat", "count"))
ggplot() +
geom_bar(data=subset(df.test2, variable=="line1"), aes(x=x_cat, y=count),
stat="identity" ) +
geom_line(data=df.test2, aes(x=x_cat, y=value, colour=variable, group=variable)) +
xlab( "X Label" ) +
ylab( "Y Label 1" ) +
theme(panel.background = element_rect(colour = "white"),
panel.grid.major = element_blank(),
panel.grid.minor = element_blank(),
legend.position = "top")
Run Code Online (Sandbox Code Playgroud)
事实证明,我们这里不需要什么传奇体操。但是,如果您确实需要将单独的图与单个图例组合起来,这里、这里和这里有一些示例。