当前位置: 首页 > news >正文

如何自己实现一个丝滑的流程图绘制工具(八) 创建节点的文本标签

背景

节点的文本标签不希望是通过节点编辑实现,而是拿到节点名字渲染上去,包括连接线

createLabel(element, name, parent) {const modeling = this.bpmnModeler.get('modeling')let labelCenter = {}// 连接线上的标签if (element.type === 'bpmn:SequenceFlow') {let xData = element.waypoints.map(item => item.x)xData = sortedUniq(xData).reduce((pre, next) => {return pre + next}, 0)let yData = element.waypoints.map(item => item.y)yData = sortedUniq(yData).reduce((pre, next) => {return pre + next}, 0)labelCenter = {x: (element.waypoints[0].x + element.waypoints[element.waypoints.length - 1].x) / 2,y: (element.waypoints[0].y + element.waypoints[element.waypoints.length - 1].y) / 2 - 5}const businessObject = element.businessObjectif (!element.labels.length) {modeling.createLabel(setLabel(element, name), labelCenter, {id: `${businessObject.id}_label`,businessObject: businessObject,di: element.di,width: name.length > 6 ? 80 : name.length * 11})} else {modeling.updateLabel(element, name)}} else {const renderer = this.bpmnModeler.get('customRender')if (!element.businessObject.$parent) {element.businessObject.$parent = parent}console.log(name, 'name')element.businessObject.name = nameconst circleElement = document.querySelector(`g[data-element-id="${element.id}"]`)if (!circleElement) returnconst p = circleElement.querySelector('.djs-visual')renderer.drawShape(p, element)}}
http://www.lryc.cn/news/149020.html

相关文章:

  • Spring Boot多数据源配置运行报错:No operations allowed after connection closed连接异常的解决
  • 3、QT 的基础控件的使用
  • 爬虫逆向实战(二十六)--某某学堂登录
  • leetcode分类刷题:哈希表(Hash Table)(四、前缀和 处理连续子数组)
  • 如何处理生产环境中的数据倾斜问题?
  • 【WSN无线传感器网络恶意节点】使用 MATLAB 进行无线传感器网络部署研究
  • C# 实现浏览器控件设置
  • 1130 - Host ‘17216.18083‘ is not allowed to connect to this MySQL server
  • 使用Spring的getBeansOfType实现接口多实现类的动态调用
  • (笔记三)opencv图像基础操作
  • PHP入门及环境搭建 - XAMPP
  • 开学季ipad手写笔什么牌子好?第三方电容笔推荐
  • 【力扣】62. 不同路径 <动态规划>
  • 【Python小项目】Python的GUI库Tkinter实现随机点名工具或抽奖工具并封装成.exe可执行文件
  • 【MySql】mysql之基础语句
  • 使用API调用获取商品数据的完整方案
  • 来看看入门级别的室内设计创意是怎么样构成的
  • Go 面向对象(匿名字段)
  • 生成式AI,赋能数字劳动力的关键工具
  • python提取邮件的附件,以excel为例
  • ZooKeeper技术内幕
  • 乱糟糟的YOLOv8-detect和pose训练自己的数据集
  • 【Nginx】Nginx $remote_addr和$proxy_add_x_forwarded_for变量详解
  • MySQL自动删除binlog日志
  • C++ 文件和流
  • 案例分享:西河水库安全监测信息化系统实施方案
  • 使用Angular和MongoDB来构建具有登录功能的博客应用程序
  • ChatGPT 与前端技术实现制作大屏可视化
  • 视频监控/视频云存储EasyCVR平台接入华为ivs3800平台提示400报错,如何解决?
  • c++基础数据结构