在一个图中绘制带有标签的多个饼图

问题描述 投票:0回答:1

前几天我遇到了这个问题,并试图为自己重新创建它。 ggplot, facet, piechart: placing text in the middle of pie chart slices 。我的数据格式非常相似,但遗憾的是接受的答案没有帮助,因此我要重新发帖。

我本质上想要创建接受的答案,但我自己的数据,但我遇到的问题是coord_polar does not support free scale。使用第一个答案:test_pie

我尝试使用第二个版本的答案,使用ddplyr版本,但我也没有得到我想要的输出。使用第二个答案:test_pie2

显然,这些都没有达到预期的效果。我更喜欢用大小饼图创建一个,但仅显示四个作为示例,如下:desired_pie。这是我在excel中做的,但有一个传说,没有背景网格。

title<-c(1,1,2,2,3,3,4,4,5,5,6,6)
type<-c('A','B','A','B','A','B','A','B','A','B','A','B')
value<-c(0.25,0.75,0.3,0.7,0.4,0.6,0.5,0.5,0.1,0.9,0.15,0.85)

piec<-data.frame(title,type,value)
library(tidyverse)    

p1<-ggplot(data = piec, aes(x = "", y = value, fill = type)) + 
  geom_bar(stat = "identity") +
  geom_text(aes(label = value), position = position_stack(vjust = 0.5)) +
  coord_polar(theta = "y") 
  #facet_grid(title ~ ., scales = "free")
p1


piec <- piec %>% group_by(title) %>% mutate(pos=cumsum(value)-0.5*value)
p2<-ggplot(data = piec) + 
  geom_bar(aes(x = "", y = value, fill = type), stat = "identity") +
  geom_text(aes(x = "", y = pos, label = value)) +
  coord_polar(theta = "y") 
  #facet_grid(Channel ~ ., scales = "free") 
p2
r ggplot2 plot pie-chart
1个回答
1
投票

您不必为geom_textgeom_bar提供不同的y值(对于它们都使用y = value)。接下来,您必须在geom_text中指定位置。最后,从facets中删除scales

library(ggplot2)

title<-c(1,1,2,2,3,3,4,4,5,5,6,6)
type<-c('A','B','A','B','A','B','A','B','A','B','A','B')
value<-c(0.25,0.75,0.3,0.7,0.4,0.6,0.5,0.5,0.1,0.9,0.15,0.85)
piec<-data.frame(title,type,value)

ggplot(piec, aes("", value, fill = type)) + 
    geom_bar(stat = "identity", color = "white", size = 1) +
    geom_text(aes(label = paste0(value * 100, "%")), 
              position = position_stack(vjust = 0.5), 
              color = "white", size = 3) +
    coord_polar(theta = "y") +
    facet_wrap(~ title, ncol = 3) +
    scale_fill_manual(values = c("#0048cc", "#cc8400")) +
    theme_void()

enter image description here

© www.soinside.com 2019 - 2024. All rights reserved.