【数据流图】用JointJs实现数据流图(二)

一、流图如何绑定绘制的元素?

通过打印JointJs生成的属性可知,id是不允许被覆盖修改的,但是cid可以。所以通过绑定元素的cid,可实现后续的操作,如查找元素、更改元素属性等。

1. 绑定cid方式示例

let textEle = new joint.shapes.standard.TextBlock();
textEle.attributes.attrs.label = {text: '例子',
};
textEle.attr('label/text', '例子');
textEle.resize(10, 10);
textEle.position(0, 0);
// 绑定cid
textEle.cid = cid;
textEle.addTo(this.graph);

2. 根据cid查找画布上的元素

let findEleByCid(cid){// 获取所有元素let eleList = this.graph.getElements();// 返回cid匹配上的元素return eleList.find((ele) => ele.cid === cid);
}

3. 改变属性,以改变文本内容为例

// 将textEle这个文本框元素的内容改为123
textEle.attr('label/text', '123');

二、流图中绘制使用的JointJs的API及函数封装

1. 绘制文本框

  • 使用API:shapes.standard.TextBlock
  • 常用属性
    • attributes.attrs.label.text:文本内容
    • attributes.attrs.label.style:文本样式,与css保持一致
    • attr(‘label/text’, text):标签内容
    • attr(‘body/stroke’, ‘none’):文本框的外边框
    • resize(width,height):文本框尺寸
    • position(x,y):文本框位置
  • 绘制文本框函数示例
 drawText(text, position, size, textStyle) {let textEle = new joint.shapes.standard.TextBlock();textEle.attributes.attrs.label = {text: text,style: textStyle};textEle.attr('label/text', text);textEle.attr('body/stroke', 'none');textEle.resize(size[0], size[1]);textEle.position(position[0], position[1]);textEle.addTo(this.graph);
}

2. 绘制图片

  • 使用API:shapes.standard.Image
  • 常用属性
    • attr(‘image/xlinkHref’, imgSrc):指定图片地址
    • resize(width,height):图片尺寸
    • position(x,y):图片位置
  • 绘制图片函数示例
drawImg(imgSrc, position, size) {let ele = new joint.shapes.standard.Image();ele.attr('image/xlinkHref', imgSrc);ele.position(position[0], position[1]);ele.resize(size[0], size[1])ele.addTo(this.graph);
},

