R语言绘制分区域网络图

数据和代码获取:请查看主页个人信息!!!

载入R包

library('networkdata')
library('ggraph')
library('igraph')
library('graphlayouts')
library('ggforce')

分区域网络图

xy <- layout_as_multilevel(multilvl_ex, type = "all", alpha = 25, beta = 45)
ggraph(multilvl_ex, "manual", x = xy[, 1], y = xy[, 2]) +
  geom_edge_link0(
    aes(filter = (node1.lvl == 1 & node2.lvl == 1)),
    edge_colour = "firebrick3",
    alpha = 0.5,
    edge_linewidth = 0.3
  ) +
  geom_edge_link0(
    aes(filter = (node1.lvl != node2.lvl)),
    alpha = 0.3,
    edge_linewidth = 0.1,
    edge_colour = "black"
  ) +
  geom_edge_link0(
    aes(filter = (node1.lvl == 2 &
                    node2.lvl == 2)),
    edge_colour = "goldenrod3",
    edge_linewidth = 0.3,
    alpha = 0.5
  ) +
  geom_node_point(aes(shape = as.factor(lvl)), fill = "grey25", size = 3) +
  scale_shape_manual(values = c(21, 22)) +
  theme_graph() +
  coord_cartesian(clip = "off", expand = TRUE) +
  theme(legend.position = "none")

这段代码使用 ggraph 包创建了一个多级网络图。其中:

  • ggraph() 函数创建了基本的图形,并指定了使用手动布局。

  • geom_edge_link0() 函数用于绘制边,通过 filter 参数指定了不同的边的过滤条件,并设置了颜色、透明度和线宽。

  • geom_node_point() 函数用于绘制节点,通过 lvl 参数指定了节点的级别,设置了节点的形状、填充颜色和大小。

  • scale_shape_manual() 函数手动设置了节点形状的值。<

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值