使用Jackmoore的缩放:http://www.jacklmoore.com/zoom/ https://github.com/jackmoore/zoom
我想在触控设备上使用双击来切换缩放效果。原因是我使用(OWL Carousel)用于图像的旋转木马还具有滑动功能,并且通过触摸和拖动图像在触摸设备上进行缩放,这与滑动冲突。
就像topman网站为移动设备所做的那样: http://www.topman.com/en/tmuk/product/clothing-140502/mens-blazers-5369753/black-textured-slim-fit-tuxedo-jacket-5390835?bi=0&ps=20
这是JS文件的链接:https://github.com/jackmoore/zoom/blob/master/jquery.zoom.js
我可以通过双击非触控设备来实现这一点:
if (settings.on === 'toggle') {
$source.on('dblclick.zoom',
function (e) {
if (clicked) {
stop();
} else {
start(e);
}
clicked = !clicked;
}
);
但是需要调整触摸设置的代码,我相信改变这一部分:
// Touch fallback
if (settings.touch) {
$source
.on('touchstart.zoom', function (e) {
e.preventDefault();
if (touched) {
touched = false;
stop();
} else {
touched = true;
start( e.originalEvent.touches[0] || e.originalEvent.changedTouches[0] );
}
})
.on('touchmove.zoom', function (e) {
e.preventDefault();
zoom.move( e.originalEvent.touches[0] || e.originalEvent.changedTouches[0] );
})
.on('touchend.zoom', function (e) {
e.preventDefault();
if (touched) {
touched = false;
stop();
}
});
}
也许添加像Touchy这样的双击监听器:https://github.com/yairEO/touchy可以解决这个问题。我现在设法让它识别出双击,但不是为了启动缩放功能。
答案 0 :(得分:0)
您可以自己创建双击处理程序。您需要一些东西来跟踪点击发生的速度。
在触摸结束时,您需要并存储一个时间戳,并了解经过多长时间,如果您想将其视为双击。
var stateVar = new Date().getTime();
function fnRef(e){
if(new Date().getTime() - stateVar < 300){
e.preventDefault();
// invoke logic here
}
}
element.addEventListener("touchend", fnRef);
上面应该适应你的编码风格和案例,但总的来说这就是它背后的逻辑。
我使用300ms作为比较值的原因是因为您需要阻止点击行为并在那时调用缩放。 300ms是指tap事件应该调用点击它的目标(触摸启用环境中使用的浏览器的常见行为)