基于X6的依赖关系图

需求

话不多说,直接上效果图!

简单来说,就是需要画出中心实体依赖的以及被依赖的关系图,并且能够切换中心实体且展示其依赖。

实现

第一步需要从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,大胆尝试,慢慢就能解决啦~

相关推荐
mapbar_front20 分钟前
面试问题—上家公司的离职原因
前端·面试
昔人'1 小时前
css使用 :where() 来简化大型 CSS 选择器列表
前端·css
昔人'1 小时前
css `dorp-shadow`
前端·css
流***陌1 小时前
扭蛋机 Roll 福利房小程序前端功能设计:融合趣味互动与福利适配
前端·小程序
可触的未来,发芽的智生1 小时前
新奇特:黑猫警长的纳米世界,忆阻器与神经网络的智慧
javascript·人工智能·python·神经网络·架构
烛阴2 小时前
用 Python 揭秘 IP 地址背后的地理位置和信息
前端·python
前端开发爱好者2 小时前
尤雨溪官宣:"新玩具" 比 Prettier 快 45 倍!
前端·javascript·vue.js
why技术2 小时前
从18w到1600w播放量,我的一点思考。
java·前端·后端
欧阳呀2 小时前
Vue+element ui导入组件封装——超级优雅版
前端·javascript·vue.js·elementui
清风徐来QCQ2 小时前
css总结
前端