• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

javascript - Hammer.js 分别识别捏和旋转

[复制链接]
菜鸟教程小白 发表于 2022-12-11 19:41:17 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我正在尝试使用 Hammer.js 来识别触摸事件。我想在捏合和旋转手势上做不同的事情,但是一旦我将两个识别器都添加到我的 Hammer.Manager 中,只有旋转手势被识别。

我在 iphone 6s 10.3.1 的 chrome 和 safari 上尝试此操作,结果相同(当我捏合或旋转时会识别旋转,而从不识别捏合)

codepen:http://codepen.io/anon/pen/YVjogm

var myElement = document.getElementById('myElement');

var mc = new Hammer.Manager(myElement);

// create a pinch and rotate recognizer
// these require 2 pointers
var pinch = new Hammer.Pinch();
var rotate = new Hammer.Rotate();

// we want to detect both separately
pinch.requireFailure(rotate);

// add to the Manager
mc.add([pinch, rotate]);


mc.on("pinch", function(ev) {
  // do something
    myElement.textContent += ev.type +" ";
});

mc.on("rotate", function(ev) {
  // do something else
    myElement.textContent += ev.type +" ";
});

有没有办法让这些手势分别被识别?



Best Answer-推荐答案


也许这段代码可以解决问题。
我只使用捏来实现旋转和缩放功能。
试试这个代码:

var imageSize = 1;
var preAngle = 0;
var rotateAngle = 0;
var currentAngle;
var hammer = new Hammer(imgObject);
hammer.get('pinch').set({enable: true});

hammer.on("pinchmove", function(e) {
    if(preAngle == 0){
        //recode previous angle
        preAngle = Math.round(e.rotation);
    }else{
        currentAngle = (rotateAngle + Math.round(e.rotation)-preAngle);
        imgObject.style.webkitTransform = "scale("+imageSize*e.scale+") 
        rotate("+currentAngle+"deg)";
    }   
});

hammer.on("pinchend", function(e) {
    imageSize = imgObject.getBoundingClientRect().width / imgObject.offsetWidth;
    rotateAngle = currentAngle;
    preAngle = 0;
});

示例:https://codepen.io/partyyaya/pen/KLoWJJ
对不起我糟糕的英语。

关于javascript - Hammer.js 分别识别捏和旋转,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44019199/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap