Граненый ggplot с осью y посередине
Предположим, у меня есть два графика рядом с одной и той же осью Y, сгенерированные следующим кодом R:
df <- data.frame(x=c(5,2,7,3), y=c(11,3,5,6), facet=c(1,1,2,2))
ggplot(df, aes(x, y)) + facet_grid(~facet) + geom_point()
Можно ли написать текст по оси Y (например, 10,0, 7,5, 5,0) в середине, между двумя графиками? (Предпочтительно текст должен быть в центре.)
1 ответ
Решение
Вот способ (ну почти), используя ответ Баптиста из этого поста SO. Отображать ось y для каждого подзаговора при фасетировании. Не совсем посередине, но близко
library(ggplot2)
library(gtable)
# your data
df <- data.frame(x=c(5,2,7,3), y=c(11,3,5,6), facet=c(1,1,2,2))
# First plot (a bit of extra space between facets)
p <- ggplot(df, aes(x, y)) + facet_grid(~facet) +
geom_point() +
theme(panel.margin = unit(1, "lines"),
axis.text.y = element_text( hjust=0))
# get y-axis labels
g <- ggplotGrob(p)
axis <- gtable_filter(g, "axis-l")[["grobs"]][[1]][["children"]][["axis"]][,1]
# remove axis
g[["grobs"]][[4]][["children"]][["axis"]] <- NULL
# build plot & add axis to LHS of left facet
panels <- subset(g$layout, name == "panel")
g <- gtable_add_grob(g, grobs=axis, t = unique(panels$t), l=tail(panels$l, -1)-1)
grid.newpage()
grid.draw(g)