如何通过html5实现摇一摇的功能

互联网 18-6-9
原理:使用DeviceMotion实现,关于DeviceMotion介绍可以查看 https://developer.mozilla.org/en-US/docs/Web/Reference/Events/devicemotion

通过DeviceMotionEvent,可以获得accelerationIncludingGravity的x,y,z属性,根据x,y,z属性的变化来判断设备是否有摇一摇的事件发生。

accelerationIncludeingGravity说明: The acceleration of the device. This value includes the effect of gravity, and may be the only value available on devices that don’t have a gyroscope to allow them to properly remove gravity from the data.

代码如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html>  <head>   <meta http-equiv="content-type" content="text/html;charset=utf-8">       <title> html5使用DeviceMotionEvent实现摇一摇 </title>   <style type="text/css">   .center{position:absolute; width:640px; height:480px; left:50%; top:50%; margin-left:-320px; margin-top:-240px; line-height:480px; text-align:center; font-size:100px; }   .normal{background:#000000;}   .normal .txt{color:#FFFFFF;}   .doing{background:#FF0000;}   .doing .txt{color:#FFFF00;}   </style>  </head>  <body id="mybody" class="normal">     <p id="txt" class="txt center">请执行摇一摇</p>  </body>  <script type="text/javascript">     var doing = 0;  // 判断是否在动画显示中     var speed = 23; // 定义摇动的速度数值     var lastx = 0;    var lasty = 0;    var lastz = 0;    function handleMotionEvent(event) {         var x = event.accelerationIncludingGravity.x;        var y = event.accelerationIncludingGravity.y;        var z = event.accelerationIncludingGravity.z;        if(doing==0){            if(Math.abs(x-lastx)>speed || Math.abs(y-lasty)>speed){                 doing = 1;                 show();             }         }         lastx = x;         lasty = y;         lastz = z;     }    function show(){         document.getElementById('mybody').className = 'doing';         document.getElementById('txt').innerHTML = '执行了摇一摇';         setTimeout(function(){             doing=0;              document.getElementById('mybody').className='normal';             document.getElementById('txt').innerHTML = '请执行摇一摇';         },3000);     }     window.addEventListener("devicemotion", handleMotionEvent, true); </script></html>

本文介绍了通过html5实现摇一摇的功能,更多相关内容请关注php中文网。

相关推荐:

如何通过MySql查看与修改auto_increment的方法

如何通过php生成网页桌面的快捷方式

利用js遍历获取表格内数据的方法

以上就是如何通过html5实现摇一摇的功能的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: device
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:html5触摸事件判断滑动方向的实现

相关资讯