@antv/x6 再vue中 ,自定义图形,画流程图、数据建模、er图等图形

X6 是基于 HTML 和 SVG 的图编辑引擎,提供低成本的定制能力和开箱即用的内置扩展,方便我们快速搭建 DAG 图、ER 图、流程图、血缘图等应用。

最终效果图

1.安装

npm install @antv/x6 --save  //x6主要包

npm install  @antv/x6-vue-shape  //使用vue组件画图插件
npm install @antv/x6-plugin-dnd //拖拽 添加元素图形插件

2.直接上代码

dom元素 form.vue

<template><!-- 新增、编辑弹窗--><el-dialog width="1200px" class="flow-dialog" top="5vh" title="实体编辑" :visible.sync="show" :append-to-body="true" :close-on-click-modal = "false" v-el-drag-dialog><div class="content"><!--左侧工具栏--><div class="stencil" ><p>流程编辑器</p><span @mousedown="startDragToGraph(item, $event)" v-for="item in list" :key="item" @click="test(item)" class="percentage-value"><i style="margin-right: 5px;cursor: pointer;"  class="el-icon-setting"/><span class="percentage-content">{{ item }}</span></span></div><div class="panel"><!--流程图工具栏--><div class="toolbar"><el-button class="float-btn" icon="el-icon-s-claim" type="primary" @click="save()">保存</el-button><el-button class="float-btn" icon="el-icon-s-home" type="danger" @click="show=false">退出</el-button><el-button style="margin-left: 100px;" class="float-btn" icon="el-icon-s-tools" type="success" @click="">设置预览参数</el-button><el-button class="float-btn" icon="el-icon-notebook-2" type="info" @click="">预览节点数据</el-button><el-button class="float-btn" icon="el-icon-refresh" type="success" @click="">重算预览数据</el-button></div><!--流程图画板--><div id="containerShape" /></div></div></el-dialog></template>

js部分

