js gesture 事件 处理

http://wanglingshu.com/wp-content/uploads/ios-gesture.html


var canvas = document.getElementById("canvas"),
spirit, startScale, startRotation;

function touchStart(e) {
e.preventDefault();
if (spirit || e.touches.length != 2) return;
var touch1 = e.touches[0],
pagex1 = touch1.pageX,
pagey1 = touch1.pageY,
touch2 = e.touches[1],
pagex2 = touch2.pageX,
pagey2 = touch2.pageY,
left = Math.min(pagex1, pagex2),
top = Math.min(pagey1, pagey2),
width = Math.abs(pagex1 - pagex2),
height = Math.abs(pagey1 - pagey2);
spirit = document.createElement("div");
spirit.className = "spirit";
spirit.innerHTML = "fadfdsafsdafsadfsdafsadfsdafsafsda";
spirit.style.height = height + "px";
spirit.style.width = width + "px";
spirit.style.left = left + "px";
spirit.style.top = top + "px";
canvas.appendChild(spirit);
}

function gestureStart(e) {
e.preventDefault();
}

function gestureChange(e) {
e.preventDefault();
if (!spirit) return;
if (startScale == null || startRotation == null) {
startScale = e.scale;
startRotation = e.rotation;
} else {
spirit.style.webkitTransform = 'scale(' + e.scale + startScale + ') rotate(' + e.rotation + startRotation + 'deg)';
}
}

function gestureEnd(e) {
e.preventDefault();
if (!spirit) return;
canvas.removeChild(spirit);
spirit = null;
startScale = null;
startRotation = null;
}

canvas.addEventListener("touchstart", touchStart, false);
canvas.addEventListener("gesturestart", gestureStart, false);
canvas.addEventListener("gesturechange", gestureChange, false);
canvas.addEventListener("gestureend", gestureEnd, false);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值