我有一个数据帧DF:

DF

enter image description here

dput(DF)
structure(list(group = c("root", "root", "NS2A", "NS2A", "NS2A", 
"NS5", "NS5", "NS5", "NS5", "NS5", "NS5", "NS5", "NS5", "NS5", 
"NS5", "NS5", "NS5", "NS5", "NS5", "NS5", "NS5"), subitem = c("NS2A", 
"NS5", "NS2A_C_to_A_Nonsynonymous_3931_1.0015", "NS2A_C_to_A_Nonsynonymous_3931_0.9404", 
"NS2A_C_to_A_Nonsynonymous_3931_1.0141", "NS5_G_to_A_Synonymous_8561_2.6323", 
"NS5_A_to_T_Synonymous_9728_2.4983", "NS5_G_to_A_Synonymous_8561_2.5331", 
"NS5_A_to_T_Synonymous_9728_2.3962", "NS5_G_to_A_Synonymous_8561_2.1411", 
"NS5_A_to_T_Synonymous_9728_2.6646", "NS5_G_to_A_Synonymous_8561_2.0874", 
"NS5_A_to_T_Synonymous_9728_2.6065", "NS5_G_to_A_Synonymous_8561_2.3789", 
"NS5_A_to_T_Synonymous_9728_2.6322", "NS5_G_to_A_Synonymous_8561_3.2712", 
"NS5_A_to_C_Nonsynonymous_9276_2.8576", "NS5_A_to_T_Synonymous_9728_2.7555", 
"NS5_G_to_A_Synonymous_8561_1.9121", "NS5_A_to_C_Nonsynonymous_9276_5.1328", 
"NS5_A_to_T_Synonymous_9728_2.6368"), size = c(0, 0, 1.0015, 
0.9404, 1.0141, 2.6323, 2.4983, 2.5331, 2.3962, 2.1411, 2.6646, 
2.0874, 2.6065, 2.3789, 2.6322, 3.2712, 2.8576, 2.7555, 1.9121, 
5.1328, 2.6368), Pass = c("PA", "PA", "P1", "P7", "P12", "P0", 
"P0", "P1", "P1", "P3", "P3", "P5", "P5", "P7", "P7", "P10", 
"P10", "P10", "P12", "P12", "P12"), cc = c("#FFFFFF", "#FFFFFF", 
"#fc2f92", "#b84592", "#8e43e7", "#3369e7", "#3369e7", "#fc2f92", 
"#fc2f92", "#00aeff", "#00aeff", "#ff4f81", "#ff4f81", "#b84592", 
"#b84592", "#Cf6c5f", "#Cf6c5f", "#Cf6c5f", "#8e43e7", "#8e43e7", 
"#8e43e7")), row.names = c(NA, -21L), class = "data.frame")

I want to create a root white circle which contains two white sub circles each of them containing those subitems listed. Colors are assigned in DF$cc

vertices <- DF %>% 
  distinct(subitem, size) %>% 
  add_row(subitem = "root", size = 0)

graph <- graph_from_data_frame(DF, vertices = vertices)


DFfff <- data.frame(group="root",    
                    subitem="root", 
                    size=0,
                    Pass="PA",
                    cc="#FFFFFF")
cc <- c("#FFFFFF","#fc2f92","#b84592","#8e43e7","#3369e7","#00aeff","#ff4f81","#Cf6c5f")

DF2=data.frame(Pass=unique(DF$Pass),cc=cc)
data2<-dplyr::inner_join(DF,DF2)
DF<-data2
ggg<-rbind(DF,DFfff)
ggg <- mutate_at(ggg, vars(cc), as.factor)


ggraph(graph, layout = "circlepack", weight = size) + 
  geom_node_circle(aes(fill=ggg$cc,colour = size,group=size)) +
  coord_fixed()

然而,我得到的曲线图,它有错误的 colored颜色 分配给每个圆圈,NS5子圆圈中最大的子项排列在中间(这里是大的蓝色圆圈),但我不想在中间

enter image description here

推荐答案

获得合适的 colored颜色 是很容易解决的.首先,要获得正确的 colored颜色 分配,请使用igraph::V()将 colored颜色 添加到图形对象的顶点.第二,由于你的 colored颜色 是色码,所以使用scale_fill_identity.不幸的是,看了这些文档后,我认为定制网络中 node 位置的选项有限.

library(igraph)
library(ggraph)

set.seed(123)

V(graph)$color <- ggg$cc

ggraph(graph,
  layout = "circlepack",
  weight = size
) +
  geom_node_circle(aes(fill = color, colour = size, group = size)) +
  scale_fill_identity() +
  coord_fixed()

R相关问答推荐

在特定列上滞后n行,同时扩展框架的长度

检测(并替换)字符串中的数学符号

R Tidymodels textercipes-使用spacyR进行标记化-如何从生成的标记列表中删除标点符号

如何按排序顺序打印一个框架中所有精确的唯一值?

在数学中正确显示摄氏度、开氏度或华氏度

基于多列将值链接到NA

为什么在ggplot2中添加geom_text这么慢?

在某些栏和某些条件下,替换dfs列表中的NA

如何在一次运行中使用count进行多列计数

如何写商,水平线,在一个单元格的表在R

LOF中的插图短文字幕

使用rvest从多个页面抓取时避免404错误

悬崖三角洲超大型群数计算导致整数溢出

我将工作代码重构为一个函数--现在我想不出如何传递轴列参数

在ggplot2上从多个数据框创建复杂的自定义图形

我需要使用ggplot2制作堆叠条形图

按两个因素将观测值分组后计算单独的百分比

随机将数据帧中特定列上的某些行设置为NA

在使用SliderInput In Shiny(R)设置输入数据的子集时,保留一些情节痕迹

将每晚的平均值与每晚的值进行比较,统计是否有效?