今回は、H5 で携帯電話を振った回数を計算する方法について説明します。H5 で携帯電話を振った回数を計算する場合の 注意事項 は何ですか。実際のケースを見てみましょう。
1. deviceOrientation: 方位センサーデータをカプセル化するイベントは、携帯電話の角度、向き、方位など、静的状態における携帯電話の方向データを取得できます。
2. deviceMotion: モーションセンサーデータをカプセル化し、携帯電話が動いているときにモーション加速度などのデータを取得できるイベント。 コードに直接進みましょう:JavaScript:
var jsonObject=null; // 当页面加载完以后会执行window.onload window.onload = function() { var times = -1; // 记录摇动次数 var last_time = 0; var borderSpeed = 800; // 加速度变化临界值 var x = y = z = last_x = last_y = last_z = 0; if (window.DeviceMotionEvent) { window.addEventListener('devicemotion',shake,false); } else { alert('您的设备不支持摇一摇哦'); } // 每次手机移动的时候都会执行下面shake函数的代码 function shake(eventData) { var acceleration = eventData.accelerationIncludingGravity; var curTime = new Date().getTime(); var diffTime = curTime-last_time; // 每隔100ms进行判断 if (diffTime>100) { x = acceleration.x; y = acceleration.y; z = acceleration.z; var speed = Math.abs(x + y + z - last_x - last_y - last_z) / diffTime * 10000; // 判断手机确实发生了摇动而不是正常的移动 if (speed>borderSpeed) { times++; document.getElementById("text").innerHTML=times+" times"; // 用户的微信昵称和头像连接发送一次即可,不需要每次都发送 if (times==0) { document.forms["insertForm"].headimg.value =img ; document.forms["insertForm"].user.value = nickname; } document.forms["insertForm"].time.value = times; } last_time = curTime; last_x = x; last_y = y; last_z = z; } } }
<img src="hand.png"> <br/><font size="16" color="red" id="text"></font>
この記事の事例を読んだ後は、この方法を習得したと思います。さらにエキサイティングな内容については、ご注意ください。 php 中国語 Web サイトの他の関連記事へ! 推奨読書:
H5 の window.postMessage とクロスドメイン
H5 のマルチスレッド (Worker SharedWorker) の詳細な説明
以上がH5 を使用して携帯電話を振った回数を計算する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。