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 相关文章推荐
20个非常有用的PHP类库 加速php开发
Jan 15 Javascript
ASP.NET jQuery 实例17 通过使用jQuery validation插件校验ListBox
Feb 03 Javascript
JS+CSS实现的经典圆角下拉菜单效果代码
Oct 21 Javascript
JavaScript中获取纯正的undefined的方法
Mar 06 Javascript
微信小程序左滑删除效果的实现代码
Feb 20 Javascript
jQuery源码解读之extend()与工具方法、实例方法详解
Mar 30 jQuery
原生JS实现图片懒加载(lazyload)实例
Jun 13 Javascript
使用angular帮你实现拖拽的示例
Jul 05 Javascript
为vue项目自动设置请求状态的配置方法
Jun 09 Javascript
vue中进行微博分享的实例讲解
Oct 14 Javascript
微信小程序scroll-view点击项自动居中效果的实现
Mar 25 Javascript
js实现筛选功能
Nov 24 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 url地址栏传中文乱码解决方法集合
2010/06/25 PHP
php生成zip压缩文件的方法详解
2013/06/09 PHP
PHP的一个完美GIF等比缩放类,附带去除缩放黑背景
2014/04/01 PHP
PHP传参之传值与传址的区别
2015/04/24 PHP
谈谈PHP中substr和substring的正确用法及相关参数的介绍
2015/12/16 PHP
ThinkPHP删除栏目(实现批量删除栏目)
2017/06/21 PHP
visual studio code 调试php方法(图文详解)
2017/09/15 PHP
php把字符串指定字符分割成数组的方法
2018/03/12 PHP
php支付宝系列之电脑网站支付
2018/05/30 PHP
javascript fullscreen全屏实现代码
2009/04/09 Javascript
JQuery 无废话系列教程(一) jquery入门 [推荐]
2009/06/23 Javascript
JavaScript 对Cookie 操作的封装小结
2009/12/31 Javascript
firefox火狐浏览器与与ie兼容的2个问题总结
2010/07/20 Javascript
异步javascript的原理和实现技巧介绍
2012/11/08 Javascript
jQuery实现回车键(Enter)切换文本框焦点的代码实例
2014/05/05 Javascript
深入分析jquery解析json数据
2014/12/09 Javascript
jquery实现可拖拽弹出层特效
2015/01/04 Javascript
简述JavaScript的正则表达式中test()方法的使用
2015/06/16 Javascript
详解Vue中使用Echarts的两种方式
2018/07/03 Javascript
JS实现HTML页面中动态显示当前时间完整示例
2018/07/30 Javascript
easyUI 实现的后台分页与前台显示功能示例
2020/06/01 Javascript
Vue项目接入Paypal实现示例详解
2020/06/04 Javascript
JavaScript交换变量常用4种方法解析
2020/09/02 Javascript
Angular+Ionic使用queryParams实现跳转页传值的方法
2020/09/05 Javascript
python编写分类决策树的代码
2017/12/21 Python
Python 使用PIL numpy 实现拼接图片的示例
2018/05/08 Python
运行django项目指定IP和端口的方法
2018/05/14 Python
windows下python安装pip图文教程
2018/05/25 Python
Python代码块批量添加Tab缩进的方法
2018/06/25 Python
关于Python 中的时间处理包datetime和arrow的方法详解
2020/03/19 Python
Myprotein意大利官网:欧洲第一运动营养品牌
2018/11/22 全球购物
日本最大化妆品和美容产品的综合口碑网站:cosme shopping
2019/08/28 全球购物
什么是动态端口(Dynamic Ports)?动态端口的范围是多少?
2014/12/12 面试题
个人简历自我评价八例
2013/10/31 职场文书
班组长岗位职责
2014/03/03 职场文书
pnpm对npm及yarn降维打击详解
2022/08/05 Javascript