echarts:graph图表拖拽节点

news2024/10/7 6:40:32

需求:实现一个可视化编辑器,用户可以添加节点,并对节点进行拖拽编辑等

在这里插入图片描述
实现期间碰到很多问题,特意记录下来,留待将来碰到这些问题的同学,省去些解决问题的时间

问题1:节点的data如下,不使用直角坐标系一切正常,但使用直角坐标系时,节点怎么不见了?

series: [{
    type: 'graph',
	data: [
		{ name: '1', x: 0, y: 0}, 
	    { name: '2', x: 10, y: 10 }
	]
}]
解决方法:开启坐标系后,坐标要以数组的方式存到value中
series: [{
    type: 'graph',
	coordinateSystem: 'cartesian2d',
	data: [
		{ name: '1', value: [0, 0] }, 
	    { name: '2', value: [10, 10] }
	]
}]

问题2:怎么拖拽节点?并且获得节点拖拽的偏移量呢?

1、在配置项中允许节点拖拽:draggable: true

series: [{
    type: 'graph',
    draggable: true,
}]

2、监听鼠标按下和松开的事件,按下时获得拖拽动作的初始坐标,松开时获得拖拽动作的结束坐标,比较后获得节点的偏移量

let dragCoords = null
myChart.on('mousedown', (e) =>{
	dragCoords = [e.event?.offsetX, e.event?.offsetY]
});
myChart.on('mouseup', (e) =>{
    const { offsetX, offsetY } =  e.event
    console.log('初始坐标:': dragCoords , '结束坐标:', [offsetX, offsetY] )
});

问题3:直接将坐标与偏移量进行加减,计算出来的坐标再赋值给节点,重新渲染后的节点位置与拖拽结束的位置不一样

原因: 出现这个问题,是因为坐标的数值与px的数值,它们只是一个正比例关系。

解决方法:
计算坐标轴的长度与屏幕可视区域宽高的比例,根据比例将节点在屏幕的偏移量转为在坐标系的偏移量。

举例: x轴刻度为1000,渲染在屏幕是500px,那么拖拽节点向右移动100px,节点的x坐标应该增加200

option: {
	xAxis: { show: true, type: 'value', min: -500, max: 500 },
    yAxis: { show: true, type: 'value', min: -1000, max: 0, },
	grid: {
      left: 0, right: 0, top: 50, bottom: 50,
    },
}

根据以上配置。可以得到:
x轴长度 = document.body.clientWidth
y轴长度 = document.body.clientHeight-50-50

当然,如果需求允许,设置grid.width=1000; grid.height=1000; 这样是最方便的,直接将坐标的数值与偏移量相加减,就可以得到新的坐标

  function updatePosition ( e: any) {
    if(!e.data.name || !dragCoords) return
    const [startX, startY] = dragCoords // 拖拽动作的初始位置
    const { offsetX, offsetY } =  e.event // 拖拽动作的结束位置
    const [ x, y ] = clip.value // 节点在坐标系内的坐标
    const { clientWidth, clientHeight } = document.body // 屏幕宽高。
    // x轴、y轴的刻度都1000
    // 根据option.grid的配置,x轴长度=clientWidth; y轴长度 = clientHeight - 50 - 50;
    // 将屏幕的偏移量数值,转为在坐标系中的偏移量数值
    const xCoord = x + (offsetX - startX) * 1000 / clientWidth
    const yCoord = y - (offsetY - startY) * 1000 / (clientHeight-100)
    console.log('节点的新坐标:', [xCoord , yCoord ]);
  }

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

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

相关文章

excel中vlookup用法

excel中vlookup用法 用法示例 参数说明 参数1:E1用于匹配的字段 参数2:E1:F4,匹配表格范围 参数3:要取的字段属于匹配表格范围的第几列 数据4:精确匹配

JumpServer2023漏洞复现合集

本文主要复现JumpServer2023年出现的大批量漏洞,既是分享也是为了记录自己的成长,近期会持续更新。 1. JumpServer MongoDB远程代码执行漏洞(CVE-2023-43651) 1.1 漏洞级别 高危 1.2 漏洞描述 经过身份验证的用户可以利用Mon…

CV计算机视觉每日开源代码Paper with code速览-2023.11.13

精华置顶 墙裂推荐!小白如何1个月系统学习CV核心知识:链接 点击CV计算机视觉,关注更多CV干货 论文已打包,点击进入—>下载界面 点击加入—>CV计算机视觉交流群 1.【基础网络架构:Transformer】PolyMaX: Gener…

官网下载tomcat

1、Tomcat官网地址: https://tomcat.apache.org/ 2、下载以及安装步骤

美颜sdk是什么?美颜sdk技术解析与比较

美颜SDK的出现为开发者提供了快速实现高质量美颜效果的工具,然而,在众多美颜SDK中,技术实现和效果差异巨大。本文将对美颜SDK进行技术解析,并进行比较,以帮助开发者更好地选择适合其应用需求的美颜SDK。 一、美颜SDK…

巷议:跌落尘埃与风光无限

近几来制造业的退潮是不争的事实,其中以老资格直辖市天津尤为突出。曾记否,想当年韩国的三星集团是天津最强的外企,但是从2015年开始便撤离了,给天津经济带来了重创。 而天津的汽车产业,也日渐变得软弱。其中那曾经小…

