我被要求使用ggplot2
重新创建一个饼图,并且很难在情节中添加第二个字幕。我需要在情节左下角的标题和右下角的。
我当前的方法可以通过使用标题放置的hjust
选项获得一个或另一个(0表示左对齐; 1表示右对齐):
library(ggplot2)
dat <- data.frame(variable = c("V1", "V2", "V3"),
value = c(.80,.50,.63))
p1 <- ggplot(dat,
aes(x = 1, y = value, fill = variable)) +
geom_bar(stat = "identity") +
coord_polar(theta = "y") +
theme(legend.position = 'none',
plot.caption = element_text(hjust = 1)) +
labs(caption = "RIGHT CAPTION")
print(p1)
这会产生:
我看过一些使用annotate()
的方法,但似乎无法让它们与coord_polar()
一起使用。
有没有人知道如何让第二个标题显示在图表的左侧(与右侧标题水平对齐)?也许可以覆盖只有左标题的空白图层?
答案 0 :(得分:3)
使用grid
包可以添加包含左标题的文本grob。
library(ggplot2)
library(grid)
dat <- data.frame(variable=c("V1", "V2", "V3"), value=c(.80,.50,.63))
p1 <- ggplot(dat, aes(x = 1, y = value, fill = variable)) +
geom_bar(stat = "identity") +
coord_polar(theta = "y") +
theme(legend.position='none', plot.caption=element_text(hjust=1)) +
labs(caption="RIGHT CAPTION")
# Generate a ggplot2 plot grob
p2 <- ggplotGrob(p1)
# Find the grob tree containing the right caption (as child)
k <- which(p2$layout$name=="caption")
# Copy the "right caption" text grob in grbTxt
grbTxt <- p2$grobs[[k]]$children[[1]]
# Modify content and position of the text grob
grbTxt$label <- "LEFT CAPTION"
grbTxt$name <- "GRID.text.left"
grbTxt$x <- unit(0,"npc")
grbTxt$hjust <- 0
grbTxt$gp$col <- "red"
# Add grbTxt (left caption) to the title grob containing the right caption
p2$grobs[[k]] <- addGrob(p2$grobs[[k]],grbTxt)
grid.draw(p2)