您的位置:首页 > Web前端 > JavaScript

JS事件监听手机屏幕触摸事件 Touch

2014-03-30 05:00 447 查看
处理Touch事件能让你跟踪用户的每一根手指的位置,可以绑定以下四种Touch事件:

touchstart:  // 手指放到屏幕上的时候触发
touchmove:  // 手指在屏幕上移动的时候触发
touchend:  // 手指从屏幕上拿起的时候触发
touchcancel:  // 系统取消touch事件的时候触发。至于系统什么时候会取消,不详


事件属性一般通过event.changedTouches获得

client / clientY:// 触摸点相对于浏览器窗口viewport的位置
pageX / pageY:// 触摸点相对于页面的位置
screenX /screenY://触摸点相对于屏幕的位置
identifier: // touch对象的unique ID


简单实现

var startX=startY=0;
function touchSatrtFunc(e) {
e.preventDefault(); //阻止触摸时浏览器的缩放、滚动条滚动等
var touch = e.Touches[0]; //获取第一个触点
var x = Number(touch.pageX); //页面触点X坐标
var y = Number(touch.pageY); //页面触点Y坐标
startX = x;
startY = y;
}
//touchmove事件
function touchMoveFunc(e) {
e.preventDefault(); //阻止触摸时浏览器的缩放、滚动条滚动等
var touch = e.touches[0];
var x = touch.pageX - startX,
y = touch.pageY - startY;
var text = 'Move:(' + (x) + ', ' + y + ')';
document.title = text;
}

//touchend事件
function ToucheEndFunc(e) {
e.preventDefault(); //阻止触摸时浏览器的缩放、滚动条滚动等
var touch = e.changedTouches[0]; //获取第一个触点

var x = touch.pageX; //页面触点X坐标
var y = Number(touch.pageY); //页面触点Y坐标
var text = 'end:(' + x + ', ' + y + ')';
document.title = text;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: