关于使用鼠标时间mouseMove拖拽元素及元素抖动的解决方案

news2024/10/5 20:19:54

最近在做一个画布相关的项目时有一个场景是移动画布,最先开始想到的是拖拽事件,但是用户希望元素是实时的变化,所以决定使用mouseMove事件来做。


思路

  1. 通过mouseDown事件确定鼠标按下的位置
  2. 根据mouseMove事件来计算出鼠标相对初始状态的横向位移距离和纵向的位移距离
  3. 获取元素的位置然后加上位移的距离并重新设置样式。

实现

首先我们应该通过给元素绑定相关的鼠标事件

<canvas
        id="canvas"
        style={{
          top: canvasPositionTop + "px",
          left: canvasPositionLeft + "px",
        }}
        onMouseDown={(e) => mouseDownHandle(e.nativeEvent)}
        onMouseMove={(e) => mouseMoveHandle(e.nativeEvent)}
        onMouseUp={(e) => mouseUpHandle(e.nativeEvent)}
      ></canvas>

创建三个state,他们的作用分别为一个是判断是否允许操作,一个是保存鼠标初始位置,还有一个是记录元素的初始位置。然后我们可以通过鼠标按下事件去获取鼠标的初始坐标

const [isStart, setIsStart] = useState(false);
const [dragBeforePosition, setDragBeforePosition] = useState([0, 0]);
const [dragInitCoordinate, setDragInitCoordinate] = useState([0, 0]);

 const mouseDownHandle = (e) => {
    setIsStart(true);
    setDragInitCoordinate([e.clientX, e.clientY]);
  };

接着我们可以借助鼠标移动事件实时计算出鼠标的位移距离,鼠标的位移距离我们就可以当做是元素的位移。我们使用两个state去保存这个位移值。

const [canvasPositionLeft, setCanvasPositionLeft] = useState(0); 
const [canvasPositionTop, setCanvasPositionTop] = useState(0); 
const mouseMoveHandle = (e) => {
    if (!isStart) {
      return;
    }
     dragCanvasHandle(e);
  }; 

const dragCanvasHandle = (e) => {
    let [x, y] = [e.clientX, e.clientY];
    let [initX, initY] = dragInitCoordinate;
    let canvasOffsetX = x - initX;
    let canvasOffsetY = y - initY;
    setCanvasPositionLeft(dragBeforePosition[0] + canvasOffsetX);
    setCanvasPositionTop(dragBeforePosition[1] + canvasOffsetY);
  }

拿到位移值以后我们就可以对元素的位置进行更改。我们可以使用定位或者元素的margin值,具体使用视情况而定,我这里是用的是定位。

当然这是很简单的实现,具体可需要进行优化,接下来要说的是一个优化点。

抖动

如果是按上面的代码去拖拽是没有任何问题的,但是上面的代码是更改后的代码。如果我们在确定鼠标位置的时候使用的是offsetX和offsetY而不是clientX和clientY就会出现下面的情况

在这里插入图片描述

可以看到抖动还是很明显的,起初我以为是state更新导致的重新渲染引起的,但是我发现在缓慢拖动的时候也会出现抖动的情况,起初不确定原因,但是在我尝试防抖节流以及requestAnimationFrame后我可以确定抖动是坐标计算导致的。但是我一遍一遍的排查发现计算逻辑是没有问题的,那么问题只在取值上。在排查以后发现是使用属性的问题,我最初取值使用的是offsetX,而offsetX是鼠标和元素内边框的距离,所以当鼠标移动的时候元素本身也在移动,这样就导致取值的时候会出现问题,而当我们使用clientX的时候,这个时候鼠标的位置是相对页面来计算的,这样能确保当元素的位置更改时我们的取值不会收到影响。

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

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

相关文章

MySQL锁杂谈

【说明】 1.MySQL版本5.7.37 2.事务隔离级别 REPEATABLE-READ 3.表结构 Create Table: CREATE TABLE isolation_innodb (id bigint(20) NOT NULL AUTO_INCREMENT,name varchar(10) DEFAULT NULL,money int(11) DEFAULT NULL,PRIMARY KEY (id) ) ENGINEInnoDB AUTO_INCREMENT4…

jsp库存管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 JSP 库存管理系统 是一套完善的web设计系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开 发&#xff0c;数据库为Mysql&#xff0c;使用ja…

VMware Cloud Director数据库操作

VMware Cloud Director 是一个云服务平台&#xff0c;以自助服务模式提供安全、隔离、弹性的虚拟数据中心计算、网络、存储和安全。在NFV整个架构中属于VIM层&#xff0c;与NFVI层&#xff08;对VMware来说即vSphere虚拟化环境&#xff09;对接获取虚拟化资源并提供给租户。 NF…

服务访问质量(QoS)——QoS技术概述与配置

作者简介&#xff1a;一名在校云计算网络运维学生、每天分享网络运维的学习经验、和学习笔记。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;网络豆的主页​​​​​​ 目录 前言 一.QoS技术概述 1.QoS的应用需求 ①网络拥塞的影响&#xff1a…

【Linux】项目自动化构建工具:make/Makefile的使用

文章目录一、背景1、make和makefile是什么&#xff1f;2、为什么要使用make和makefile?二、原理1、使用make和makefile2、依赖关系和依赖方法3、具体原理4、项目清理一、背景 1、make和makefile是什么&#xff1f; make是一个命令&#xff0c;是一个解释makefile中指令的命令…

Linux项目:自主web服务器

