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 相关文章推荐
兼容FireFox 的 js 日历 支持时间的获取
Mar 04 Javascript
利用onresize使得div可以随着屏幕大小而自适应的代码
Jan 15 Javascript
JQuery优缺点分析说明
Apr 10 Javascript
关于JavaScript中string 的replace
Apr 12 Javascript
js 走马灯简单实例
Nov 21 Javascript
JS中产生标识符方式的演变
Jun 12 Javascript
js实现模拟银行卡账号输入显示效果
Nov 18 Javascript
一种基于浏览器的自动小票机打印实现方案(js版)
Jul 26 Javascript
Canvas 制作动态进度加载水球详解及实例代码
Dec 09 Javascript
通过 JS 判断页面是否有滚动条的实现方法
Apr 05 Javascript
vue中datepicker的使用教程实例代码详解
Jul 08 Javascript
vue使用节流函数的踩坑实例指南
May 20 Vue.js
一个简易的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
为php4加入动态flash文件的生成的支持
2006/10/09 PHP
php5 图片验证码实现代码
2009/12/11 PHP
php smarty模版引擎中变量操作符及使用方法
2009/12/11 PHP
PHP输出两个数字中间有多少个回文数的方法
2015/03/23 PHP
360搜索引擎自动收录php改写方案
2018/04/28 PHP
javascript重复绑定事件造成的后果说明
2013/03/02 Javascript
json数据处理技巧(字段带空格、增加字段、排序等等)
2013/06/14 Javascript
jQuery通过扩展实现抖动效果的方法
2015/03/11 Javascript
JavaScript和JQuery的鼠标mouse事件冒泡处理
2015/06/19 Javascript
js实现密码强度检测【附示例】
2016/03/30 Javascript
JS iFrame加载慢怎么解决
2016/05/13 Javascript
JavaScript基础——使用Canvas绘图
2016/11/02 Javascript
js编写三级联动简单案例
2016/12/21 Javascript
jquery实现input框获取焦点的方法
2017/02/06 Javascript
vue与TypeScript集成配置最简教程(推荐)
2017/10/17 Javascript
JS实现HTML页面中动态显示当前时间完整示例
2018/07/30 Javascript
react 国际化的实现代码示例
2018/09/14 Javascript
详解Vue中的基本语法和常用指令
2019/07/23 Javascript
vue 获取视频时长的实例代码
2019/08/20 Javascript
[55:35]DOTA2-DPC中国联赛 正赛 CDEC vs Dragon BO3 第二场 1月22日
2021/03/11 DOTA
Python随机数random模块使用指南
2016/09/09 Python
Python发送http请求解析返回json的实例
2018/03/26 Python
浅谈python日志的配置文件路径问题
2018/04/28 Python
python实现判断一个字符串是否是合法IP地址的示例
2018/06/04 Python
Python使用Tkinter实现滚动抽奖器效果
2020/01/06 Python
HTML5去掉输入框type为number时的上下箭头的实现方法
2020/01/03 HTML / CSS
自荐信格式技巧有哪些呢
2013/11/19 职场文书
经理任命书模板
2014/06/06 职场文书
淘宝店策划方案
2014/06/07 职场文书
离婚协议书范本样本
2014/08/19 职场文书
党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书
2014年办公室文员工作总结
2014/11/12 职场文书
结婚保证书(三从四德)
2015/02/26 职场文书
教师聘用意向书
2015/05/11 职场文书
linux下导入、导出mysql数据库命令的实现方法
2021/05/26 MySQL
详细聊一聊mysql的树形结构存储以及查询
2022/04/05 MySQL