最终的效果
配置画布
首先通过npm安装LogicFlow
npm install @logicflow/core --save
在vue页面引用LogicFlow和css
import LogicFlow from "@logicflow/core"; import "@logicflow/core/dist/style/index.css";
创建div容器并添加ref
<div id="container" ref="container"></div>
分别定义container、lf、data
//ref获取div容器 const container = ref(); //用来渲染画布 const lf = ref(); //定义好需要渲染的JSON数据 const data = { // 节点 nodes: [ { id: 1, type: "rect", x: 100, y: 250, text: "开始", }, { id: 2, type: "circle", x: 300, y: 150, text: "进行中", }, { id: 3, type: "circle", x: 300, y: 350, text: "失败了", }, { id: 4, type: "circle", x: 500, y: 250, text: "结束", }, ], // 边 edges: [ { type: "polyline", sourceNodeId: 1, targetNodeId: 2, }, { type: "polyline", sourceNodeId: 1, targetNodeId: 3, }, { type: "polyline", sourceNodeId: 2, targetNodeId: 4, }, ], };
在onMounted中创建实例并渲染画布
onMounted(() => { lf.value = new LogicFlow({ container: container.value, stopScrollGraph: true, //禁止鼠标滚动移动画布 stopZoomGraph: true, //禁止缩放画布 width: 1200, //默认100% height: 800, //默认100% //画布的网格配置 // grid:false, //禁止画布网格 grid: { type: "dot", //mesh方格 size: 20, //间距 }, }); //渲染画布 lf.value.render(data); });
下面是网页渲染出的效果
完整代码
1 <template> 2 <div id="container" ref="container"></div> 3 </template> 4 <script lang="ts" setup> 5 import { ref, onMounted } from "vue"; 6 import LogicFlow from "@logicflow/core"; 7 import "@logicflow/core/dist/style/index.css"; 8 9 //ref获取div容器 10 const container = ref(); 11 //用来渲染画布 12 const lf = ref(); 13 //定义好需要渲染的JSON数据 14 const data = { 15 // 节点 16 nodes: [ 17 { 18 id: 1, 19 type: "rect", 20 x: 100, 21 y: 250, 22 text: "开始", 23 }, 24 { 25 id: 2, 26 type: "circle", 27 x: 300, 28 y: 150, 29 text: "进行中", 30 }, 31 { 32 id: 3, 33 type: "circle", 34 x: 300, 35 y: 350, 36 text: "失败了", 37 }, 38 { 39 id: 4, 40 type: "circle", 41 x: 500, 42 y: 250, 43 text: "结束", 44 }, 45 ], 46 // 边 47 edges: [ 48 { 49 type: "polyline", 50 sourceNodeId: 1, 51 targetNodeId: 2, 52 }, 53 { 54 type: "polyline", 55 sourceNodeId: 1, 56 targetNodeId: 3, 57 }, 58 { 59 type: "polyline", 60 sourceNodeId: 2, 61 targetNodeId: 4, 62 }, 63 ], 64 }; 65 66 onMounted(() => { 67 lf.value = new LogicFlow({ 68 container: container.value, 69 stopScrollGraph: true, //禁止鼠标滚动移动画布 70 stopZoomGraph: true, //禁止缩放画布 71 width: 1200, //默认100% 72 height: 800, //默认100% 73 //画布的网格配置 74 // grid:false, //禁止画布网格 75 grid: { 76 type: "dot", //mesh方格 77 size: 20, //间距 78 }, 79 }); 80 //渲染画布 81 lf.value.render(data); 82 }); 83 </script>View Code
配置左侧菜单和右键菜单
先通过npm安装工具栏扩展
npm i @logicflow/extension
在页面引用
import { DndPanel, Menu } from "@logicflow/extension"; import "@logicflow/core/dist/style/index.css"; import "@logicflow/extension/lib/style/index.css";
在创建实例的时候注册这两个插件 plugins: [DndPanel, Menu], //注册插件
lf.value = new LogicFlow({ container: container.value, plugins: [DndPanel, Menu], //注册两个插件 stopScrollGraph: true, //禁止鼠标滚动移动画布 stopZoomGraph: true, //禁止缩放画布 width: 1200, //默认100% height: 800, //默认100% //画布的网格配置 // grid:false, //禁止画布网格 grid: { type: "dot", //mesh方格 size: 20, //间距 }, });
定义左侧菜单patternItems和右键菜单menuConfig,我这里图标直接用的base64编码
const patternItems = [ { type: 'circle', text: '文本', label: '圆形', icon: '', }, { type: 'rect', text: '文本', label: '矩形', icon: '', }, { type: 'ellipse', text: '文本', label: '椭圆', icon: '', }, { type: 'diamond', text: '文本', label: '菱形', icon: '', }, { type: 'polygon', text: '文本', label: '多边形', icon: '', }, { type: 'text', text: '文本', label: '文本', icon: '', }, // { // type: 'html', // text: 'html', // label: 'html', // icon: '', // }, { text: '', label: '查看JSON', icon: '', callback() { console.log(lf.value?.getGraphData()); alert('已输出至控制台'); }, }, ]; const menuConfig = { nodeMenu: [ { text: '属性', callback(node: any) { alert(` 节点id:${node.id} 节点类型:${node.type} 节点坐标:(x: ${node.x}, y: ${node.y})`); }, }, ], edgeMenu: [ { text: '属性', callback(edge: any) { alert(` 边id:${edge.id} 边类型:${edge.type} 边坐标:(x: ${edge.x}, y: ${edge.y}) 源节点id:${edge.sourceNodeId} 目标节点id:${edge.targetNodeId}`); }, }, ], };View Code
在lf.value.render(graphData);渲染画布之前进行配置
lf.value.extension.dndPanel.setPatternItems(patternItems); lf.value.extension.menu.addMenuConfig(menuConfig);
//渲染画布 lf.value.render(graphData);
最终效果
完整代码
<template> <div id="container" ref="container"></div> </template> <script lang="ts" setup> import { ref, onMounted } from "vue"; import LogicFlow from "@logicflow/core"; import "@logicflow/core/dist/style/index.css"; import { DndPanel, Menu } from "@logicflow/extension"; import "@logicflow/core/dist/style/index.css"; import "@logicflow/extension/lib/style/index.css"; //ref获取div容器 const container = ref(); //用来渲染画布 const lf = ref(); //定义好需要渲染的JSON数据 const data = { // 节点 nodes: [ { id: 1, type: "rect", x: 100, y: 250, text: "开始", }, { id: 2, type: "circle", x: 300, y: 150, text: "进行中", }, { id: 3, type: "circle", x: 300, y: 350, text: "失败了", }, { id: 4, type: "circle", x: 500, y: 250, text: "结束", }, ], // 边 edges: [ { type: "polyline", sourceNodeId: 1, targetNodeId: 2, }, { type: "polyline", sourceNodeId: 1, targetNodeId: 3, }, { type: "polyline", sourceNodeId: 2, targetNodeId: 4, }, ], }; const patternItems = [ { type: "circle", text: "文本", label: "圆形", icon: "", }, { type: "rect", text: "文本", label: "矩形", icon: "", }, { type: "ellipse", text: "文本", label: "椭圆", icon: "", }, { type: "diamond", text: "文本", label: "菱形", icon: "", }, { type: "polygon", text: "文本", label: "多边形", icon: "", }, { type: "text", text: "文本", label: "文本", icon: "", }, // { // type: 'html', // text: 'html', // label: 'html', // icon: '', // }, { text: "", label: "查看JSON", icon: "", callback() { console.log(lf.value?.getGraphData()); alert("已输出至控制台"); }, }, ]; const menuConfig = { nodeMenu: [ { text: "属性", callback(node: any) { alert(` 节点id:${node.id} 节点类型:${node.type} 节点坐标:(x: ${node.x}, y: ${node.y})`); }, }, ], edgeMenu: [ { text: "属性", callback(edge: any) { alert(` 边id:${edge.id} 边类型:${edge.type} 边坐标:(x: ${edge.x}, y: ${edge.y}) 源节点id:${edge.sourceNodeId} 目标节点id:${edge.targetNodeId}`); }, }, ], }; onMounted(() => { lf.value = new LogicFlow({ container: container.value, plugins: [DndPanel, Menu], //注册插件 stopScrollGraph: true, //禁止鼠标滚动移动画布 stopZoomGraph: true, //禁止缩放画布 width: 1200, //默认100% height: 800, //默认100% //画布的网格配置 // grid:false, //禁止画布网格 grid: { type: "dot", //mesh方格 size: 20, //间距 }, }); lf.value.extension.dndPanel.setPatternItems(patternItems); lf.value.extension.menu.addMenuConfig(menuConfig); //渲染画布 lf.value.render(data); }); </script>View Code 标签:lf,菜单,工具栏,text,data,画布,右键,type,id From: https://www.cnblogs.com/shenhaii/p/18224750