多个ggplot饼图与整个馅饼

the*_*ide 3 r ggplot2

我想制作两个并排的饼图,ggplot2但我很难使两个饼图"整体"这里是我的数据样本.

> test
  New York Berlin         group
1      474    755 Never Visited
2      214    123  Visited Once
3       66    122   Visited > 1
4      142     64       Resided
Run Code Online (Sandbox Code Playgroud)

当我尝试:

  pie <- ggplot(data = melted2, aes(x = "", y = Cnt, fill = Type )) + 
  geom_bar(stat = "identity") +
  geom_text(aes(label = Cnt), position = position_stack(vjust = 0.5)) +
  coord_polar(theta = "y") +
  facet_grid(facets=. ~ City)  +
  theme(
    axis.title.x = element_blank(),
    axis.title.y = element_blank()) + theme(legend.position='bottom') + guides(fill=guide_legend(nrow=2,byrow=TRUE))

pie
Run Code Online (Sandbox Code Playgroud)

但这会产生: 在此输入图像描述

编辑: Changing facet_grid(facets=. ~ City)facet_grid(City ~ ., scales = "free")工作,但它产生的垂直堆叠的图表所示:

在此输入图像描述

关于如何生成两个横向的整个饼图的任何建议?

这是数据:

> dput(melted2)
structure(list(Type = structure(c(1L, 4L, 3L, 2L, 1L, 4L, 3L, 
2L), .Label = c("Never Visited", "Resided", "Visited > 1", "Visited Once"
), class = "factor"), City = structure(c(1L, 1L, 1L, 1L, 2L, 
2L, 2L, 2L), .Label = c("New York", "Berlin"), class = "factor"), 
    Cnt = c(474L, 214L, 66L, 142L, 755L, 123L, 122L, 64L)), row.names = c(NA, 
-8L), .Names = c("Type", "City", "Cnt"), class = "data.frame")
Run Code Online (Sandbox Code Playgroud)

aos*_*ith 6

T显示每个面的相对比例,一个选项是使用position_fill.它适用于条形和文本堆叠.

ggplot(data = melted2, aes(x = "", y = Cnt, fill = Type )) + 
    geom_bar(stat = "identity", position = position_fill()) +
    geom_text(aes(label = Cnt), position = position_fill(vjust = 0.5)) +
    coord_polar(theta = "y") +
    facet_wrap(~ City)  +
    theme(axis.title.x = element_blank(),
          axis.title.y = element_blank()) + 
    theme(legend.position='bottom') + 
    guides(fill=guide_legend(nrow=2, byrow=TRUE))
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述