3. 绘制线条

  • 使用API:shapes.standard.Link&dia.Link&dia.LinkView
  • 常用属性
    • attr(‘line/stroke’, ‘#FF620C’):连线颜色
    • attr(‘line/strokeWidth’, 1.5):连线宽度
    • .connector(‘curve’, {}):贝塞尔三次曲线

贝塞尔三次曲线计算较为复杂,若不指定,按官方默认的来绘制,会呈现s型曲线

  • 绘制线条函数示例
// linkInfo:连线信息
// color:圆点颜色
// sourceDirection:连线起点位置
// targetDirection:连线终点位置
drawLink(linkInfo, color, sourceDirection, targetDirection) {let link = new joint.shapes.standard.Link(linkInfo);link.attr('line/stroke', '#FF620C');link.attr('line/strokeWidth', 1.5);link.attr({line: {targetMarker: {type: 'path','stroke-width': 1,fill: '#FF620C',d: 'M 8 -4 0 0 8 4 Z'}}});let paperLink = new joint.dia.Link(linkInfo);paperLink.attr({'.connection': { stroke: 'none' }});if (sourceDirection && targetDirection) {link.connector('curve', {sourceDirection: sourceDirection,targetDirection: targetDirection,distanceCoefficient: 0.4});paperLink.connector('curve', {sourceDirection: sourceDirection,targetDirection: targetDirection,distanceCoefficient: 0.4});} else {link.connector('curve', {distanceCoefficient: 0.4});paperLink.connector('curve', {distanceCoefficient: 0.4});}paperLink.addTo(this.graph);let vCircle = V('circle', {r: 5,fill: color});let paperLinkView = paperLink.findView(this.paper);paperLinkView.sendToken(vCircle, 4000);this.dataInterval = setInterval(() => {paperLinkView.sendToken(vCircle, 4000);}, 5000);link.addTo(this.graph);},

三、流图中绘制使用JointJs的方法总结

1. 触摸连线事件(link:mouseover)

this.paper.on('link:mouseover', (cell) => {// cell即为鼠标悬停的连线元素
});

2. 移出连线事件(link:mouseleave)

this.paper.on('link:mouseleave', () => {// cell即为鼠标离开的连线元素
});

3. 触摸元素事件(element:mouseover)

this.paper.on('element:mouseover', (cell) => {// cell即为鼠标悬停的元素
});

4. 移出元素事件(element:mouseleave)

this.paper.on('element:mouseleave', (cell) => {// cell即为鼠标移出的元素  
});

5. 鼠标点击元素事件(element:pointerclick)

this.paper.on('element:pointerclick', (cell) => {// cell即为鼠标点击的元素  
});

6. 获取所有画布上的元素(getElements)

// eleList即为画布上的元素
let eleList = this.graph.getElements();

7. 获取所有画布上的连线

// links即为画布上的连线
let links = this.graph.getLinks();

8. 移除画布上的元素(removeCells)

// cells为要移除的元素的数组
this.graph.removeCells(cells);

9. 画布自适应(paper.scale)

resizeCanvas() {let paperWidth = window.innerWidth;// 示例为1250,可自行更改if (paperWidth > 1250) {let scale = paperWidth / 1250;this.paper.scale(scale, scale);// this.$refs.canvas为vue获取canvas元素的方式if (this.$refs.canvas) {this.$refs.canvas.style.width = `${800 * scale}px`;this.$refs.canvas.style.height = `${520 * scale}px`;}}
}

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

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

相关文章

vector实战

vector声明 初始化 获取数据 修改元素值 追加元素 遍历 定义二维的vector 二维vector遍历 #include <iostream> #include <vector>using namespace std;int main(){// vector 声明vector<string> name_vector;// vector 初始化vector<int> sco…

户外公园实景儿童剧本杀小程序系统开发搭建

户外公园实景儿童剧本杀小程序系统开发搭建涉及到的内容包括但不限于以下几个方面&#xff1a; 1. 项目规划&#xff1a;需要考虑场地的大小、设施的配置、剧本的设定等&#xff0c;这些都是开发前的必要考虑因素。 2. 平台开发&#xff1a;基于小程序开发户外公园实景儿童剧本…

Screeps工程化之数量控制模块

前言 将Screeps的代码进行模块化后&#xff0c;可以将各个功能进行分离&#xff0c;互相不影响&#xff0c;本文将会介绍Screeps中如何进行creep的数量控制来维持房间资源的平衡和发展。本文仅为作者本人的游戏思路&#xff0c;并不是最佳实践&#xff0c;如有更好的实现方法可…

十二届蓝桥杯Python组3月中/高级试题 第四题

** 十二届蓝桥杯Python组3月中/高级试题 第四题 ** 第四题&#xff08;难度系数 4&#xff0c;30 个计分点&#xff09; 编程实现&#xff1a; 给定一组包含n个&#xff08;n>3) 正整数数据&#xff0c;和一个正整数M&#xff0c;从这n个正整数中任意拿出两个数相 加&…

【概率论基础】 一篇文章缕清概率论常见概念关系

碎碎念&#xff1a;再写CSDN之前有一小段时间写数模公众号的经历&#xff0c;但是公众号看的人实在太少了&#xff0c;而且排版和公式、代码编辑都没有CSDN这么方便&#xff0c;所以坚持一算时间就没有更新了。公众号大多写的是概念性的基础&#xff0c;稍加修改搬到咱们的主战…

Git使用及相关问题

总结git中使用的问题 目录 1.git维护文件拷贝后unchanged 1.git维护文件拷贝后unchanged 文件权限不同&#xff0c;文件权限被修改&#xff0c;但内容未改变 命令行中使用git diff: diff --git a/compat/plan9/head b/compat/plan9/head old mode 100755 new mode 100644 主要…

Redis rehash 相关问题

前言 本文主要介绍 Redis Hash 表 rehash 相关的三个问题&#xff1a; 什么时候触发 rehashrehash 扩容扩多大rehash 如何执行 介绍的源码基于 Redis 5.0.8 版本&#xff0c;会删除一些不影响理解的部分。 什么时候触发 rehash Redis 用于判断是否触发 rehash 的函数是 _d…

‘pip‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。

因为python13不支持 pip install cx_Oracle&#xff0c;卸载了python13&#xff0c;重新安装python10&#xff0c;导致cmd命令不识别 pip &#xff0c;和python10&#xff0c;(;༎ຶД༎ຶ) 记录一种临时方案 如果你的命令行界面&#xff08;cmd&#xff09;不识别pip命令&am…

如何挑选“好用”的工业APP

我们日常生活中每天都在使用各种生活类的APP,然而&#xff0c;当我们谈到工业APP时&#xff0c;很多人可能并不那么熟悉。工业APP&#xff0c;虽然不像生活类APP那样直接面向广大消费者&#xff0c;但在工业领域却扮演着至关重要的角色。 先简单认识下啥是工业APP? 工业APP是…

集成学习算法:AdaBoost原理详解以及基于adaboost的图像二分类代码实现

本文尽量从一个机器学习小白或是只对机器学习算法有一个大体浅显的视角入手&#xff0c;尽量通俗易懂的介绍清楚AdaBoost算法&#xff01; 一、AdaBoost简介 AdaBoost&#xff0c;是英文"Adaptive Boosting"&#xff08;自适应增强&#xff09;的缩写&#xff0c;由…

【退役之重学Java】关于缓存

一、为什么要用缓存 缓存嘛&#xff0c;对比计算机组成原理中的“高速缓存控制器”&#xff0c;就可以知道&#xff0c;缓存的存在是为了获取高性能&#xff0c;特别是在高并发场景下获取高性能。 二、缓存是如何获取高性能的 SQL的执行是非常消耗性能的有一些SQL经常是一样的…

【开发工具】使用Github pages、Hexo如何10分钟内快速生成个人博客网站

文章目录 一.准备工作1.安装git2.安装node安装 cnpm 3.使用 GitHub 创建仓库&#xff0c;并配置 GitHub Pages0.Github Pages是什么1. 在 GitHub 上创建一个新仓库2. 创建您的静态网站3. 启用 GitHub Pages4. 等待构建完成5. 访问您的网站 二. Hexo1.什么是Hexo2.安装Hexo1. 安…

分拣机器人也卷的飞起来了

导语 大家好&#xff0c;我是智能仓储物流技术研习社的社长&#xff0c;老K。专注分享智能仓储物流技术、智能制造等内容。 新书《智能物流系统构成与技术实践》 智能制造-话题精读 1、西门子、ABB、汇川&#xff1a;2024中国工业数字化自动化50强 2、完整拆解&#xff1a;智能…

解锁Swagger鉴权

在开发过程中&#xff0c;Swagger 是一个非常流行的 API 文档生成工具&#xff0c;它不仅可以帮助开发者设计、构建、记录 RESTful API&#xff0c;还能通过其交互式的 UI 改善前后端开发者的沟通效率。然而&#xff0c;在实际生产环境中&#xff0c;暴露未加保护的 API 文档可…

大数据基础工程技术团队4篇论文入选ICLR,ICDE,WWW

近日&#xff0c;由阿里云计算平台大数据基础工程技术团队主导的四篇时间序列相关论文分别被国际顶会ICLR2024、ICDE2024和WWW2024接收。 论文成果是阿里云与华东师范大学、浙江大学、南京大学等高校共同研发&#xff0c;涉及时间序列与智能运维结合的多个应用场景。包括基于P…

Android 蓝牙实战——蓝牙电话通话状态同步(二十四)

前面分析了蓝牙电话通话状态的广播,我们可以在蓝牙电话中实时监听蓝牙电话的状态,但如果是其他音乐类 APP 呢,在播放的时候也需要知道当前是否有通话正在进行,但是有完全没必要实时监听电话的状态,这就需要一个获取通话状态的方法。 一、通话状态处理 1、CallsManager …

MySQL学习笔记12——效率和优化

效率和优化 一、对查询语句进行调优1、查询分析语句2、优化查询方法 二、改进表设计以提高性能1、优化数据类型2、合理增加冗余字段以提高效率3、拆分表4、使用非空约束 三、如何充分利用系统资源1、优化系统资源配置2、如何利用系统资源来诊断问题 一、对查询语句进行调优 你…

vscode触发建议缓慢问题

说明 关于vscode上vite项目文件过多导致触发建议缓慢问题&#xff0c; 本人框架主要使用的技术是 vite vue3 ts tailwind eslint 项目初始阶段建议提示秒出&#xff0c;当项目文件过多时&#xff0c;建议延迟太高&#xff0c;即使是console代码片段也会过好几秒才出现 …

【R语言】边缘概率密度图

边缘概率密度图是一种在多变量数据分析中常用的图形工具&#xff0c;用于显示每个单独变量的概率密度估计。它通常用于散点图的边缘&#xff0c;以便更好地理解单个变量的分布情况&#xff0c;同时保留了散点图的相关性信息。 在边缘概率密度图中&#xff0c;每个变量的概率密度…

react native 设置屏幕锁定

原生配置 android 在android/app/src/main/AndroidManifest.xml在这个文件里的入口activity里添加 android:screenOrientation"portrait" <activityandroid:name".MainActivity"android:label"string/app_name" …