需求
话不多说,直接上效果图!
简单来说,就是需要画出中心实体依赖的以及被依赖的关系图,并且能够切换中心实体且展示其依赖。
实现
第一步需要从x6官网找到贴合依赖的例子,最终选中的是Dagre布局,贴合依赖下游的场景,如下图:
解析官网实现:
ts
const data: Model.FromJSONData = {
nodes: [],//节点
edges: [],//边
}
const edges = [ //左边👈:被依赖ID,右边👉:依赖的ID
['1', '2'],
['2', '3'],
['2', '4'],
['4', '5'],
['4', '6'],
['4', '7'],
['4', '8'],
['5', '9'],
['6', '10'],
['7', '11'],
['8', '12'],
]
for (let i = 1; i <= 12; i++) {
data.nodes!.push({ //节点配置
id: `${i}`,
shape: 'circle',
width: 32,
height: 32,
label: i,
attrs: {
body: {
fill: '#5F95FF',
stroke: 'transparent',
},
label: {
fill: '#ffffff',
},
},
})
}
edges.forEach((edge: [string, string]) => {
data.edges!.push({ //边的关系配置
source: edge[0], //连接的头
target: edge[1],//连接尾
attrs: {
line: {
stroke: '#A2B1C3',
strokeWidth: 2,
},
},
})
})
const graph = new Graph({
container: document.getElementById('container')!,
})
const dagreLayout = new DagreLayout({
type: 'dagre',
rankdir: 'LR',
align: 'UR',
ranksep: 35,
nodesep: 15,
})
const model = dagreLayout.layout(data)
graph.fromJSON(model)
主要是data的节点nodes配置和对应的边edges配置的整合,看懂了官网的实现,就只要思考以下三个问题:
1、实体节点之间的关系如何表示
2、如何自定义节点
3、如何自定义箭头以及连接路由
只要解决以上三个问题,那么慢慢就能实现啦。接下来就逐一分析吧~
实体节点之间的关系如何表示
我们认真看官网的示例代码,就能看出实现节点的关系其实是在设置边的关系,就是只需要设置好Edge的source和target
,所以我们只需要把Edge整理成两部分,然后遍历设置就好啦:
中心实体依赖的: [中心实体,中心实体依赖的实体]、
依赖中心实体的:[依赖中心实体的实体,中心实体]
获取数据的接口数据格式如下:
arduino
export const MOCK_DATA = {
//中心实体
bizEntity: {
},
//中心实体依赖的
relatedBizEntities: [
],
//依赖中心实体的
beRelatedBizEntities: [
]
};
如何自定义节点
接下来就是节点的问题。官网上简单配置得到的节点显然不是需求所需要的样子。我们需要自定义节点,这样节点想写成什么样就写成什么样。 于是再找找节点的官网例子:找到啦找到啦使用antv/x6-react-shape库可以自定义node节点组件。这样问题就简单啦。
如何自定义连接线以及连接路由
我们看官网的例子的箭头不符合需求,所以就需要配置我们自己的箭头。从官网的例子可以看到,我们在定义边关系的时候,就有在设置边的样式配置,比如,stroke,strokeWidth等。所以我们就需要再从官网去寻找 自定义箭头,也就是设置sourceMarker和targetMarker的d属性,详情可见:自定义箭头path。再设置router就可以使连线更丝滑。
代码实现
详细代码前往: codepen
踩坑:
1、需要初始化画布之后再请求数据,请求数据之后再创建创建DagreLayout布局。
2、中心实体切换的时候需要重新初始化画布,将上一层的画布清空。(此代码未实现中心实体的切换)
总结
平常不怎么接触图形的实现,一开始会无从下手,多看看官网例子+官网API,大胆尝试,慢慢就能解决啦~