分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn/jiangjunshow
也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!
http://www.swiper/
下载:http://download.csdn/detail/cometwo/9407912
原文地址:http://wwwblogs/iamlilinfeng/p/4239957.html
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事件进行处理。
经验分享:写到这个事件的时候有人必然要问了,在触屏中我们使用Click事件不也可以吗?这个Tap事件与Click事件有什么区别呢?博主也曾经有过这样的疑惑,起初在触屏上处理点击的时候也一直用的click事件,并且没也有出现任何问题,直到有一天为一个公司做了微信版本的“连连看”小游戏,连连看的业务简单来说就是屏幕上有很多图片,当点击两个相同图案的图片时可以在中间产生连接线,并且产生爆破效果后消失。这个游戏刚开始做的时候是在ff浏览器上做的测试,鼠标点击后效果非常流畅,但当游戏部署到服务器上并用手机端操作时,iphone和wp都非常流畅,安卓下不管怎么调都是有卡顿。起初以为是手机性能的问题,但换了高配手机后仍然会有卡顿,游戏也不是不能玩,就是反应慢。经过多次的测试后排除了手机配置的硬件原因,开始怀疑click事件。经过网上查阅后才得知,在安卓触屏上,Tap事件和click事件可以同时触发,但click事件会有几百毫秒的延迟,即先触发Tap事件,过一段时间再触发click事件。后来把游戏的所有click事件修改成Tap事件问题就自然解决了。
<!DOCTYPE html><html lang="zh"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta content="initial-scale=1.0,maximum-scale=1.0,width=device-width" name="viewport"> <meta name="apple-touch-fullscreen" content="YES"> <meta name="format-detection" content="telephone=no"> <meta name="apple-mobile-web-app-capable" content="yes"> <meta name="apple-mobile-web-app-status-bar-style" content="black"> <meta http-equiv="expires" content="0"> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <title>jQuery支持触摸事件的轮播图</title> <link rel="stylesheet" type="text/css" href="css/default.css"> <link rel="stylesheet" href="css/jquery.hiSlider.min.css"> <script src="js/jquery.1.9.1.js"></script> <script src="js/jquery.hiSlider.min.js"></script> <script type="text/javascript" src="js/hammer.js"></script> <script> $(function() { //首页轮播图 $('.hiSlider3').hiSlider({ isFlexible: true, isSupportTouch: true, titleAttr: function(curIdx) { return $('img', this).attr('alt'); } }); }); $(function() { var i = 0; //创建一个新的hammer对象并且在初始化时指定要处理的dom元素 var hammertime = new Hammer(document.getElementById("test1")); //添加事件 hammertime.on("tap", function(e) { document.getElementById("result1").innerHTML = "点击触发第" + (i++) + "次,长按无效"; //控制台输出 console.log(e); }); }); $(function() { //创建一个新的hammer对象并且在初始化时指定要处理的dom元素 var hammertime = new Hammer(document.getElementById("test2")); //添加事件 hammertime.on("swipeleft", function(e) { document.getElementById("result2").innerHTML = "向左滑动: X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />"; //控制台输出 console.log(e); }); hammertime.on("swiperight", function(e) { document.getElementById("result2").innerHTML = "向右滑动: X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />"; //控制台输出 console.log(e); }); //垂直方向默认是关闭的,swipeup,swipedown默认不能用,需手动打开,可能会影响左右滑动// hammertime.get('swipe').set({// direction: Hammer.DIRECTION_VERTICAL// }); hammertime.on("swipeup", function(e) { document.getElementById("result2").innerHTML = "向上滑动: X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />"; //控制台输出 console.log(e); }); hammertime.on("swipedown", function(e) { document.getElementById("result2").innerHTML = "向下滑动: X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />"; //控制台输出 console.log(e); }); }); $(function() { //创建一个新的hammer对象并且在初始化时指定要处理的dom元素 var hammertime = new Hammer(document.getElementById("test3")); //添加事件 hammertime.on("pan", function(e) { document.getElementById("result3").innerHTML = "X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />"; //控制台输出 console.log(e); }); }); $(function() { //创建一个新的hammer对象并且在初始化时指定要处理的dom元素 var hammertime = new Hammer(document.getElementById("test4")); //为该dom元素指定触屏移动事件 hammertime.add(new Hammer.Pinch()); //添加事件 hammertime.on("pinchin", function(e) { document.getElementById("result4").innerHTML = "两手指越来越近<br />"; //控制台输出 console.log(e); }); hammertime.on("pinchout", function(e) { document.getElementById("result4").innerHTML = "两手指越来越远<br />"; //控制台输出 console.log(e); }); }); $(function() { //创建一个新的hammer对象并且在初始化时指定要处理的dom元素 var hammertime = new Hammer(document.getElementById("test5")); //添加事件 var i = 0; hammertime.on("press", function(e) { document.getElementById("result5").innerHTML = "第" + (i++) + "次按压超过500ms了<br />"; //控制台输出 console.log(e); }); }); $(function() { //创建一个新的hammer对象并且在初始化时指定要处理的dom元素 var hammertime = new Hammer(document.getElementById("test6")); //为该dom元素指定触屏移动事件 hammertime.add(new Hammer.Rotate()); //添加事件 hammertime.on("rotate", function(e) { document.getElementById("result6").innerHTML = "X偏移量:【" + e.deltaX + "】,Y偏移量:【" + e.deltaY + "】<br />"; //控制台输出 console.log(e); }); }) </script> <style type="text/css"> body, html, * { margin: 0; padding: 0; } body { width: 100%; font: 14px/2 'Microsoft YaHei', 'Arial'; } h2 { text-align: center; color: red; } li { list-style: none; } li img { display: block; margin: 0 auto; } #main { padding: 1px; /*min-width: 400px;*/ margin: 0px; background: #fefefe; } .hiSlider { overflow: hidden; height: 280px; margin: 0px; background: #eee; } .hiSlider-item { float: left; } /*hiSlider.js教程*/ .test { width: 100%; height: 150px; background: blue; text-align: left; } .result { width: 100%; height: 150px; background: green; text-align: left; overflow: hidden; } </style> </head> <body> <div id="main"> <h2>jQuery支持移动端轮播图</h2> <ul class="hiSlider hiSlider3"> <li class="hiSlider-item"><img src="images/1.jpg" alt="我是第1幅图"></li> <li class="hiSlider-item"><img src="images/2.jpg" alt="我是第2幅图"></li> <li class="hiSlider-item"><img src="images/3.jpg" alt="我是第3幅图"></li> <li class="hiSlider-item"><img src="images/4.jpg" alt="我是第4幅图"></li> <li class="hiSlider-item"><img src="images/5.jpg" alt="我是第5幅图"></li> </ul> <h2>hammer.js教程1:tap事件(点击事件)</h2> <div> <div id="test1" class="test">事件区域</div> <div id="result1" class="result">事件结果</div> </div> <h2>hammer.js教程2:swipe事件(滑动事件)</h2> <div> <div id="test2" class="test">事件区域</div> <div id="result2" class="result">事件结果</div> </div> <h2>hammer.js教程3:pan事件(拖动事件)</h2> <div> <div id="test3" class="test">事件区域</div> <div id="result3" class="result">事件结果</div> </div> <h2>hammer.js教程4:pinch事件(多点触控事件)</h2> <div> <div id="test4" class="test">事件区域</div> <div id="result4" class="result">事件结果</div> </div> <h2>hammer.js教程5:press事件(按压事件)</h2> <div> <div id="test5" class="test">事件区域</div> <div id="result5" class="result">事件结果</div> </div> <h2>hammer.js教程6:rotate事件(旋转事件)</h2> <div> <div id="test6" class="test">事件区域</div> <div id="result6" class="result">事件结果</div> </div> </div> </body></html>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
- 79
- 80
- 81
- 82
- 83
- 84
- 85
- 86
- 87
- 88
- 89
- 90
- 91
- 92
- 93
- 94
- 95
- 96
- 97
- 98
- 99
- 100
- 101
- 102
- 103
- 104
- 105
- 106
- 107
- 108
- 109
- 110
- 111
- 112
- 113
- 114
- 115
- 116
- 117
- 118
- 119
- 120
- 121
- 122
- 123
- 124
- 125
- 126
- 127
- 128
- 129
- 130
- 131
- 132
- 133
- 134
- 135
- 136
- 137
- 138
- 139
- 140
- 141
- 142
- 143
- 144
- 145
- 146
- 147
- 148
- 149
- 150
- 151
- 152
- 153
- 154
- 155
- 156
- 157
- 158
- 159
- 160
- 161
- 162
- 163
- 164
- 165
- 166
- 167
- 168
- 169
- 170
- 171
- 172
- 173
- 174
- 175
- 176
- 177
- 178
- 179
- 180
- 181
- 182
- 183
- 184
- 185
- 186
- 187
- 188
- 189
- 190
- 191
- 192
- 193
- 194
- 195
- 196
- 197
- 198
- 199
- 200
- 201
- 202
- 203
- 204
- 205
- 206
- 207
- 208
- 209
- 210
- 211
- 212
- 213
- 214
- 215
- 216
- 217
- 218
- 219
- 220
- 221
- 222
- 223
- 224
- 225
- 226
- 227
- 228
- 229
- 230
- 231
给我老师的人工智能教程打call!http://blog.csdn/jiangjunshow
更多推荐
支持移动端和PC端的轻量级轮播图插件 hammer js教程
发布评论