JS实现微信摇一摇原理解析


Posted in Javascript onJuly 22, 2017

本文为大家分享了JS实现微信摇一摇的原理,供大家参考,具体内容如下

实现原理:

1.微信摇一摇事件需要有硬件支撑,必须要求手机中有陀螺仪
2.在JS中给window添加ondevectionmotion事件。该事件在手机晃动,即手机中的陀螺仪发生旋转,该事件会触发
3.触发ondevectionmotion事件,会产生一个事件对象,通过该对象中的键值(accelerationIncludingGravity)来获得该重力加速器对象
4.重力加速器对象中含有陀螺仪的坐标,通过重力加速器对象.x - .y - .z 获取陀螺仪当前的坐标

<!DOCTYPE html> 
<html> 
 <head> 
  <meta charset="UTF-8"> 
  <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> 
  <title>微信摇一摇</title> 
 </head> 
 <body> 
  <!--请摇一摇--> 
 </body> 
 <script type="text/javascript"> 
  function randomNum(m,n){ 
   return Math.floor(Math.random(n - m + 1) + m); 
  } 
  //cover设置背景尺寸 
  //将背景图按所在标签的宽高,缩放 
  document.body.style.backgroundSize = "cover"; 
  //设置body的背景图 
  document.body.style.backgroundImage = "url(img/bg.jpg)" ; 
  //事件设备:触发该事件需要硬件支持 
  //摇一摇功能: 
  //1.手机中的陀螺仪加速两次 加速器的差值当达到某个值时,则认为是手机晃动事件 
  //2.设置手机晃动事件前,获取加速器的值 
  //3.添加手机晃动事件;     
  //获取手机晃动前加速器的值,创建一个对象获取 
  var currentValue = { 
   x : 0, 
   y : 0, 
   z : 0 
  }; 
  //获取手机晃动之后加速器的值,创建一个对象获取 
  var lastValue = { 
   x : 0, 
   y : 0, 
   z : 0 
  } 
  //设置晃动的最小的距离,只有达到该距离时,才执行摇一摇事件 
  var minValue = 20; 
  //当手机触发摇一摇事件时,我们得到此时的位置信息,存储到一个p标签上 
  //理论上讲:陀螺仪事件中的加速器是无法静止的; 
  var p1 = document.createElement("p"); 
  //第一种方式: 
  var img1 = document.createElement("img"); 
  img1.style.width = "375px"; 
  img1.style.height = "560px"; 
  //手机晃动事件 
  window.ondevicemotion = function(e){ 
   //获取对象 
   var event1 = event || e; 
   //获取加速器对象,为了获取陀螺仪上的坐标信息 
   var acceleration = event1.accelerationIncludingGravity; 
   //记录当前加速器的值 
   currentValue.x = acceleration.x; 
   currentValue.y = acceleration.y; 
   currentValue.z = acceleration.z; 
   //判断微信摇一摇事件(手机是否晃动) 
   if (Math.abs(currentValue.x - lastValue.x) >= minValue || Math.abs(currentValue.y - lastValue.y) > minValue || Math.abs(currentValue.z - lastValue.z) > minValue) { 
    //说明摇一摇事件触发 
    //实现微信摇一摇,可以将摇一摇中的图片,作为body的背景图 
    //随机一张图片的下标(1 - 5) 
    var ranN = randomNum(1,6); 
    //创一个定时器 
    var timer = setInterval(function(){ 
     ranN ++ 
     if (ranN == 6) { 
      ranN = 1; 
     } 
     //为当前的body设置背景图 
     //document.body.style.backgroundImage = "url(img/"+ranN+".jpg)"; 
     //为当前img设置路径 
     img1.src = "img/"+ranN+".jpg"; 
      
    },200); 
    //设置一个延时器,延时一段时间后消除延时器 
    setTimeout(function(){ 
     clearInterval(timer); 
    },1000); 
   } 
   //记录最后的值(保存上一次晃动事件中的加速器的值) 
   lastValue.x = currentValue.x; 
   lastValue.y = currentValue.y; 
   lastValue.z = currentValue.z; 
  } 
  document.body.appendChild(img1); 
 </script> 
</html>

