js实现Mac触摸板双指事件(上/下/左/右/放大/缩小)

摘要:
前言这几天在修复一个web问题时,需要捕获Mac触摸板双指事件,但发现并没有现成的轮子,还是要自己造。目标获取Mac触摸板双指行为,具体有两个,一个是实时拖动路线,二是手势。双指特性1.在快速滑动过程中,deltaX、deltaY值的最初值的正负是与滑动方向不同的。实现手势思路在上面的基础上,记录一段时间内deltaX、deltaY和两两差值:deltaX、deltaY用来统计放大、缩小手势。

前言

这几天在修复一个web问题时,需要捕获Mac触摸板双指事件(上、下、左、右、放大、缩小),但发现并没有现成的轮子,还是要自己造。

例如:jquery.mousewheel.js(添加跨浏览器的鼠标滚轮支持), 给得太简单,没有处理Mac双指行为,所以不能用。

目标

获取Mac触摸板双指行为,具体有两个,一个是实时拖动路线,二是手势(上、下、左、右、放大、缩小)。

难点

双指行为只会触发mousewheel事件,其他什么的touch,mouse都不会触发,只能从这个下手。

双指特性

1.在快速滑动过程中,deltaX、deltaY值的最初值的正负是与滑动方向不同的。

2.在缓慢滑动过程中,deltaX、deltaY值的值域是非常小的,一般在于[-3, 3]。

3.在1s内,mousewheel事件大概触发100次左右。

4.滑动过程中,数值会有抖动问题。

实现拖动路线思路(Path)

针对快速滑动

1.deltaX、deltaY值的最初值的正负是与滑动方向不同的这部分数据要舍弃。(因为不是真正方向)

2.每次触发的deltaX、deltaY值两两相减,结果值如果与方向不同,则舍弃。
3.剩下的差值就是方向挪动距离。

4.两个方向的所有差值相加,共两组,哪组值大取哪组,正负决定方向。

针对缓慢滑动

1.由于deltaX、deltaY值的值域是非常小,所以都保留,但值与方向不同的,也舍弃。

2.两个方向的所有差值相加,共两组,哪组值大取哪组,正负决定方向。

实现手势思路(Gesture)

在上面的基础上,记录一段时间内deltaX、deltaY和两两差值:

deltaX、deltaY用来统计放大、缩小手势。

两两差值用来统计上、下、左、右手势。

所以,手势是一段时间的手势,而不是某个时刻的。

实现代码

具体代码就不贴出来,可直接在我Github下载:https://github.com/codingforme/jquery-mac-mousewheel

总结

路线问题:mousewheel给予的deltaX、deltaY值跟操作效果有挺大不同,快速滑动效果特别不准确。

手势问题:由于双指特性的第三点,手势实现无法精确,即便是把时间段变得很短,但因为数据量问题(无法用微积分的思路),会变得更不精确;把时间段变长,反应时长又会变长;

具体效果可以下代码来看看,效果不大满意,但可以下载看看,有更好的方案,请告诉我,跪谢。

免责声明:文章转载自《js实现Mac触摸板双指事件(上/下/左/右/放大/缩小)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇DBMS_LOCK包的学习基于jQuery实现简单的js模块化下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

macOS Catalina 根目录锁定问题解决方法

更新完macOS Catalina(Version 10.15), 发现根目录的/data目录被移除了, 很是懊恼, 和同事交流找了个办法搞回来, 以下是步骤. 1.关机按cmd+R重启进入恢复模式, 关闭SIP(命令: csrutil disable ), 正常重启2.重新挂载根目录 (命令: sudo mount -uw /), 在你喜欢的地方建立da...

如何在CentOS 7上安装Node.js和npm

Node.js是一个跨平台的JavaScript运行时环境,允许在服务器端执行JavaScript代码。Node.js主要用于后端,但也作为全栈和前端解决方案而流行。 npm,Node软件包管理器的缩写,是Node.js的默认软件包管理器,也是用于发布开源Node.js软件包的世界上最大的软件存储库。 本文引导完成在CentOS 7计算机上安装Node....

mac 获得进程信息的方法

NSProcessInfo可以获得当前进程的信息。获得所有活动进程信息可以尝试使用下面的方法。 进程的信息可以通过ps命令得到也可以通过sysctl方法得到。 但是我总是不能获取进程的流量信息,关于这一点很纠结,现在的想法就是如果能够获取进程的网络端口,然后对端口进行监听,统计其流量,但是如何能够获取进程的网络端口? 在linux中可以通过netstat...

分享一个博客园皮肤制作脚手架

前言 最近本着新年新气象的想法,想换套新的博客园皮肤。 之前自己做了一套制作皮肤的解决方案,这是当时分享皮肤以及解决方案的博客:分享一款博客园皮肤及其解决方案。 不过在制作新的皮肤过程中,使用这个解决方案时还是遇到了很多问题。 而为了更方便地制作新皮肤,就升级了原先的解决方案,搭建了这套博客园皮肤制作脚手架。 项目地址已从github换到了码云:https:...

JS中常用的xpath特性

//选择所有dir元素的值等于xx的元素    Dom.documentElement.selectNodes("server/dir[text()='xx']")       //选择server元素下的所有dir元素:    Dom.documentElement.selectNodes("server/dir")       //选择server元素...

js 递归思想 处理后台多维数组的数据 之 完美契合

不多BB! 直接看源码 get(tree = []) {let self = thislet arr = [];if (!!tree && tree.length !== 0) {tree.forEach(item => {let obj = {};obj.title = item.menuName;// obj.id = item....