Как показать легенду на сдвоенном Y-оси ggplot
Я пытаюсь составить двойную диаграмму оси Y, используя ggplot. Во-первых, позвольте мне сказать, что я не ищу обсуждения по существу того, является ли это хорошей практикой. Я считаю, что они особенно полезны при просмотре данных, основанных на времени, для выявления тенденций в 2 дискретных переменных. Дальнейшее обсуждение этого лучше подходит для перекрестной проверки на мой взгляд.
Kohske дает очень хороший пример того, как это сделать, и я до сих пор пользовался большим эффектом. Я, однако, в моих силах включить легенду для обеих осей Y. Я также видел подобные вопросы здесь и здесь, но, похоже, ни один из них не решает проблему включения легенды.
У меня есть воспроизводимый пример с использованием набора данных diamonds из ggplot.
Данные
library(ggplot2)
library(gtable)
library(grid)
library(data.table)
library(scales)
grid.newpage()
dt.diamonds <- as.data.table(diamonds)
d1 <- dt.diamonds[,list(revenue = sum(price),
stones = length(price)),
by=clarity]
setkey(d1, clarity)
Графики
p1 <- ggplot(d1, aes(x=clarity,y=revenue, fill="#4B92DB")) +
geom_bar(stat="identity") +
labs(x="clarity", y="revenue") +
scale_fill_identity(name="", guide="legend", labels=c("Revenue")) +
scale_y_continuous(labels=dollar, expand=c(0,0)) +
theme(axis.text.x = element_text(angle = 90, hjust = 1),
axis.text.y = element_text(colour="#4B92DB"),
legend.position="bottom")
p2 <- ggplot(d1, aes(x=clarity, y=stones, colour="red")) +
geom_point(size=6) +
labs(x="", y="number of stones") + expand_limits(y=0) +
scale_y_continuous(labels=comma, expand=c(0,0)) +
scale_colour_manual(name = '',values =c("red","green"), labels = c("Number of Stones"))+
theme(axis.text.y = element_text(colour = "red")) +
theme(panel.background = element_rect(fill = NA),
panel.grid.major = element_blank(),
panel.grid.minor = element_blank(),
panel.border = element_rect(fill=NA,colour="grey50"),
legend.position="bottom")
# extract gtable
g1 <- ggplot_gtable(ggplot_build(p1))
g2 <- ggplot_gtable(ggplot_build(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)
# axis tweaks
ia <- which(g2$layout$name == "axis-l")
ga <- g2$grobs[[ia]]
ax <- ga$children[[2]]
ax$widths <- rev(ax$widths)
ax$grobs <- rev(ax$grobs)
ax$grobs[[1]]$x <- ax$grobs[[1]]$x - unit(1, "npc") + unit(0.15, "cm")
g <- gtable_add_cols(g, g2$widths[g2$layout[ia, ]$l], length(g$widths) - 1)
g <- gtable_add_grob(g, ax, pp$t, length(g$widths) - 1, pp$b)
# draw it
grid.draw(g)
ВОПРОС: У кого-нибудь есть несколько советов о том, как заставить показать 2-ю часть легенды?
Ниже приведены диаграммы, созданные в порядке p1, p2, комбинированные p1 и p2, вы заметите, что легенда для p2 не отображается на комбинированном графике.
p1
p2
комбинированные p1 и p2
1 ответ
Подобно технике, которую вы используете выше, вы можете извлечь легенды, связать их, а затем переписать легенду сюжета с ними.
Итак, начиная с # draw it
в вашем коде
# extract legend
leg1 <- g1$grobs[[which(g1$layout$name == "guide-box")]]
leg2 <- g2$grobs[[which(g2$layout$name == "guide-box")]]
g$grobs[[which(g$layout$name == "guide-box")]] <-
gtable:::cbind_gtable(leg1, leg2, "first")
grid.draw(g)