loop

G6 内置了折线 loop 边,其默认样式如下。loop - 图1

注意 loop 边适用于自环边,即起始点与结束点为相同节点的边,在不同端点的边上适用 loop 边将会出现异常效果。loop - 图2

使用方法

内置边 一节所示,配置边的方式有两种:实例化图时全局配置,在数据中动态配置。

1 实例化图时全局配置

用户在实例化 Graph 时候可以通过 defaultEdge 指定 shape'loop',即可使用 loop 边。需要注意的是,如果图上存在非自环边,loop 将会表现异常。因此不建议在存在非自环边的图上使用此全局配置方法。

  1. const graph = new G6.Graph({
  2. container: 'mountNode',
  3. width: 800,
  4. height: 600,
  5. defaultEdge: {
  6. shape: 'loop',
  7. // 其他配置
  8. },
  9. });

2 在数据中动态配置

如果需要使不同节点有不同的配置,可以将配置写入到节点数据中。这种配置方式可以通过下面代码的形式直接写入数据,也可以通过遍历数据的方式写入。

  1. const data = {
  2. nodes: [
  3. ... // 节点
  4. ],
  5. edges: [{
  6. source: 'node0',
  7. target: 'node0'
  8. shape: 'loop',
  9. ... // 其他配置
  10. style: {
  11. ... // 样式属性,每种边的详细样式属性参见各边文档
  12. }
  13. },
  14. ... // 其他边
  15. ]
  16. }

配置项说明

自环是指连接单个节点自身的边,是一种边的特殊情况,因此,在通用属性基础上,支持了特殊的配置 loopCfg

loop 边支持以下的配置项,对于 Object 类型的配置项将在后面有详细讲解:

名称含义类型备注
color边的颜色String优先级低于 style 中的 stroke
style边的样式ObjectCanvas支持的属性
style.endArrow边结束端是否有箭头Boolean默认为 false
label标签文本文字String
labelCfg文件配置项Object
loopCfg自环特殊配置Object

样式属性 style

Object 类型。配置项与边的通用样式属性相同,见 内置边。下面代码演示在实例化图时全局配置方法中配置 style,以达到下图效果。loop - 图3

  1. const data = {
  2. nodes: [
  3. {
  4. id: 'node0',
  5. x: 100,
  6. y: 100,
  7. size: 20,
  8. },
  9. ],
  10. edges: [
  11. {
  12. source: 'node0',
  13. target: 'node0',
  14. shape: 'loop',
  15. label: 'loop',
  16. },
  17. ],
  18. };
  19. const graph = new G6.Graph({
  20. container: 'mountNode',
  21. width: 800,
  22. height: 600,
  23. defaultEdge: {
  24. // shape: 'loop', // 在数据中已经指定 shape,这里无需再次指定
  25. style: {
  26. endArrow: true,
  27. stroke: '#088',
  28. lineWidth: 3,
  29. },
  30. },
  31. });
  32. graph.data(data);
  33. graph.render();

标签文本配置 labelCfg

Object 类型。其配置与边的通用文本配置相同,见 内置边。基于上面 样式属性 style 中的代码,下面代码在 defaultNode 中增加了 labelCfg 配置项进行文本的配置,使之达到如下图效果。loop - 图4

  1. const data = {
  2. // ... data 内容
  3. };
  4. const graph = new G6.Graph({
  5. // ... 图的其他配置
  6. defaultEdge: {
  7. // ... 其他配置
  8. labelCfg: {
  9. refY: -5,
  10. refX: 30,
  11. },
  12. },
  13. });
  14. // ...

自环特殊配置 loopCfg

Object 类型。通过 loopCfg 配置自环的方位、高度、顺逆时针。

  • position: 指定自环与节点的相对位置。默认为:top。支持的值有:top, top-right, right,bottom-right, bottom, bottom-left, left, top-left
  • dist: 从节点 keyShape 的边缘到自环最顶端的位置,用于指定自环的曲度,默认为节点的高度。
  • clockwise: 指定是否顺时针画环,默认为 true

基于上面 样式属性 style 中的代码,下面代码在 defaultNode 中增加了 loopCfg 配置项进行文本的配置,使之达到如下图效果。loop - 图5

  1. const data = {
  2. // ... data 内容
  3. };
  4. const graph = new G6.Graph({
  5. // ... 图的其他配置
  6. defaultEdge: {
  7. // ... 其他配置
  8. loopCfg: {
  9. position: 'left',
  10. dist: 100,
  11. clockwise: false,
  12. },
  13. },
  14. });
  15. // ...