html拖拽手势,h5实现手势操作放大缩小拖动等

本文介绍如何在Vue开发的H5应用中利用Hammer.js实现手势操作,包括手势放大缩小和拖动功能。通过安装和引入Hammer.js,设置pinch和pan事件监听,处理缩放比例和拖动距离,实现无缝手势交互。同时,文章提到在双击后恢复初始状态的处理方法。
摘要由CSDN通过智能技术生成

最近开发遇到了这个需求,使用vue开发h5加一个手势放大缩小的功能,移动端的手势操作用原生的写法太麻烦,而且体验还不好,所以从github找到一个hammer.js的一个手势操作插件。

官方文档地址:http://hammerjs.github.io/

文档写的一般的,看的不怎么明白,又从网上查了一些别人做过的案例,这个插件可以实现功能,但是一些逻辑还是得自己写。

实现手势缩放用到了插件的pinch翻译就是捏的意思,使用也遇到一些坑。

1、首先下载这个插件

cnpm install hammerjs --save

2、然后在使用的组件页面引入

import Hammer from 'hammerjs'

3、初始化插件,找到指定的dom节点。手势缩放默认是禁调的,需要设置开启。

4、手势缩放在pinch回调函数里面的e的对象里面封装了一个scale的属性,就是代表这个缩放大小,但是有一个问题,每次缩放完毕之后,再次缩放scale就会重置为1所以需要判断是不是第一次缩放,记录缩放之后的值,以相乘的方式进行比例缩放,测试之后是可行的。更多功能参考官方文档。

5、拖动用到了pan,拖动有向上拖动panup,向下拖动pandown,向左拖动panleft,向右拖动panright,拖动开始panstart,拖动结束panend,拖动通过e.deltaX,e.deltalY来计算移动的距离,我用的是css3的translate,拖动结束记录结束的delatX delatY,在拖动的时候当前的的delatX

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值