首页 > 其他分享 >记录一下LogicFlow流程图在vue3中的简单使用,配置左侧菜单工具栏和右键菜单

记录一下LogicFlow流程图在vue3中的简单使用,配置左侧菜单工具栏和右键菜单

时间:2024-05-31 18:32:49浏览次数:22  
标签:lf 菜单 工具栏 text data 画布 右键 type id

 

最终的效果

配置画布

首先通过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

相关文章

  • javascript右键菜单
      文章来源:https://segmentfault.com/a/1190000023098787 HTML<h1>Clickonblanktoshowcustomcontextmenus</h1>CSS.custom-context-menu{position:fixed;border:1pxsolid#ccc;list-style:none;padding:4px0;border-radius:......
  • 将sublime text 3加入到windows右键功能中
    1.reg文件内容,编辑好之后,双击1.reg文件即可WindowsRegistryEditorVersion5.00[HKEY_CLASSES_ROOT\*\shell\SublimeText3]@="EditwithSublimeText3""Icon"="D:\\software\\sublime_text_build_4169_x64\\sublime_text.exe,0"[HKEY_CLASS......
  • 实现树形菜单
    在Android中创建树形菜单(TreeView)有几种方法,可以根据你的需求选择合适的方式。这种结构通常用于展示层级关系的数据。一个常见的实现方式是使用`RecyclerView`配合自定义的适配器来创建树形菜单。以下是一个简单的示例,展示如何在Android中创建树形菜单,并点击每个分类可以......
  • win11右键子菜单展开增加延时
    展开注册表HKEY_CURRENT_USER\ControlPanel\Desktop在右侧窗格中,查找名为MenuShowDelay的字符串值。如果没有此项,可以右键单击空白处,选择新建>字符串值,然后将其命名为MenuShowDelay。双击MenuShowDelay项,修改其值数据。默认值是400(单位是毫秒)。你可以将其改为更高的......
  • win11通过注册表禁用鼠标右键
    本经验分为5个步骤,详情如下。工具/原料华硕K5win11专业版21H2注册表22000.556方法/步骤 同时按下“win”+"R"键,打开运行弹窗。 在运行框的输入框中输入“regedit”,然后点击"确定"按钮进入注册表。  接着依次打开以下的文件......
  • vs2019(或者2012),项目右键重新生成,就提示打不开某某lib链接文件。而右键生成则成功通过
    参考这个VS2019附加库目录路径和附加依赖项没有问题却仍报错LNK1104无法打开lib的解决办法https://blog.csdn.net/weixin_66296893/article/details/127463346 他解释的原因很好,目录深度(绝对路径深度) 而我遇到的问题是,右键重新生成则提示打不开某lib文件。而右键生成,则没......
  • 响应式UI组件DevExtreme中文教程 - 工具栏的自适应模式
    DevExtreme拥有高性能的HTML5/JavaScript小部件集合,使您可以利用现代Web开发堆栈(包括React,Angular,ASP.NETCore,jQuery,Knockout等)构建交互式的Web应用程序。从Angular和Reac,到ASP.NETCore或Vue,DevExtreme包含全面的高性能和响应式UI小部件集合,可在传统Web和下一代移动应用程......
  • 响应式UI组件DevExtreme中文教程 - 工具栏的自适应模式
    DevExtreme拥有高性能的HTML5/JavaScript小部件集合,使您可以利用现代Web开发堆栈(包括React,Angular,ASP.NETCore,jQuery,Knockout等)构建交互式的Web应用程序。从Angular和Reac,到ASP.NETCore或Vue,DevExtreme包含全面的高性能和响应式UI小部件集合,可在传统Web和下一代移动应用程序中......
  • Cesium实现右键弹出菜单
    一、实现思路1.创建菜单容器,设置好样式,并隐藏2.监听鼠标右键事件,控制菜单的显隐性二、实现代码1.创建菜单代码如下:<divid="menu"v-show="menuVisible":style="{left:menuX+'px',top:menuY+'px'}"style="position:absolute;background-color......
  • 8-4 【Python0036】中文级联菜单
    编写程序实现中文级联菜单,建议可以使用pypinyin或其它扩展库。 importtkinterastkfromtkinterimportttkfrompypinyinimportpinyin,Style#示例数据menu_data={"水果":\["苹果","香蕉","橙子"\],"动物":\["狗","猫"......