AntV X6自定义连接线样式(Vue3+TypeScript)

效果图如下:(连接线是有动画的,模拟数据传输特效)

核心代码:

在创建画布的时候即可设置连接线样式,通过createEdge属性即可实现,代码如下:

复制代码
    connecting: {
      snap: {
        radius: 50, //自动吸附,并设置自动吸附路径
      },
      allowBlank: false, // 是否允许连接到画布空白位置的点(就是能不能拉线连空白的地方)
      allowLoop: false, // 是否允许创建循环连线,即边的起始节点和终止节点为同一节点,就是能不能自我连线(箭头不能穿过仪器)
      allowNode:false, //是否允许边连接到节点(非节点上的连接桩),默认为 true 。(就是要让它必须连接到连接桩,连接到节点不行)
      allowEdge:false, //是否可以同一个起点终点,在箭头的线中间加一个箭头,就是一条线能一直加箭头
      allowMulti: true, // 是否可以一个起点连多个终点
      highlight: true, // 拖动边时,是否高亮显示所有可用的连接桩或节点,默认值为 false 。一般都会与 highlighting 联合使用。
      createEdge() {
        return new Shape.Edge({
          attrs: {
            line: {
              stroke: '#1890ff',
              strokeDasharray: 5,
              style: {
                animation: 'ant-line 30s infinite linear',
              },
              strokeWidth: 2,    // 设置连接线宽度
              targetMarker: null, // 去掉终点箭头
              sourceMarker: null, // 去掉起点箭头
            },
          },
        });
      },
    },

在全局注册连接线特效,方便AntVX6检测到样式。

复制代码
<template>
  <RouterView />
</template>

<script setup lang="ts">


</script>


<style>
body {
  margin: 0; /* 修正了这里的拼写错误 */
  padding: 0;
}
/* 连接线特效 */
@keyframes ant-line {
  to {
    stroke-dashoffset: -1000;
  }
}
</style>

总体代码如下:

复制代码
  graph.value = new Graph({
    width: 1958,
    height: 1240,
    panning:true,
    mousewheel:true,
    background: {
      color: '#f0f7fc',
    },
    container: document.getElementById('antvcontainer')!, // 断言该值不为 null
    grid: {
      visible: true,
      type: 'doubleMesh',
      args: [
        {
          color: '#eee', // 主网格线颜色
          thickness: 1, // 主网格线宽度
        },
        {
          color: '#ddd', // 次网格线颜色
          thickness: 1, // 次网格线宽度
          factor: 4, // 主次网格线间隔
        },
      ],
    },
    //连线交互
    connecting: {
      snap: {
        radius: 50, //自动吸附,并设置自动吸附路径
      },
      allowBlank: false, // 是否允许连接到画布空白位置的点(就是能不能拉线连空白的地方)
      allowLoop: false, // 是否允许创建循环连线,即边的起始节点和终止节点为同一节点,就是能不能自我连线(箭头不能穿过仪器)
      allowNode:false, //是否允许边连接到节点(非节点上的连接桩),默认为 true 。(就是要让它必须连接到连接桩,连接到节点不行)
      allowEdge:false, //是否可以同一个起点终点,在箭头的线中间加一个箭头,就是一条线能一直加箭头
      allowMulti: true, // 是否可以一个起点连多个终点
      highlight: true, // 拖动边时,是否高亮显示所有可用的连接桩或节点,默认值为 false 。一般都会与 highlighting 联合使用。
      createEdge() {
        return new Shape.Edge({
          attrs: {
            line: {
              stroke: '#1890ff',
              strokeDasharray: 5,
              style: {
                animation: 'ant-line 30s infinite linear',
              },
              strokeWidth: 2,    // 设置连接线宽度
              targetMarker: null, // 去掉终点箭头
              sourceMarker: null, // 去掉起点箭头
            },
          },
        });
      },
    },
    //高亮器
    highlighting:{
      // 当连接桩可以被链接时,在连接桩外围渲染一个 2px 宽的红色矩形框
      magnetAvailable: {
        name: 'stroke',
        args: {
          padding: 4,
          attrs: {
            'stroke-width': 2,
            stroke: 'red',
          },
        },
      }
    },

  });
相关推荐
小笔学长5 分钟前
Mixin 模式:灵活组合对象功能
开发语言·javascript·项目实战·前端开发·mixin模式
我是人机不吃鸭梨6 分钟前
Flutter 桌面端开发终极指南(2025版):构建跨平台企业级应用的完整解决方案
开发语言·javascript·人工智能·flutter·架构
Gogym8 分钟前
解决vue axios提交日期,服务器接收少一天的问题
前端·javascript·vue.js
韭菜炒大葱14 分钟前
LangChain 二:输出结果定制与历史管理能力详解
前端·langchain·openai
明月_清风16 分钟前
不止是代码堆放:带你全面掌握 Monorepo 核心技术与选型
前端
Aliex_git17 分钟前
Vue2 - Watch 侦听器源码理解
前端·javascript·vue.js·笔记·学习
你疯了抱抱我19 分钟前
【QQ】空间说说批量删除脚本(不用任何额外插件,打开F12控制台即可使用)
开发语言·前端·javascript
进击的野人24 分钟前
Vuex 详解:现代 Vue.js 应用的状态管理方案
前端·vue.js·前端框架
未知原色24 分钟前
前端工程师转型AI的优势与挑战
前端·人工智能
鹏北海25 分钟前
Single-SPA 学习总结
前端·javascript·微服务