上门预约洗衣洗鞋系统,互联网洗鞋店小程序

干洗店预约下单小程序的功能一览,开发一个成功的干洗店小程序需要具备哪些功能: 最近我们开发了一款洗衣洗鞋工厂小程序,其功能强大,主要功能包括: 用户选择洗护用品,选择取衣方式,取衣方式有&a…

Postman如何发送Https请求

Postman如果想要发送Https请求,需要从设置中将SSL安全认证禁用

录制电脑屏幕的软件推荐,满足你的各种需求

屏幕录制是我们在现代数字世界中常常需要用到的技能。无论是为了创建教程、分享游戏经验,还是制作演示文稿,录制电脑屏幕都是一项重要的任务,本文将介绍三款录制电脑屏幕的软件,帮助用户了解并选择合适的录屏工具。 录制电脑屏幕软…

四川芸鹰蓬飞商务信息咨询有限公司是可靠的选择

随着电商行业的快速发展,越来越多的消费者选择通过线上平台购物。在这个大背景下,四川芸鹰蓬飞商务信息咨询有限公司以其独特的抖音电商服务,为广大消费者带来了更加便捷、安全的购物体验。 一、服务的优势 专业团队:公司拥有一支…

没有 SegWit 和 Taproot 的比特币序数

序号 (Ordinals)已成为 BTC 圈子中创建不可替代令牌(NFT)的热门话题。 它的主要特点是将 NFT 本身完全存储在链上。 我们表明原始的比特币协议已经可以支持它。 Ordinals 不需要任何重大更改,包括 SegWit 和 Taproot。…

vue+springboot实现图形验证码Kaptcha

1、前端 form使用了element-ui的组件&#xff0c;主要还是看img标签&#xff0c;src绑定了form.imgCodeUrl数据&#xff0c;点击图片时触发refreshCode更新图片验证码。 <el-form-item prop"verificationCode" label"验证码" style"text-align: l…

SpringBoot和Spring源码下载

1.下载&#xff1a;在一个空的干净地创建一个文件夹叫springsourcecode&#xff0c;其实叫什么都行的。 git clone https://github.com/spring-projects/spring-framework.git 2.JDK要和gradle匹配 我们要21的&#xff0c;今天为止2023年11月13日&#xff0c;idea是2023.2。 …

软件测试/测试开发丨接口自动化测试学习笔记,加密与解密

点此获取更多相关资料 本文为霍格沃兹测试开发学社学员学习笔记分享 原文链接&#xff1a;https://ceshiren.com/t/topic/28019 一、原理 在得到响应后对响应做解密处理&#xff1a; 如果知道使用的是哪个通用加密算法的话&#xff0c;可以自行解决。如果不了解对应的加密算法…

利用网络管理解决方案简化网络运维

当今的网络正朝着提高敏捷性和动态功能的方向发展&#xff0c;以支持高级网络要求和关键业务流程&#xff0c;这导致 IT 基础架构也跨越无线、虚拟和混合环境。但是&#xff0c;随着网络的快速发展&#xff0c;如果没有合适的解决方案&#xff0c;IT 管理员很难管理它们&#x…

为开发GPT-5,OpenAI向微软寻求新融资

11月14日&#xff0c;金融时报消息&#xff0c;OpenAI正在向微软寻求新一轮融资&#xff0c;用于开发超级智能向AGI&#xff08;通用人工智能&#xff09;迈进&#xff0c;包括最新模型GPT-5。 最近&#xff0c;OpenAI召开了首届开发者大会&#xff0c;推出了GPT-4 Turbo、自定…

完全未接触过软件测试的人,培训两个月就可上岗,这现实吗?

如果你想两个月能学完是可以的&#xff0c;但是只能做一些简单的功能测试&#xff0c;但也只限下面这四种情况 1.自身基础较好&#xff0c;自控力较强 比如一个计算机专业的学生要入行软件测试&#xff0c;可能就不需要进行入门培训了&#xff0c;自己找点视频看看就能很快上…

web 渗透 信息搜集

一 收集域名信息 1.whois查询 whois&#xff08;读作“Who is”&#xff0c;非缩写&#xff09;&#xff0c;标准的互联网协议&#xff0c…

光伏仪器-87110A/B太阳辐照度计

87110A/B 太阳辐照度计 光伏仪器 一款小巧、全数字化的太阳辐照度测试仪表&#xff0c;通过标准太阳电池测试太阳辐照度&#xff0c;并自带温度修正功能。太阳辐照度计集成了环境温度、电池板温度、倾斜角等测试功能&#xff0c;可以通过附带的蓝牙或串行接口连至电脑或智能…

运营商大数据是新时期贷款公司精准拓客的生命!!是企业的灵魂

贷款客户资源主要根据运营商大数据建模分析网站、app等&#xff0c;获取每天的网站实时访客&#xff0c;app活跃用户使用者数据的信息资源。 而贷款客户资源精准获客平台能帮您做的&#xff0c;就是根据用户实时动态轨迹与通信上网数据&#xff0c;锁定潜在意向客户&#xff0…