mousemove事件,鼠标移动过快时,无法全部响应
来源:互联网 发布:ca认证 知乎 编辑:程序博客网 时间:2024/04/28 00:58
问题描述:
项目中,运用mousemove来实现绘制圆形时,发现鼠标移动速度过快时,绘制的圆形,不能连接一起,中间出现断点,无法形成一条完整的路径。
问题分析:
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>事件</title> <style type="text/css"> *{ margin: 0; padding: 0; } #content{ width: 200px; height: 200px; border: 1px solid #ccc; background-color: blue; margin: 0 auto; } </style></head><body> <div id="content"></div> <script type="text/javascript"> var box=document.getElementById("content"); var isMouseDown=false; var t=0; box.addEventListener("mousemove",function(e){ if(isMouseDown){ console.log("move"); /*t++; console.log(t);*/ } }); box.addEventListener("mousedown",function(e){ isMouseDown=true; }); document.addEventListener("mouseup",function(e){ isMouseDown=false; }); </script></body></html>
效果图:
经过如上代码分析,发现当鼠标移动过快时,console.log(“move”)执行的次数很少;当鼠标移动足够缓慢时,执行次数鼠标移动的像素数近似(这正好验证了,当每移动一个像素时,就会触发mousemove事件)。
原因:鼠标移动时,不会存储所有的移动信息,而是通过取插值的方法取得鼠标位置信息,否则,系统会被鼠标移动拖垮。所以就会出现,移动过快时,出现断点的问题。
解决方案:
鼠标移动过快时,不能做到移动一个像素,响应一次mousemove事件,所以导致,绘制的圆形不连续。我们换种思路,直接在两次响应mousemove事件时,绘制直线,正好可以连接中间的断点。
为了美观,可以利用lineCap属性,可以保证直线两端为圆角,如下所示:
ctx.beginPath();ctx.lineCap="round";ctx.moveTo(20,40);ctx.lineTo(200,40);ctx.stroke();
这样我们的问题就解决了
演示效果:http://zhaoshaobang.github.io/blog/lottery/
0 0
- mousemove事件,鼠标移动过快时,无法全部响应
- wpf 无边框窗体无法响应MouseMove事件
- 鼠标掠过iframe事件mousemove
- 鼠标事件mousemove、mouseover、mouseout、mouseenter、mouseleave
- [C#]GDI+在鼠标移动(MouseMove)时画平滑曲线
- CSS 鼠标响应事件,鼠标经过CSS,鼠标移动CSS,鼠标点击CSS
- CSS 鼠标响应事件,鼠标经过CSS,鼠标移动CSS,鼠标点击CSS
- eclipse鼠标悬浮提示过快 修改注册表设置响应时间差
- 让Shockwave flash控件响应鼠标移动的事件
- jquery之鼠标滑过图片mousemove事件
- 鼠标mouseenter, mouseleave , mouseout mousehover mousemove等事件
- Android防止点击过快造成多次响应事件
- OpenGL鼠标响应事件
- OpenCV--鼠标事件响应
- 鼠标事件的响应
- opencv鼠标响应事件
- 【win32】鼠标响应事件
- 让控件响应mousemove
- oracle OCCI编程
- 一个酷炫实用的下拉刷新开源库
- 解决spring mvc中乱码的问题。
- 打包volley
- ssh+mysql 登陆 及增删改成
- mousemove事件,鼠标移动过快时,无法全部响应
- navigationbar右侧加两个自定义按钮
- 华为oj: 提取不重复的整数
- python实现杨辉三角(使用生成器generator)
- linux常用命令(14):head命令
- Java ArrayList遍历方法
- 【实验】高斯混合模型+vs2012+opencv2.4.4
- 存储过程Append 二进制 _ParameterPtr“不正常地定义参数对象。提供了不一致或不完整的信息”
- 高效的求大数的幂和取余