HTML5实现摇一摇的功能(实测后)
来源:互联网 发布:origins悦木之源 知乎 编辑:程序博客网 时间:2024/05/18 03:06
利用html5实现类似微信的手机摇一摇功能,并播放音乐。
1、 deviceOrientation:封装了方向传感器数据的事件,可以获取手机静止状态下的方向数据,例如手机所处角度、方位、朝向等。
2、 deviceMotion:封装了运动传感器数据的事件,可以获取手机运动状态下的运动加速度等数据。
不多说直接上代码,
Javascript:
- var SHAKE_THRESHOLD = 3000;
- var last_update = 0;
- var x = y = z = last_x = last_y = last_z = 0;
- function init() {
- if (window.DeviceMotionEvent) {
- window.addEventListener('devicemotion', deviceMotionHandler, false);
- } else {
- alert('not support mobile event');
- }
- }
- function deviceMotionHandler(eventData) {
- var acceleration = eventData.accelerationIncludingGravity;
- var curTime = new Date().getTime();
- if ((curTime - last_update) > 100) {
- var diffTime = curTime - last_update;
- last_update = curTime;
- 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 > SHAKE_THRESHOLD) {
- alert("摇动了");
- media.setAttribute("src", "http://211.148.5.228:8002/Pages/test/Kalimba.mp3");
- media.load();
- media.play();
- }
- last_x = x;
- last_y = y;
- last_z = z;
- }
- }
Html:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8" />
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
- <title>摇一摇功能</title>
- <script type="text/javascript">
- //Javascript
- </script>
- </head>
- <body onload="init()">
- <p>用力摇一摇你手机</p>
- <audio style="display:hiden" id="musicBox" preload="metadata" controls src="http://211.148.5.228:8002/Pages/test/Kalimba.mp3" autoplay="false">
- </audio>
- </body>
- </html>
IOS 测试:Safari 弹框\不播放音乐, Chroma 弹框\不播放音乐,UC弹框\不播放音乐
Andriod 测试:UC弹框\播放音乐,Chroma 弹框\播放音乐,内置浏览器 弹框\播放音乐
0 1
- HTML5实现摇一摇的功能(实测后)
- HTML5实现摇一摇的功能(实测后)
- HTML5实现摇一摇的功能(实测后)
- HTML5实现摇一摇的功能(实测后)
- HTML5实现摇一摇的功能
- html5实现摇一摇功能
- HTML5实现摇一摇功能
- html5实现摇一摇功能
- 用HTML5实现手机摇一摇的功能
- 用HTML5实现手机摇一摇的功能
- 用HTML5实现手机摇一摇的功能 .
- 用HTML5实现手机摇一摇的功能
- 用HTML5实现手机摇一摇的功能
- HTML5实现手机摇一摇的功能
- 用HTML5实现手机摇一摇的功能
- HTML5实现手机摇一摇功能
- 使用Html5的DeviceOrientation特性实现摇一摇功能
- html5实现跳动的小球的功能
- 最小的k个数
- Swift语法之 ---- ?和!区别
- Android Lrucache类注意事项
- 巴蜀最美
- 系统自带的网络加载和获取最顶层view
- HTML5实现摇一摇的功能(实测后)
- combogrid使用javascript及java做出既可以全部查询也可以模糊查询并显示的效果
- Android实现网络多线程断点续传下载
- Android中常用单位(dpi、px、dp、sp)
- TestFlight的使用步骤
- Android 根据EditText搜索框ListView动态显示数据小结
- leetcode 019 —— Remove Nth Node From End of List
- Canvas合成图像 比较简单 看代码和demo
- 大数加法