基于ggplot2绘图将第二个标题添加到极坐标

时间:2017-08-14 16:45:03

标签: r ggplot2

我被要求使用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)

这会产生:

Pie chart with right caption

我看过一些使用annotate()的方法,但似乎无法让它们与coord_polar()一起使用。

有没有人知道如何让第二个标题显示在图表的左侧(与右侧标题水平对齐)?也许可以覆盖只有左标题的空白图层?

1 个答案:

答案 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)

enter image description here