1、 Pan事件:在指定的dom区域内,一个手指放下并移动事件,即触屏中的拖动事件。这个事件在屏触开发中比较常用,如:左拖动、右拖动等,如手要上使用QQ时向右滑动出现功能菜单的效果。该事件还可以分别对以下事件进行监听并处理:
Panstart:拖动开始、Panmove:拖动过程、Panend:拖动结束、Pancancel:拖动取消、Panleft:向左拖动、Panright:向右拖动、Panup:向上拖动、Pandown:向下拖动
2、 Pinch事件:在指定的dom区域内,两个手指(默认为两个手指,多指触控需要单独设置)或多个手指相对(越来越近)移动或相向(越来越远)移动时事件。该事件事以分别对以下事件进行监听并处理:
Pinchstart:多点触控开始、Pinchmove:多点触控过程、Pinchend:多点触控结束、Pinchcancel:多点触控取消、Pinchin:多点触控时两手指距离越来越近、Pinchout:多点触控时两手指距离越来越远
3、 Press事件:在指定的dom区域内触屏版本的点击事件,这个事件相当于PC端的Click事件,该不能包含任何的移动,最小按压时间为500毫秒,常用于我们在手机上用的“复制、粘贴”等功能。该事件分别对以下事件进行监听并处理:
Pressup:点击事件离开时触发
4、 Rotate事件:在指定的dom区域内,当两个手指或更多手指成圆型旋转时触发(就像两个手指拧螺丝一样)。该事件分别对以下事件进行监听并处理:
Rotatestart:旋转开始、Rotatemove:旋转过程、Rotateend:旋转结束、Rotatecancel:旋转取消
5、 Swipe事件:在指定的dom区域内,一个手指快速的在触屏上滑动。即我们平时用到最多的滑动事件。
Swipeleft:向左滑动、Swiperight:向右滑动、Swipeup:向上滑动、Swipedown:向下滑动
6、Tap事件:在指定的dom区域内,一个手指轻拍或点击时触发该事件(类似PC端的click)。该事件最大点击时间为250毫秒,如果超过250毫秒则按Press事件进行处理。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
#myDiv{
width: 800px;
height: 800px;
background-color: red;
color:black;
text-align: center;
line-height: 400px;
margin: 200px auto;
font-size: 30px;
}
</style>
</head>
<body>
<div id="myDiv"></div>
</body>
<script src="Hammer.min.js"></script>
<!-- <script src="Hammer-time.min.js"></script> -->
<script>
var myDiv=document.getElementById('myDiv');
//创建一个新的hammer对象并且在初始化时指定要处理的dom元素
var hammertime = new Hammer(myDiv);
//为该dom元素指定触屏移动事件
// hammertime.add(new Hammer.Pinch());
hammertime.add(new Hammer.Rotate());
hammertime.on('pan', function(ev){
myDiv.style.backgroundColor="yellow";
myDiv.innerHTML="屏幕被滑动了";
});
hammertime.on('tap', function(ev){
myDiv.style.backgroundColor="pink";
myDiv.innerHTML="屏幕被点击了";
});
hammertime.on('pinch', function(ev){
myDiv.style.backgroundColor="blue";
myDiv.innerHTML="屏幕捏合被触发";
myDiv.style.transform = "scale("+ev.scale+")";
// myDiv.style.transition="2s linear";
});
hammertime.on('press', function(ev){
myDiv.style.backgroundColor="gray";
myDiv.innerHTML="屏幕长按";
});
hammertime.on('rotate', function(ev){
myDiv.style.backgroundColor="green";
myDiv.innerHTML="两个手指或更多手指成圆型旋转";
});
hammertime.on('swipeleft', function(ev){
myDiv.style.backgroundColor="white";
myDiv.innerHTML="一个手指快速的在触屏上滑动";
});
// hammertime.on("panleft panright tap press", function(ev) {
// myDiv.textContent = ev.type +" gesture detected.";
// });
</script>
</html>