<script>import elDragDialog from '@/directive/el-drag-dialog'import { register } from '@antv/x6-vue-shape'import { Graph,Shape} from "@antv/x6";import CustomNode from './CustomNode.vue'import { Dnd } from '@antv/x6-plugin-dnd'export default {directives: { elDragDialog },data() {return {show:false,list: ['数据查询', '横向连接', '追加合并', '分组汇总', '数据过滤','字段设置','输出'],graph:{}}},mounted() {const attrs = {circle: {r: 4,magnet: true,fill: '#fff',stroke: '#85A5FF',strokeWidth: 1,},};register({shape: 'custom-vue-node',component: CustomNode,width: 180,height: 40,// port默认不可见ports: {groups: {in: {position: {name:'left',args: {dx: -10,y: '50%',},},attrs: attrs},out: {position: {name:'right',args: {x: '100%',dx: 10,y: '50%',},},attrs: attrs},},},})},methods: {open() {this.show = true;this.$nextTick(() => {this.init("containerShape");});},init(id){const graph = new Graph({container: document.getElementById(id),width: 1000,height: 1000,connecting: {router: 'manhattan',anchor: 'center',connectionPoint: 'anchor',createEdge() {return new Shape.Edge({attrs: {line: {stroke: '#52c41a',strokeWidth: 1,strokeDasharray: 5,targetMarker: 'classic',style: {animation: 'ant-line 30s infinite linear',},},},zIndex: 0,})},}})graph.addNode({shape: 'custom-vue-node',x: 100,y: 100,ports: [{group: 'in'},{group: 'out'}],data:{percentage: 30}})this.graph = graph;},save() {this.graph.addNode({shape: 'custom-vue-node',x: 200,y: 300,ports: [{group: 'in'},{group: 'out'}],data:{percentage: '数据流程飒飒飒飒拉开阿斯兰的卡死了的科目来打开'}})},// 自定义一个拖拽方法,也可以单独封装成一个js文件(方便调用)// 这里直接写到vue文件的methods方法里了// 需求:未置灰的可以拖拽,置灰的无法拖拽即禁用状态startDragToGraph(item, e) {const node = this.graph.createNode({shape: 'custom-vue-node',x: 200,y: 300,ports: [{group: 'in'},{group: 'out'}],data:{percentage: item}});const dnd = new Dnd({target: this.graph,// ☆拖拽结束时,验证节点是否可以放置到目标画布中。validateNode: () => {console.log('成功拖拽至目标画布')},})dnd.start(node, e)},}}
</script>

css部分

<style type="text/css">@keyframes ant-line {to {stroke-dashoffset: -1000}}
</style><style type="text/css" scoped>.flow-dialog ::v-deep .el-dialog__body{max-height: 85vh;padding: 0;}.toolbar ::v-deep .el-button--small{padding: 5px 10px;}.content {width: 1180px;height: 85vh;display: flex;}.stencil {width: 230px;height: 100%;position: relative;margin-right: 10px;border-right: 1px solid rgba(0, 0, 0, 0.08);box-sizing: border-box;text-align: center;}.stencil p{margin: 0;line-height: 37px;border-bottom: 1px solid #00000008;background-color: #f7f9fb;font-size: 14px;padding-left: 5px;text-align: left;}.panel {width: calc(100% - 230px);height: 100%;}.panel .toolbar {width: 100%;height: 38px;display: flex;align-items: center;background-color: #f7f9fb;border-bottom: 1px solid rgba(0, 0, 0, 0.08);}.panel #containerShape {width: 100%;height: calc(100% - 10px) !important;}.percentage-value{display: inline-block;width: max-content;background-color: #fff;border: 1px solid #c2c8d5;border-left: 4px solid #5F95FF;border-radius: 4px;box-shadow: 0 2px 5px 1px rgba(0, 0, 0, 0.06);padding: 8px;font-size: 16px;margin-top: 10px;text-align: left;}.percentage-content{width: 100px;max-width: 150px;overflow: hidden;font-size: 12px;display: inline-block;}</style>

CustomNode.vue节点元素dom

<template><span class="percentage-value"><i style="margin-right: 5px;cursor: pointer;" @click="save()" class="el-icon-setting"/><span class="percentage-content">{{ percentage }}%</span><i @click="save()" class="el-icon-success data-start"/></span>
</template><script>export default {inject: ['getNode'],data() {return {percentage: 50,}},mounted() {const cell = this.getNode();this.percentage = cell.data.percentage;},methods: {save(){console.log("点击成功")}}}
</script>
<style type="text/css" scoped>.percentage-value{display: inline-block;width: max-content;background-color: #fff;border: 1px solid #c2c8d5;border-left: 4px solid #5F95FF;border-radius: 4px;box-shadow: 0 2px 5px 1px rgba(0, 0, 0, 0.06);padding: 10px;font-size: 16px;}.percentage-content{width: 100px;max-width: 150px;overflow: hidden;font-size: 12px;display: inline-block;}.data-start{margin-right: 5px;margin-left: 10px;cursor: pointer;color: #6bcc00;}
</style>

相关官方文档x6.antv官网

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/62878.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2.4特征预处理(机器学习)

2.4特征预处理 2.4.1 什么是特征预处理 通过 一些转换函数将特征数据转换成更加适合算法模型的特征数据过程。 1 包含内容 数值型数据的无量纲化&#xff1a; 归一化 标准化 2 特征预处理API sklearn.preprocessing 为什么要进行归一化/标准化&#xff1f; 特征的单…

前端、后端、测试?如何选择

目录 一、前端开发 &#xff08;一&#xff09;职业概述 &#xff08;二&#xff09;需学习的技术 二、后端开发 &#xff08;一&#xff09;职业概述 &#xff08;二&#xff09;需学习的技术 三、测试 &#xff08;一&#xff09;职业概述 &#xff08;二&#xff0…

AI - 谈谈RAG中的查询分析(2)

AI - 谈谈RAG中的查询分析&#xff08;2&#xff09; 大家好&#xff0c;RAG中的查询分析是比较有趣的一个点&#xff0c;内容丰富&#xff0c;并不是一句话能聊的清楚的。今天接着上一篇&#xff0c;继续探讨RAG中的查询分析&#xff0c;并在功能层面和代码层面持续改进。 功…

hadoop环境配置-创建hadoop用户+更新apt+安装SSH+配置Java环境

一、创建hadoop用户(在vm安装的ubantu上打开控制台) 1、sudo useradd -m hadoop -s /bin/bash &#xff08;创建hadoop用户&#xff09; 2、sudo passwd hadoop (设置密码) 3、sudo adduser hadoop sudo&#xff08;将新建的hadoop用户设置为管理员&#xff09; 执行如下图 将…

大数据新视界 -- Hive 数据湖架构中的角色与应用(上)(25 / 30)

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

SpringMVC:参数传递之日期类型参数传递

环境准备和参数传递请见&#xff1a;SpringMVC参数传递环境准备 日期类型比较特殊&#xff0c;因为对于日期的格式有N多中输入方式&#xff0c;比如: 2088-08-182088/08/1808/18/2088… 针对这么多日期格式&#xff0c;SpringMVC该如何接收&#xff0c;它能很好的处理日期类…

jmeter如何导出中文版的测试报告?

文章目录 0、初始步骤&#xff1a;把报告模板换成中文形式1、首先添加一份聚合报告2、然后点开【聚合报告】3&#xff0c;生成报告3.1 选择【工具】-【generate HTML report】3.2 【generate HTML report】参数详解3.3 、最后点击 【generate report】直接生成。 声明&#xff…

基于IPD双轮驱动, 打破产品同质化竞争魔咒

在当今竞争激烈的商业环境中&#xff0c;产品同质化现象愈发严重&#xff0c;企业面临着巨大的挑战。如何在众多相似产品中脱颖而出&#xff0c;赢得客户的青睐并获取持续的竞争优势&#xff0c;成为企业亟待解决的关键问题。基于 IPD 双轮驱动的产品开发模式&#xff0c;为企业…

2.mysql 中一条更新语句的执行流程是怎样的呢?

前面我们系统了解了一个查询语句的执行流程&#xff0c;并介绍了执行过程中涉及的处理模块。 相信你还记得&#xff0c;一条查询语句的执行过程一般是经过连接器、分析器、优化器、执行器等功能模块&#xff0c;最后到达存储引擎。 那么&#xff0c;一条更新语句的执行流程又…

【LeetCode每日一题】——204.计数质数

文章目录 一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【题目提示】七【解题思路】八【时空频度】九【代码实现】十【提交结果】 一【题目类别】 数组 二【题目难度】 中等 三【题目编号】 204.计数质数 四【题目描述】 给定整数 n &…

【数据事务】.NET开源 ORM 框架 SqlSugar 系列

.NET开源 ORM 框架 SqlSugar 系列 【开篇】.NET开源 ORM 框架 SqlSugar 系列【入门必看】.NET开源 ORM 框架 SqlSugar 系列【实体配置】.NET开源 ORM 框架 SqlSugar 系列【Db First】.NET开源 ORM 框架 SqlSugar 系列【Code First】.NET开源 ORM 框架 SqlSugar 系列【数据事务…

【机器学习】机器学习的基本分类-监督学习-决策树-ID3 算法

ID3&#xff08;Iterative Dichotomiser 3&#xff09;是决策树的一种构造算法&#xff0c;由 Ross Quinlan 在 1986 年提出。它主要用于分类问题&#xff0c;通过信息增益选择特征来构建决策树。ID3 假设数据是离散型特征&#xff0c;且不支持连续型数据。 1. 核心思想 划分标…

JAVA |日常开发中读写XML详解

JAVA &#xff5c;日常开发中读写XML详解 前言一、XML 简介二、在 Java 中读取 XML2.1 使用 DOM&#xff08;Document Object Model&#xff09;方式读取 XML2.2 使用 SAX&#xff08;Simple API for XML&#xff09;方式读取 XML 三、在 Java 中写入 XML3.1 使用 DOM 方式写入…

ISAAC SIM踩坑记录--Omniverse Launcher添加代理

最近Omniverse Launcher不知道又抽什么疯&#xff0c;在Exchange界面安装各种软件都不成功&#xff0c;报错如下&#xff1a; FetchError: request to https://launcher-index-prod.s3.amazonaws.com/en/components.json failed, reason: Client network socket disconnected…

ECharts柱状图-交错正负轴标签,附视频讲解与代码下载

引言&#xff1a; 在数据可视化的世界里&#xff0c;ECharts凭借其丰富的图表类型和强大的配置能力&#xff0c;成为了众多开发者的首选。今天&#xff0c;我将带大家一起实现一个柱状图图表&#xff0c;通过该图表我们可以直观地展示和分析数据。此外&#xff0c;我还将提供…

07《缓存》计算机组成与体系结构 系列课

目录 深入了解缓存内存 缓存的重要性 游戏中的存储需求与主内存 虚拟内存和按需分页 现代系统中的多级缓存 缓存级别的大小与速度 缓存相关的术语 缓存命中与未命中 页面命中与缺页 局部性原理 结语 深入了解缓存内存 大家好&#xff0c;欢迎来到今天的课程。上节课…

FPGA实战篇(触摸按键控制LED灯)

1.触摸按键简介 触摸按键主要可分为四大类&#xff1a;电阻式、电容式、红外感应式以及表面声波式。根据其属性的不同&#xff0c;每种触摸按键都有其合适的使用领域。 电阻式触摸按键由多块导电薄膜按照按键的位置印制而成&#xff0c;但由于耐用性较差且维护复杂&#xff0c…

java基础概念47-ArrayList、LinkList和迭代器

一、ArrayList集合 1-1、ArrayList的两种添加信息的方式 1-2、ArrayList集合底层逻辑 1、利用空参创建的集合&#xff0c;在底层创建一个默认长度为0的数组 2、添加第一个元素时&#xff0c;底层会创建一个新的长度为10的数组 3、存满时&#xff0c;会扩容1.5倍。 4、如果…

C++学习日记---第16天

笔记复习 1.C对象模型 在C中&#xff0c;类内的成员变量和成员函数分开存储 我们知道&#xff0c;C中的成员变量和成员函数均可分为两种&#xff0c;一种是普通的&#xff0c;一种是静态的&#xff0c;对于静态成员变量和静态成员函数&#xff0c;我们知道他们不属于类的对象…

Java基础之网络编程:开启网络通信的神秘之门

一、网络编程概述 网络编程是通过计算机网络进行数据传输和通信的编程技术&#xff0c;在 Java 中&#xff0c;我们可以使用丰富的网络编程功能和 API 来实现不同计算机之间的数据交互。 Java 网络编程是指在 Java 语言中使用网络协议和 API 进行网络通信的编程技术。Java 网络…