注意:该代码中没有上传图片,如需要运行需要自己在代码的同级目录创建一个img文件夹,里面放上从1到6的后缀为.jpg的图片

Javascript 相关文章推荐
奇妙的js
Sep 24 Javascript
javascript获取作用在元素上面的样式属性代码
Sep 20 Javascript
如何在指定的地方插入html内容和文本内容
Dec 23 Javascript
JQuery记住用户名和密码的具体实现
Apr 04 Javascript
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
Dec 14 Javascript
Angular2 Service实现简单音乐播放器服务
Feb 24 Javascript
移动端手指放大缩小插件与js源码
May 22 Javascript
浅谈vuepress 踩坑记
Apr 18 Javascript
使用jquery的cookie实现登录页记住用户名和密码的方法
Mar 13 jQuery
Javascript读写cookie的实例源码
Mar 16 Javascript
使用mixins实现elementUI表单全局验证的解决方法
Apr 02 Javascript
javascript中this的用法实践分析
Jul 29 Javascript
一个简易的js图片轮播效果
Jul 22 #Javascript
基于JS脚本语言的基础语法详解
Jul 22 #Javascript
JS原生轮播图的简单实现(推荐)
Jul 22 #Javascript
JS+HTML5实现图片在线预览功能
Jul 22 #Javascript
JQuery和html+css实现带小圆点和左右按钮的轮播图实例
Jul 22 #jQuery
JS原生带小白点轮播图实例讲解
Jul 22 #Javascript
JS按钮闪烁功能的实现代码
Jul 21 #Javascript
You might like
php数组(array)输出的三种形式详解
2013/06/05 PHP
PHP使用DES进行加密与解密的方法详解
2013/06/06 PHP
php实现计数器方法小结
2015/01/05 PHP
php生成数字字母的验证码图片
2015/07/14 PHP
PHP中Closure类的使用方法及详解
2015/10/09 PHP
php转换上传word文件为PDF的方法【基于COM组件】
2019/06/10 PHP
Extjs学习笔记之八 继承和事件基础
2010/01/08 Javascript
动态载入/删除/更新外部 JavaScript/Css 文件的代码
2010/07/03 Javascript
基于jQuery实现模拟页面加载进度条
2013/04/01 Javascript
jQuery根据纬度经度查看地图处理程序
2013/05/08 Javascript
使用Chrome调试JavaScript的断点设置和调试技巧
2014/12/16 Javascript
JavaScript中遍历对象的property的3种方法介绍
2014/12/30 Javascript
JavaScript判断变量是否为空的自定义函数分享
2015/01/31 Javascript
js正则表达式匹配数字字母下划线等
2015/04/14 Javascript
微信小程序 数据访问实例详解
2016/10/08 Javascript
基于Vue+element-ui 的Table二次封装的实现
2018/07/20 Javascript
JS执行控制之节流模式实例分析
2018/12/21 Javascript
windows实现npm和cnpm安装步骤
2019/10/24 Javascript
原生JS实现汇率转换功能代码实例
2020/05/13 Javascript
Python操作MySQL简单实现方法
2015/01/26 Python
Python实现生成简单的Makefile文件代码示例
2015/03/10 Python
Python实现把回车符\r\n转换成\n
2015/04/23 Python
python 进程的几种创建方式详解
2019/08/29 Python
python调用摄像头的示例代码
2020/09/28 Python
mac系统下安装pycharm、永久激活、中文汉化详细教程
2020/11/24 Python
Python控制鼠标键盘代码实例
2020/12/08 Python
Python3+Flask安装使用教程详解
2021/02/16 Python
Molton Brown美国官网:奢华美容、香水、沐浴和身体护理
2020/09/02 全球购物
电大自我鉴定范文
2013/10/01 职场文书
消防安全宣传口号
2014/06/10 职场文书
补充协议书
2015/01/28 职场文书
考博导师推荐信范文
2015/03/27 职场文书
毕业论文答辩开场白和答辩技巧
2015/05/27 职场文书
领导莅临指导欢迎词
2015/09/30 职场文书
学生会2016感恩节活动小结
2016/04/01 职场文书
详解Vue项目的打包方式(生成dist文件)
2022/01/18 Vue.js