-
Notifications
You must be signed in to change notification settings - Fork 69
/
touches.htm
153 lines (147 loc) · 6.63 KB
/
touches.htm
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
<!doctype html />
<html>
<head>
<title>touch</title>
<meta http-equiv="content-type" content="text/html;charset=gbk" />
</head>
<body>
<img src="http://cn.bing.com/az/hprichbg?p=rb%2fForbiddenCity_ZH-CN276990937.jpg"
alt="test" ontouchstart="touchStart(event)" ontouchmove="touchMove(event)" ontouchend="touchEnd(event)" />
<div id="debug"></div>
<div id="debugSpeed"></div>
<script type="text/javascript">
function $id(id) { return document.getElementById(id); }
function setDebugMsg(msg, debugType) {
var id = 'debug' + (debugType ? debugType : '');
var o = $id(id);
if (!o) {
o = document.createElement('DIV');
o.id = id;
document.body.appendChild(o);
}
o.innerHTML = '<p>' + msg + '</p>';
}
function getTarget(e) {
return e.target || e.srcElement;
}
function getTouchFingers(e){
var fingers = [];
var touchTime = new Date();
for(var i=0;i<e.touches.length;i++){
var touch = e.touches[i];
function touchToFinger(touch) {
return {identifier:touch.identifier,pageX:touch.pageX,pageY:touch.pageY,touchTime:touchTime};
}
var finger = touchToFinger(touch);
fingers.push(finger);
}
//计算两个touch点之间的距离
for (var i = 0; i < fingers.length; i++) {
var fingerI = fingers[i];
if(i == fingers.length-1)break;
var distances = [];
for (var j = i + 1; j < fingers.length; j++) {
var fingerJ = fingers[j];
distances[fingerJ.identifier] = { x: fingerJ.pageX - fingerI.pageX, y: fingerJ.pageY - fingerI.pageY };
}
fingers[i].distances = distances;
}
return fingers;
}
function disableBubbleAndPreventDefault(e) {
if (e.preventDefault) e.preventDefault();
e.cancelBubble = true;
}
function touchStart(e) {
e = e || window.event;
//var h = 'touchStart:' + getTouchEventDesc(e);
//setDebugMsg(h);
var target = getTarget(e);
var fingers = getTouchFingers(e);
target.fingers = fingers;
disableBubbleAndPreventDefault(e);
}
function touchMove(e) {
e = e || event;
//var h = 'touchMove:' + getTouchEventDesc(e);
//setDebugMsg(h);
var target = getTarget(e);
var fingers = getTouchFingers(e);
//计算各个手指的移动速度和加速度
var oldFingers = target.fingers;
var continueExec = (fingers && fingers.length && oldFingers && oldFingers.length);
setDebugMsg('continueExec is ' + continueExec);
if (!continueExec) return;
setDebugMsg('fingers.length is ' + fingers.length);
for (var i = 0; i < fingers.length; i++) {
var fingerNew = fingers[i];
var fingerOld = null;
for (var j = 0; j < oldFingers.length; j++) {
var fingerJ = oldFingers[j];
if (fingerNew.identifier == fingerJ.identifier) {
fingerOld = fingerJ;
break;
}
}
setDebugMsg('fingerOld is ' + fingerOld);
if (fingerOld) {
//计算x方向速度
var timeSpan = (fingerNew.touchTime.getTime() - fingerOld.touchTime.getTime())*.001;
var xNew = fingerNew.pageX;
var xOld = fingerOld.pageX;
var speed = (xNew - xOld) / timeSpan;
fingerNew.speed = speed;
setDebugMsg('speed is ' + speed);
var speedOld = fingerOld.speed;
var accelerate = 0;
if (speedOld) {
accelerate = (speed - speedOld) / timeSpan;
fingerNew.accelerate = accelerate;
}
setDebugMsg('accelerate is ' + accelerate);
fingers[i] = fingerNew;
function distancesHtml(distances){
var h = '';
for(var att in distances){
h += att + '= [x:' + distances[att].x + ',y:' + distances[att].y + '];';
}
return h;
}
setDebugMsg('finger ' + fingerOld.identifier + ' x\'speed is ' + speed + ',accelerate is ' + accelerate
+ ' distances ' + distancesHtml(fingerNew.distances),
'Speed'+fingerOld.identifier);
}
}
target.fingers = fingers;
disableBubbleAndPreventDefault(e);
}
function touchEnd(e) {
e = e || event;
//var h = 'touchEnd:' + getTouchEventDesc(e);
//setDebugMsg(h);
var target = getTarget(e);
target.fingers = null;
disableBubbleAndPreventDefault(e);
}
function getTouchEventDesc(e) {
var h = 'e.touches.length=' + e.touches.length;
for (var k in e) {
h += 'e attr ' + k + ' = ' + e[k] + '<br/>';
}
for (var i = 0; i < e.touches.length; i++) {
var touch = e.touches[i];
h += ('<br/> touches[' + i + ']');
for (var att in touch) {
h += '<br/> ' + att + '=' + touch[att];
}
}
return h;
}
document.write('<div>');
for(var i in navigator){
document.write('<br/>navigator.'+i+'=' +navigator[i]);
}
document.write('</div>');
</script>
</body>
</html>