Loading...
本文介绍内置节点通用属性配置。
import { Graph } from '@antv/g6';const graph = new Graph({node: {type: 'circle', // 节点类型style: {}, // 节点样式state: {}, // 状态样式palette: {}, // 色板配置animation: {}, // 动画配置},});
指定节点类型,内置节点类型名称或自定义节点的名称。默认为 circle
(圆形)。⚠️ 注意:这里决定了主图形的形状。
const graph = new Graph({node: {type: 'circle',},});
⚠️ 动态配置说明:type
属性同样支持动态配置,可以根据节点数据动态选择节点类型:
const graph = new Graph({node: {// 静态配置type: 'circle',// 动态配置 - 箭头函数形式type: (datum) => datum.data.nodeType || 'circle',// 动态配置 - 普通函数形式(可访问 graph 实例)type: function (datum) {console.log(this); // graph 实例return datum.data.category === 'important' ? 'diamond' : 'circle';},},});
可选值有:
circle
:圆形节点diamond
:菱形节点donut
:甜甜圈节点ellipse
:椭圆节点hexagon
:六边形节点html
:HTML 节点image
:图片节点rect
:矩形节点star
:星形节点triangle
:三角形节点定义节点的样式,包括颜色、大小等。
const graph = new Graph({node: {style: {},},});
⚠️ 动态配置说明:以下所有样式属性都支持动态配置,即可以传入函数来根据节点数据动态计算属性值:
const graph = new Graph({node: {style: {// 静态配置fill: '#1783FF',// 动态配置 - 箭头函数形式stroke: (datum) => (datum.data.isActive ? '#FF0000' : '#000000'),// 动态配置 - 普通函数形式(可访问 graph 实例)lineWidth: function (datum) {console.log(this); // graph 实例return datum.data.importance > 5 ? 3 : 1;},// 嵌套属性也支持动态配置labelText: (datum) => `节点: ${datum.id}`,badges: (datum) => datum.data.tags.map((tag) => ({ text: tag })),},},});
其中 datum
参数为节点数据对象 (NodeData
),包含节点的所有数据信息。
一个完整的节点由以下几部分构成:
key
:节点的主图形,表示节点的主要形状,例如矩形、圆形等;label
:文本标签,通常用于展示节点的名称或描述;icon
:图标图形,通常用于展示节点的图标,可以是图片或者文本图标;badge
:默认位于节点右上角的徽标;halo
:主图形周围展示的光晕效果的图形;port
:节点上的连接点,用于连接边。以下样式配置将按原子图形依次说明:
主图形是节点的核心部分,定义了节点的基本形状和外观。以下是常见的配置场景:
设置节点的基本外观:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {fill: '#5B8FF9', // 蓝色填充stroke: '#1A1A1A', // 深色描边lineWidth: 2,size: 40,},},});graph.render();
为节点添加透明度和阴影效果:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {fill: '#61DDAA',fillOpacity: 0.85,shadowColor: 'rgba(97, 221, 170, 0.4)',shadowBlur: 12,shadowOffsetX: 2,shadowOffsetY: 4,stroke: '#F0F0F0',lineWidth: 1,},},});graph.render();
创建带虚线边框的节点:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {fill: '#FFF1F0',stroke: '#F5222D',lineWidth: 2,lineDash: [6, 4],lineCap: 'round',},},});graph.render();
以下为完整的主图形样式配置:
属性 | 描述 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
collapsed | 当前节点/组合是否折叠 | boolean | false | |
cursor | 节点鼠标移入样式,配置项 | string | default | |
fill | 节点填充色 | string | #1783FF | |
fillOpacity | 节点填充色透明度 | number | string | 1 | |
increasedLineWidthForHitTesting | 当 lineWidth 较小时,可交互区域也随之变小,有时我们想增大这个区域,让"细线"更容易被拾取到 | number | 0 | |
lineCap | 节点描边端点样式 | round | square | butt | butt | |
lineDash | 节点描边虚线样式 | number[] | - | |
lineDashOffset | 节点描边虚线偏移量 | number | - | |
lineJoin | 节点描边连接处样式 | round | bevel | miter | miter | |
lineWidth | 节点描边宽度 | number | 1 | |
opacity | 节点透明度 | number | string | 1 | |
pointerEvents | 节点如何响应指针事件,配置项 | string | auto | |
shadowBlur | 节点阴影模糊度 | number | - | |
shadowColor | 节点阴影颜色 | string | - | |
shadowOffsetX | 节点阴影在 x 轴方向上的偏移量 | number | string | - | |
shadowOffsetY | 节点阴影在 y 轴方向上的偏移量 | number | string | - | |
shadowType | 节点阴影类型 | inner | outer | outer | |
size | 节点大小,快捷设置节点宽高,配置项 | number | number[] | 32 | |
stroke | 节点描边色 | string | #000 | |
strokeOpacity | 节点描边色透明度 | number | string | 1 | |
transform | transform 属性允许你旋转、缩放、倾斜或平移给定节点 | string | - | |
transformOrigin | 旋转与缩放中心,也称作变换中心 | string | - | |
visibility | 节点是否可见 | visible | hidden | visible | |
x | 节点 x 坐标 | number | 0 | |
y | 节点 y 坐标 | number | 0 | |
z | 节点 z 坐标 | number | 0 | |
zIndex | 节点渲染层级 | number | 0 |
节点大小,快捷设置节点宽高,支持三种配置方式:
pointerEvents
属性控制图形如何响应交互事件,可参考 MDN 文档。
可选值有:visible
| visiblepainted
| visiblestroke
| non-transparent-pixel
| visiblefill
| visible
| painted
| fill
| stroke
| all
| none
| auto
| inherit
| initial
| unset
简而言之,fill
、stroke
和 visibility
都可以独立或组合影响拾取判定行为。目前支持以下关键词:
auto
:默认值,等同于 visiblepainted
none
:永远不会成为响应事件的目标visiblepainted
:满足以下条件才会响应事件:
visibility
设置为 visible
,即图形为可见的fill
取非 none
的值;或者在图形描边区域触发同时 stroke
取非 none
的值visiblefill
:满足以下条件才会响应事件:
visibility
设置为 visible
,即图形为可见的fill
取值的影响visiblestroke
:满足以下条件才会响应事件:
visibility
设置为 visible
,即图形为可见的stroke
取值的影响visible
:满足以下条件才会响应事件:
visibility
设置为 visible
,即图形为可见的fill
和 stroke
取值的影响painted
:满足以下条件才会响应事件:
fill
取非 none
的值;或者在图形描边区域触发同时 stroke
取非 none
的值visibility
取值的影响fill
:满足以下条件才会响应事件:
fill
取值的影响visibility
取值的影响stroke
:满足以下条件才会响应事件:
stroke
取值的影响visibility
取值的影响all
:只要进入图形的填充和描边区域就会响应事件,不会受 fill
、stroke
、visibility
的取值影响使用示例:
// 示例1:只有描边区域响应事件const graph = new Graph({node: {style: {fill: 'none',stroke: '#000',lineWidth: 2,pointerEvents: 'stroke', // 只有描边响应事件},},});// 示例2:完全不响应事件const graph = new Graph({node: {style: {pointerEvents: 'none', // 节点不响应任何事件},},});
可选值有:auto
| default
| none
| context-menu
| help
| pointer
| progress
| wait
| cell
| crosshair
| text
| vertical-text
| alias
| copy
| move
| no-drop
| not-allowed
| grab
| grabbing
| all-scroll
| col-resize
| row-resize
| n-resize
| e-resize
| s-resize
| w-resize
| ne-resize
| nw-resize
| se-resize
| sw-resize
| ew-resize
| ns-resize
| nesw-resize
| nwse-resize
| zoom-in
| zoom-out
标签用于显示节点的文本信息,支持多种样式配置和布局方式。以下是常见的使用场景:
最简单的文本标签配置:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 120,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {labelText: '节点名称',labelFill: '#262626',labelFontSize: 12,labelPlacement: 'bottom',},},});graph.render();
当文本较长时,可以设置自动换行:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 120,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {labelText: '这是一个很长的节点名称需要换行显示',labelWordWrap: true,labelMaxWidth: '150%',labelMaxLines: 3,labelTextOverflow: 'ellipsis',labelFill: '#434343',labelPlacement: 'bottom',labelTextAlign: 'center',},},});graph.render();
为标签添加背景,提高可读性:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 120,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {labelText: '重要节点',labelBackground: true,labelBackgroundFill: 'rgba(250, 140, 22, 0.1)',labelBackgroundRadius: 6,labelPadding: [6, 12],labelFill: '#D4380D',labelFontWeight: 'bold',labelPlacement: 'bottom',},},});graph.render();
以下为完整的标签样式配置:
属性 | 描述 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
label | 是否显示节点标签 | boolean | true | |
labelCursor | 鼠标移入节点标签时显示的样式,配置项 | string | default | |
labelFill | 节点标签文字颜色 | string | - | |
labelFontFamily | 节点标签字体族 | string | - | |
labelFontSize | 节点标签字体大小 | number | 12 | |
labelFontStyle | 节点标签字体样式 | normal | italic | oblique | - | |
labelFontVariant | 节点标签字体变种 | normal | small-caps | string | - | |
labelFontWeight | 节点标签字体粗细 | normal | bold | bolder | lighter | number | - | |
labelLeading | 行间距 | number | 0 | |
labelLetterSpacing | 节点标签字间距 | number | string | - | |
labelLineHeight | 节点标签行高 | number | string | - | |
labelMaxLines | 节点标签最大行数 | number | 1 | |
labelMaxWidth | 节点标签最大宽度,配置项 | number | string | 200% | |
labelOffsetX | 节点标签在 x 轴方向上的偏移量 | number | 0 | |
labelOffsetY | 节点标签在 y 轴方向上的偏移量 | number | 0 | |
labelPadding | 节点标签内边距 | number | number[] | 0 | |
labelPlacement | 节点标签相对于节点主图形的位置,配置项 | string | bottom | |
labelText | 节点标签文字内容 | string | (datum) => string | - | |
labelTextAlign | 节点标签文本水平对齐方式 | start | center | middle | end | left | right | left | |
labelTextBaseline | 节点标签文本基线 | top | hanging | middle | alphabetic | ideographic | bottom | - | |
labelTextDecorationColor | 节点标签文本装饰线颜色 | string | - | |
labelTextDecorationLine | 节点标签文本装饰线 | string | - | |
labelTextDecorationStyle | 节点标签文本装饰线样式 | solid | double | dotted | dashed | wavy | - | |
labelTextOverflow | 节点标签文本溢出处理方式 | clip | ellipsis | string | - | |
labelTextPath | 节点标签文本路径 | Path | - | |
labelWordWrap | 节点标签是否开启自动折行。开启 labelWordWrap 后,超出 labelMaxWidth 的部分自动换行 | boolean | false | |
labelZIndex | 节点标签渲染层级 | number | 0 |
可选值有:left
| right
| top
| bottom
| left-top
| left-bottom
| right-top
| right-bottom
| top-left
| top-right
| bottom-left
| bottom-right
| center
| bottom
开启自动折行 labelWordWrap
后,超出该宽度则换行:
50%
表示标签宽度不超过节点宽度的一半比如,设置多行标签文字:
{"labelWordWrap": true,"labelMaxWidth": 200,"labelMaxLines": 3}
标签背景用于显示节点标签的背景:
属性 | 描述 | 类型 | 默认值 |
---|---|---|---|
labelBackground | 节点标签背景是否显示 | boolean | false |
labelBackgroundCursor | 节点标签背景鼠标移入样式,配置项 | string | default |
labelBackgroundFill | 节点标签背景填充色 | string | - |
labelBackgroundFillOpacity | 节点标签背景透明度 | number | 1 |
labelBackgroundHeight | 节点标签背景高度 | string | number | - |
labelBackgroundLineDash | 节点标签背景虚线配置 | number | string |(number | string )[] | - |
labelBackgroundLineDashOffset | 节点标签背景虚线偏移量 | number | - |
labelBackgroundLineWidth | 节点标签背景描边线宽 | number | - |
labelBackgroundRadius | 节点标签背景圆角半径 - number: 统一设置四个圆角半径 - number[]: 分别设置四个圆角半径,不足则自动补充 | number | number[] | 0 |
labelBackgroundShadowBlur | 节点标签背景阴影模糊程度 | number | - |
labelBackgroundShadowColor | 节点标签背景阴影颜色 | string | - |
labelBackgroundShadowOffsetX | 节点标签背景阴影 X 方向偏移 | number | - |
labelBackgroundShadowOffsetY | 节点标签背景阴影 Y 方向偏移 | number | - |
labelBackgroundStroke | 节点标签背景描边颜色 | string | - |
labelBackgroundStrokeOpacity | 节点标签背景描边透明度 | number | string | 1 |
labelBackgroundVisibility | 节点标签背景是否可见 | visible | hidden | - |
labelBackgroundZIndex | 节点标签背景渲染层级 | number | 1 |
光晕是围绕节点主图形显示的效果,通常用于高亮显示或表示节点的特殊状态。
为节点添加基本的光晕效果:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {lineWidth: 1.5,halo: true,haloStroke: '#1890FF',haloLineWidth: 6,haloStrokeOpacity: 0.3,},},});graph.render();
以下为完整的光晕样式配置:
属性 | 描述 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
halo | 节点光晕是否显示 | boolean | false | |
haloCursor | 节点光晕鼠标移入样式,配置项 | strig | default | |
haloDraggable | 节点光晕是否允许拖拽 | boolean | true | |
haloDroppable | 节点光晕是否允许接收被拖拽的元素 | boolean | true | |
haloFillRule | 节点光晕填充规则 | nonzero | evenodd | - | |
haloFilter | 节点光晕滤镜 | string | - | |
haloLineWidth | 节点光晕描边宽度 | number | 3 | |
haloPointerEvents | 节点光晕效果是否响应指针事件,配置项 | string | none | |
haloStroke | 节点光晕描边色,此属性用于设置节点周围光晕的颜色,帮助突出显示节点 | string | 与主图形的填充色 fill 一致 | |
haloStrokeOpacity | 节点光晕描边色透明度 | number | 0.25 | |
haloVisibility | 节点光晕可见性 | visible | hidden | visible | |
haloZIndex | 节点光晕渲染层级 | number | -1 |
节点图标支持三种常见的使用方式:文字图标、图片图标和 IconFont 图标。下面分别展示这三种方式的配置:
直接使用文字作为图标,适合简单的标识:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {fill: '#FFF0F6',stroke: '#EB2F96',lineWidth: 1.5,iconText: 'A', // 图标文字内容iconFill: '#C41D7F', // 深粉色图标iconFontSize: 16,iconFontWeight: 'bold',},},});graph.render();
使用图片作为图标,支持各种图片格式:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {fill: '#F6FFED',stroke: '#52C41A',lineWidth: 1.5,iconSrc:'',iconWidth: 20,iconHeight: 20,},},});graph.render();
使用 IconFont 字体图标,需要先引入相应的字体文件:
import { Graph, iconfont } from '@antv/g6';const style = document.createElement('style');style.innerHTML = `@import url('${iconfont.css}');`;document.head.appendChild(style);const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {fill: '#E6F7FF', // 淡蓝色背景stroke: '#1890FF', // 蓝色边框lineWidth: 1.5,iconFontFamily: 'iconfont',iconText: '\ue602',iconFill: '#1890FF',},},});graph.render();
以下为完整的图标样式配置:
属性 | 描述 | 类型 | 默认值 |
---|---|---|---|
icon | 是否显示节点图标 | boolean | true |
iconFill | 节点图标文字颜色 | string | - |
iconFontFamily | 节点图标字体族 | string | - |
iconFontSize | 节点图标字体大小 | number | 16 |
iconFontStyle | 节点图标字体样式 | normal | italic | oblique | normal |
iconFontVariant | 节点图标字体变种 | normal | small-caps | string | normal |
iconFontWeight | 节点图标字体粗细 | number | string | normal |
iconHeight | 节点图标高度 | number | 主图形高度的一半 |
iconLetterSpacing | 节点图标文本字间距 | number | string | - |
iconLineHeight | 节点图标文本行高 | number | string | - |
iconMaxLines | 节点图标文本最大行数 | number | 1 |
iconRadius | 节点图标圆角半径 | number | 0 |
iconSrc | 节点图片来源。其优先级高于 iconText | string | - |
iconText | 节点图标文字 | string | - |
iconTextAlign | 节点图标文本水平对齐方式 | start | center | middle | end | left | right | left |
iconTextBaseline | 节点图标文本基线 | top | hanging | middle | alphabetic | ideographic | bottom | alphabetic |
iconTextDecorationColor | 节点图标文本装饰线颜色 | string | - |
iconTextDecorationLine | 节点图标文本装饰线 | string | - |
iconTextDecorationStyle | 节点图标文本装饰线样式 | solid | double | dotted | dashed | wavy | solid |
iconTextOverflow | 节点图标文本溢出处理方式 | clip | ellipsis | string | clip |
iconWidth | 节点图标宽度 | number | 主图形宽度的一半 |
iconWordWrap | 节点图标文本是否自动换行 | boolean | - |
徽标是节点上显示的小标记,通常用于展示状态、数量或其他辅助信息。支持多个徽标同时显示,并可自定义位置。
为节点添加一个简单的徽标:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {badges: [{ text: 'NEW' }, // 默认显示在上方],},},});graph.render();
为节点添加多个不同位置的徽标:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {badge: true, // 是否显示徽标badges: [{ text: 'A', placement: 'right-top' },{ text: 'Important', placement: 'right' },{ text: 'Notice', placement: 'right-bottom' },],badgePalette: ['#7E92B5', '#F4664A', '#FFBE3A'], // 徽标的背景色板badgeFontSize: 7, // 徽标字体大小},},});graph.render();
完全自定义徽标的外观:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {badges: [{text: '99+',placement: 'right-top',backgroundFill: '#FF4D4F', // 红色背景fill: '#fff', // 白色文字fontSize: 10,padding: [2, 6],backgroundRadius: 8,},],},},});graph.render();
以下为完整的徽标样式配置:
属性 | 描述 | 类型 | 默认值 |
---|---|---|---|
badge | 节点是否显示徽标 | boolean | true |
badgePalette | 节点徽标的背景色板 | string[] | [#7E92B5 , #F4664A , #FFBE3A ] |
badges | 节点徽标设置 | BadgeStyleProps[] | - |
属性 | 描述 | 类型 | 默认值 |
---|---|---|---|
background | 节点徽标是否显示背景 | boolean | true |
backgroundCursor | 节点徽标背景鼠标移入样式,配置项 | string | default |
backgroundFill | 节点徽标背景填充色。若不指定,优先考虑 badgePalette 按顺序分配 | string | - |
backgroundFillOpacity | 节点徽标背景填充透明度 | number | 1 |
backgroundFilter | 节点徽标背景滤镜 | string | - |
backgroundHeight | 节点徽标背景高度 | number | string | - |
backgroundLineDash | 节点徽标背景虚线配置 | number | string |(number | string )[] | - |
backgroundLineDashOffset | 节点徽标背景虚线偏移量 | number | - |
backgroundLineWidth | 节点徽标背景描边线宽 | number | - |
backgroundRadius | 节点徽标背景圆角半径 - number: 统一设置四个圆角半径 - number[]: 分别设置四个圆角半径,会补足缺省的分量 - string: 与 CSS padding 属性类似,使用空格分隔 | number | number[] | string | 0 |
backgroundShadowBlur | 节点徽标背景阴影模糊程度 | number | - |
backgroundShadowColor | 节点徽标背景阴影颜色 | string | - |
backgroundShadowOffsetX | 节点徽标背景阴影 X 方向偏移 | number | - |
backgroundShadowOffsetY | 节点徽标背景阴影 Y 方向偏移 | number | - |
backgroundStroke | 节点徽标背景描边颜色 | string | - |
backgroundStrokeOpacity | 节点徽标背景描边透明度 | number | string | 1 |
backgroundVisibility | 节点徽标背景是否可见 | visible | hidden | - |
backgroundZIndex | 节点徽标背景渲染层级 | number | - |
fill | 节点徽标文字颜色 | string | - |
fontFamily | 节点徽标字体族 | string | - |
fontSize | 节点徽标字体大小 | number | 8 |
fontStyle | 节点徽标字体样式 | normal | italic | oblique | normal |
fontVariant | 节点徽标字体变种 | normal | small-caps | string | normal |
fontWeight | 节点徽标字体粗细 | number | string | normal |
lineHeight | 节点徽标行高 | string | number | - |
lineWidth | 节点徽标行宽 | string | number | - |
maxLines | 节点徽标文本最大行数 | number | 1 |
offsetX | 节点徽标在 x 轴方向上的偏移量 | number | 0 |
offsetY | 节点徽标在 y 轴方向上的偏移量 | number | 0 |
padding | 节点徽标内边距 | number | number[] | 0 |
placement | 节点徽标相对于节点主图形的位置。若不指定,默认从右上角顺时针依次排放 | left | right | top | bottom | left-top | left-bottom | right-top | right-bottom | top-left | top-right | bottom-left | bottom-right | - |
text | 节点徽标文字内容 | string | - |
textAlign | 节点徽标文本水平对齐方式 | start | center | middle | end | left | right | left |
textBaseline | 节点徽标文本基线 | top | hanging | middle | alphabetic | ideographic | bottom | alphabetic |
textDecorationColor | 节点徽标文本装饰线颜色 | string | - |
textDecorationLine | 节点徽标文本装饰线 | string | - |
textDecorationStyle | 节点徽标文本装饰线样式 | solid | double | dotted | dashed | wavy | solid |
textOverflow | 节点徽标文本溢出处理方式 | clip | ellipsis | string | clip |
visibility | 节点徽标是否可见 | visible | hidden | - |
wordWrap | 节点徽标文本是否自动换行 | boolean | - |
zIndex | 节点徽标渲染层级 | number | 3 |
连接桩是节点上的连接点,用于连接边。支持在节点的不同位置添加多个连接桩,并可自定义样式。
为节点添加四个基本方向的连接桩:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {port: true,ports: [{ key: 'top', placement: 'top', fill: '#7E92B5' },{ key: 'right', placement: 'right', fill: '#F4664A' },{ key: 'bottom', placement: 'bottom', fill: '#FFBE3A' },{ key: 'left', placement: 'left', fill: '#D580FF' },],portR: 3,portLineWidth: 1,portStroke: '#fff',},},});graph.render();
使用百分比或绝对坐标精确定位连接桩:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {ports: [{ key: 'custom1', placement: [0.2, 0] }, // 相对位置:左上角20%处{ key: 'custom2', placement: [0.8, 0] }, // 相对位置:右上角80%处{ key: 'custom3', placement: [1, 0.5] }, // 相对位置:右边中央],portR: 4,portLineWidth: 1,portStroke: '#fff',},},});graph.render();
为不同的连接桩设置不同的样式:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: { nodes: [{ id: 'node1' }] },node: {style: {ports: [{key: 'input',placement: 'left',fill: '#52C41A', // 绿色输入桩r: 4,},{key: 'output',placement: 'right',fill: '#FF4D4F', // 红色输出桩r: 4,},],portStroke: '#fff', // 统一的描边颜色portLineWidth: 2,},},});graph.render();
以下为完整的连接桩样式配置:
属性 | 描述 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
port | 节点是否显示连接桩 | boolean | true | |
ports | 节点连接桩配置项,支持配置多个连接桩 | PortStyleProps[] |
属性 | 描述 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
key | 节点连接桩的键值,默认为节点连接桩的索引 | string | - | |
placement | 节点连接桩相对于节点主图形的位置 | left | right | top | bottom | center | left-top | left-bottom | right-top | right-bottom | top-left | top-right | bottom-left | bottom-right | [number, number] | - | ✓ |
r | 节点连接桩半径 - 如果设置为 undefined,则连接桩被视为一个点,不在画布上显示但存在,边会优先连接到最近的连接桩 - 如果设置为数字,则连接桩被视为一个圆,圆的半径由此处指定 | number | - | |
linkToCenter | 边是否连接到节点连接桩的中心 - 若为 true,则边连接到节点连接桩的中心 - 若为 false,则边连接到节点连接桩的边缘 | boolean | false | |
cursor | 节点连接桩鼠标移入样式,配置项 | string | default | |
fill | 节点连接桩填充颜色 | string | - | |
fillOpacity | 节点连接桩填充透明度 | number | 1 | |
isBillboard | 节点连接桩是否为Billboard 效果 | boolean | - | |
isSizeAttenuation | 节点连接桩是否启用大小衰减 | boolean | - | |
lineDash | 节点连接桩描边虚线配置 | number | string |(number | string )[] | - | |
lineDashOffset | 节点连接桩描边虚线偏移量 | number | - | |
lineWidth | 节点连接桩描边线宽 | number | - | |
shadowBlur | 节点连接桩阴影模糊程度 | number | - | |
shadowColor | 节点连接桩阴影颜色 | string | - | |
shadowOffsetX | 节点连接桩阴影 X 方向偏移 | number | - | |
shadowOffsetY | 节点连接桩阴影 Y 方向偏移 | number | - | |
stroke | 节点连接桩描边颜色 | string | - | |
strokeOpacity | 节点连接桩描边透明度 | number | string | 1 | |
visibility | 节点连接桩是否可见 | visible | hidden | visible | |
zIndex | 节点连接桩渲染层级 | number | 2 |
在一些交互行为中,比如点击选中一个节点或鼠标悬停激活一个边,仅仅是在该元素做了某些状态的标识。为了将这些状态反应到终端用户所见的视觉空间中,我们需要为不同的状态设置不同的图元素样式,以响应该图元素状态的变化。
G6 提供了几种内置的状态,包括选中(selected)、高亮(highlight)、激活(active)、不活跃(inactive)和禁用(disabled)。此外,它还支持自定义状态,以满足更特定的需求。对于每个状态,开发者可以定义一套样式规则,这些规则会覆盖元素的默认样式。
数据结构如下:
type NodeState = {[state: string]: NodeStyle;};
例如,当节点处于 focus
状态时,可以为其添加一个宽度为 3 且颜色为橙色的描边。
const graph = new Graph({node: {state: {focus: {lineWidth: 3, // 描边宽度stroke: 'orange', // 描边颜色},},},});
效果如下图所示:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 200,height: 100,autoFit: 'center',data: {nodes: [{ id: 'node1', states: ['focus'] }],},node: {state: {focus: {lineWidth: 3,stroke: 'orange',},},},});graph.render();
定义节点的动画效果,支持下列两种配置方式:
{"node": {"animation": false}}
阶段动画是指节点在进入画布、更新、离开画布时的动画效果。目前支持的阶段包括:
enter
: 节点进入画布时的动画update
: 节点更新时的动画exit
: 节点离开画布时的动画show
: 节点从隐藏状态显示时的动画hide
: 节点隐藏时的动画collapse
: 节点收起时的动画expand
: 节点展开时的动画你可以参考 动画范式 使用动画语法来配置节点,如:
{"node": {"animation": {"update": [{"fields": ["x", "y"], // 更新时只对 x 和 y 属性进行动画"duration": 1000, // 动画持续时间"easing": "linear" // 缓动函数}],}}
也可以使用内置的动画效果:
{"node": {"animation": {"enter": "fade", // 使用渐变动画"update": "translate", // 使用平移动画"exit": "fade" // 使用渐变动画}}}
你可以传入 false 来关闭特定阶段的动画:
{"node": {"animation": {"enter": false // 关闭节点入场动画}}}
定义节点的色板,即预定义节点颜色池,并根据规则进行分配,将颜色映射到 fill
属性。
有关色板的定义,请参考 色板。
属性 | 描述 | 类型 | 默认值 |
---|---|---|---|
color | 色板颜色。如果色板注册过,可以直接指定其注册名,也接受一个颜色数组 | string | string[] | - |
field | 指定元素数据中的分组字段。若不指定,默认取 id 作为分组字段 | string | ((datum) => string) | id |
invert | 是否反转色板 | boolean | false |
type | 指定当前色板类型。 - group : 离散色板 - value : 连续色板 | group | value | group |
如将一组数据按 category
字段分配节点颜色,使得同类别的节点颜色相同:
{"node": {"palette": {"type": "group","field": "category","color": ["#1783FF", "#F08F56", "#D580FF", "#00C9C9", "#7863FF"]}}}
效果如下图所示:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 600,height: 100,data: {nodes: new Array(10).fill(0).map((_, i) => ({ id: `node-${i}`, data: { category: ['A', 'B', 'C', 'D', 'E'][i % 5] } })),},layout: { type: 'grid', cols: 10 },node: {palette: {type: 'group',field: 'category',color: ['#1783FF', '#F08F56', '#D580FF', '#00C9C9', '#7863FF'],},},});graph.render();
也可以使用默认配置:
{"node": {"palette": "tableau" // tableau 为色板名,默认根据 ID 分配颜色}}
效果如下图所示:
import { Graph } from '@antv/g6';const graph = new Graph({container: 'container',width: 600,height: 100,data: {nodes: new Array(10).fill(0).map((_, i) => ({ id: `node-${i}`, data: { category: ['A', 'B', 'C', 'D', 'E'][i % 5] } })),},layout: { type: 'grid', cols: 10 },node: {palette: 'tableau',},});graph.render();