试图在R

时间:2015-12-16 08:50:09

标签: r colors ggplot2 donut-chart

我正在尝试复制下图中的圆环图。

Attempting to replicate

我已经完成了除了实际着色之外的所有事情,并且对于我在ggplot的scale_colour_manual部分错误地做了什么感到困惑。

这是我用于ggplot的代码:

    ggplot(base_ind_zones) + 
    geom_rect(aes(fill = base_zones, ymax=ymax, ymin=ymin, xmax=4, xmin=3)) +
    geom_rect(aes(fill = ind, ymax=ymax, ymin=ymin, xmax=3, xmin=2)) +  
    xlim(c(0, 4)) + 
    theme(aspect.ratio=1) +
    coord_polar(theta = "y", start = ((2*3.14)/3)) +
    theme(panel.grid=element_blank()) +
    theme(axis.text=element_blank()) +
    theme(axis.ticks=element_blank()) +
    scale_colour_manual(breaks = c("A", "B", "C", "D"),
    values = c(adjustcolor("blue", alpha.f = 0), "firebrick4", "grey99", "skyblue1"))

和样本数据集:

    base_ind_zones <- base_ind_zones = data.frame(category=c("A", "B", "C", "D"),
    base_zones=c(33, 44, 12, 11),
    ind=c(33, 44, 2, 21))

    #Needed to determine the ymin and ymax for ggplot
    base_ind_zones$fraction = base_ind_zones$ind / sum(base_ind_zones$ind)
    base_ind_zones$ymax = cumsum(base_ind_zones$fraction)
    base_ind_zones$ymin = c(0, head(base_ind_zones$ymax, n = -1))

Current output

在添加scale_colour_manual之前,我获得了上面的圆环图。添加scale_colour_manual后,着色没有变化。我需要对scale_colou_manual进行哪些更改以更改着色?如果我没有走上正轨,我真的很感激任何指导。提前致谢!

1 个答案:

答案 0 :(得分:1)

base_ind_zones <- data.frame(category=c("A", "B", "C", "D"),
                                          base_zones=as.character(c(33, 44, 12, 11)),
                                          ind=as.character(c(33, 45, 2, 21)),
                         stringsAsFactors = FALSE)

#Needed to determine the ymin and ymax for ggplot
base_ind_zones$fraction = as.numeric(base_ind_zones$ind) /
  sum(as.numeric(base_ind_zones$ind))
base_ind_zones$ymax = cumsum(base_ind_zones$fraction)
base_ind_zones$ymin = c(0, head(base_ind_zones$ymax, n = -1))

ggplot(base_ind_zones) + 
  geom_rect(aes(fill = base_zones, ymax=ymax, ymin=ymin, xmax=4, xmin=3)) +
  geom_rect(aes(fill = ind, ymax=ymax, ymin=ymin, xmax=3, xmin=2)) +  
  xlim(c(0, 4)) + 
  theme(aspect.ratio=1) +
  coord_polar(theta = "y", start = ((2*3.14)/3)) +
  theme(panel.grid=element_blank()) +
  theme(axis.text=element_blank()) +
  theme(axis.ticks=element_blank()) +
  scale_fill_manual(breaks = c("A", "B", "C", "D"),
              values = c("33"="white", "44"="firebrick4", "12"="white", 
                         "11"="skyblue1", "2"="black", "21"="white", "45"="black"))

enter image description here