文章目录项目描述Web与 http 发展史DNSURI URL URNHTTP 概述项目纲要项目架构套接字的封装HTTP服务启动日志信息与工具类请求、响应类读取请求读取请求行读取请求报头分析请求行分析请求报头读取正文构建响应预处理返回静态网页CGI机制CGI机制的基本概念CGI函数的实现子CGI程序…

【点云处理】点云法向量估计及其加速(4)

上篇文章【点云处理】点云法向量估计及其加速(3)介绍了如何使用pcl提供的gpu版本法向量计算接口对点云发向量计算进行加速。不足之处在于点云k近邻查找依然比较耗时&#xff0c;成为影响整体计算性能的瓶颈。这篇文章就如何优化点云K近邻查找效率进行实验。上一篇文章的示例代码…

redis数据库的下载安装/免安装版

文章目录下载方式一下载方式二免安装版redis是一款高性能的NOSQL系列的非关系型数据库这里分享三个下载源&#xff0c;只介绍免安装版下载方式一 官网下下载https://redis.io&#xff08;国外网站下载速度比较慢&#xff09; 下载方式二 Redis中文网http://www.redis.net.cn…

想你所想,华为云桌面Workspace助你轻松办公

想你所想&#xff0c;华为云桌面Workspace助你轻松办公 双11作为近年来最受关注的购物季&#xff0c;从最开始的电商&#xff0c;到现在各行各业纷纷下场推出活动&#xff0c;期望在此段时间内迅速积累用户&#xff0c;从而提升产品知名度和用户基础。华为云也不例外&#xff0…

学生个人博客网页设计作品 学生个人网页模板 个人网页制作 HTML学生个人网站作业设计

&#x1f389;精彩专栏推荐 &#x1f4ad;文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;毕设项目精品实战案例 (10…

应用商店的ASO和搜索引擎的SEO的区别

ASO和SEO&#xff0c;目标相似&#xff0c;有着异曲同工之妙&#xff0c;两者都是提高搜索排名的方式&#xff0c;具体有什么区别呢&#xff1f;今天柚鸥ASO给大家做一下总结。 SEO是指搜索引擎优化&#xff0c;利用搜索引擎的规则来提高网站&#xff08;例如&#xff1a;百度…

室内定位解决方案-最新全套文件

室内定位解决方案-最新全套文件一、建设背景二、建设思路三、建设方案四、获取 - 室内定位全套最新解决方案合集一、建设背景 室内定位顾名思义就是定位室内目标对象的位置&#xff0c;可以是人也可以是物体的位置的一种技术方案&#xff0c;根据定位精度的不同&#xff0c;被…

C++ Primer Plus第五版笔记(p1-50)

1 在unix中 echo 获得状态 2iostream 包含istream以及ostream:随着时间的推移&#xff0c;字符是按照顺序生成或者是消耗的 3cin标准输入 cout标准输出 Cerr标准错误 clog 一般性信息 4cin>>c1>>c2&#xff1b;连续输入 5cout是ostream的对象&#xff0c;第一个<…

VirtualBox安装openEuler

下载&#xff1a; https://www.openeuler.org/zh/mirror/list/ 根据设备架构选择对应的版本&#xff1a;windows是x86架构 选择下面这个4.2G大小的&#xff1a; 安装&#xff1a; 1&#xff0c;点击新建&#xff1a; 按下图设置 设置内存大小&#xff0c;使用的cpu数…

SpringBoot项目在使用Maven打包war中遇到的问题

问题描述 在使用maven打包&#xff08;package&#xff09;springboot项目为war项目后&#xff0c;在本地机器上使用Tomcat跑这个项目&#xff0c;访问资源时出现下面的错误&#xff1a; o.s.b.w.servlet.support.ErrorPageFilter : Cannot forward to error page for reque…

TIKTOK出海公会为什么是2022出海风口?有哪些机遇与挑战?

近两年在全球迅速扩张市场的TIKTOK一举跃为全球下载量第一的APP&#xff0c;背靠十几亿月活用户的流量矿山&#xff0c;成为首个非Facebook系达成此成就的应用&#xff0c;可谓是赚足了全世界的目光。与此同时&#xff0c;大量跨境商家与自媒体从业者也盯上了TIKTOK的造富潜力&…

zlib-1.2.11库、libpng-1.6.36库编译及交叉编译 —— 附带shell编译脚本及源码

目录 一、zlib-1.2.11库编译 二、libpng-1.6.36库编译 三、编译zlib和libpng的编译脚本 编译libpng库之前需要先下载编译zlib库&#xff0c;因为libpng需要依赖zlib才能编译通过。 编译环境如下&#xff1a;ubunt 14.04、gcc 4.8.4、arm-hisiv100nptl-linux-gcc 一、zlib-1.2…

SAP S4客户与供应商如何管理 事务代码 BP

在 S4里里面&#xff0c; “客户”与“供应商”的概念被整合为为“业务伙伴”了 &#xff0c;所以SAP也用也新的事务代码来管理“业务伙伴” 新的业务代码是BP 。 在旧版本的SAP里面采用供应商和客户的方式来管理业务伙伴&#xff0c;有一些弊端&#xff0c;例如&#xff1a; 1…

[附源码]java毕业设计源冀平行进口车系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

二、进程管理(三)同步与互斥

目录 3.1 临界资源与临界区 3.2 同步与互斥概念 3.3 实现临界区互斥的基本方法 3.3.1 软件实现方法 3.3.1.1 单标志法 3.3.1.2 双标志先检查法 3.3.1.3 双标志后检查法 3.3.1.4 Peterson算法 3.3.2 硬件实现方法 3.3.2.1 中断屏蔽方法 3.3.2.2 硬件指令方法之TestAn…