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 相关文章推荐
jQuery 关于伪类选择符的使用说明
Apr 24 Javascript
js为鼠标添加右击事件防止默认的右击菜单弹出
Jul 29 Javascript
javascript中bind函数的作用实例介绍
Sep 28 Javascript
javascript中Function类型详解
Apr 28 Javascript
jQuery构造函数init参数分析续
May 13 Javascript
JavaScript评论点赞功能的实现方法
Mar 13 Javascript
微信小程序 支付功能(前端)的实现
May 24 Javascript
浅谈vue父子组件怎么传值
Jul 21 Javascript
微信小程序中上传图片并进行压缩的实现代码
Aug 28 Javascript
Angular4.x Event (DOM事件和自定义事件详解)
Oct 09 Javascript
浅谈VueJS SSR 后端绘制内存泄漏的相关解决经验
Dec 20 Javascript
微信小程序自定义导航栏实例代码
Apr 05 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
Syphon 使用方法
2021/03/03 冲泡冲煮
php字符串截取中文截取2,单字节截取模式
2007/12/10 PHP
php更改目录及子目录下所有的文件后缀扩展名的代码
2010/10/12 PHP
php输入数据统一类实例
2015/02/23 PHP
php编写的抽奖程序中奖概率算法
2015/05/14 PHP
JavaScript实用技巧(一)
2010/08/16 Javascript
jquery带翻页动画的电子杂志代码分享
2015/08/21 Javascript
jQuery模仿单选按钮选中效果
2016/06/24 Javascript
Mvc提交表单的四种方法全程详解
2016/08/10 Javascript
基于cssSlidy.js插件实现响应式手机图片轮播效果
2016/08/30 Javascript
jQuery Validation Engine验证控件调用外部函数验证的方法
2017/01/18 Javascript
ES6中Symbol类型用法实例详解
2017/04/06 Javascript
vue自定义表单生成器form-create使用详解
2019/07/19 Javascript
简单实现节流函数和防抖函数过程解析
2019/10/08 Javascript
使用Node.js实现base64和png文件相互转换的方法
2020/03/11 Javascript
Flexible.js可伸缩布局实现方法详解
2020/11/13 Javascript
python实现机器人行走效果
2018/01/29 Python
Python实现上下班抢个顺风单脚本
2018/02/07 Python
使用pytorch进行图像的顺序读取方法
2018/07/27 Python
python中类的输出或类的实例输出为这种形式的原因
2019/08/12 Python
Python多线程及其基本使用方法实例分析
2019/10/29 Python
Python生成随机验证码代码实例解析
2020/06/09 Python
Python绘制组合图的示例
2020/09/18 Python
CSS3 绘制BMW logo实的现代码
2013/04/25 HTML / CSS
MVC的各个部分都有那些技术来实现?如何实现?
2016/04/21 面试题
实习单位接收函
2014/01/11 职场文书
服务员自我评价
2014/01/25 职场文书
英文求职信写作小建议
2014/02/16 职场文书
大专生求职信
2014/06/29 职场文书
员工试用期自我评价
2014/09/18 职场文书
应聘教师自荐信
2015/03/26 职场文书
2015年社会治安综合治理工作总结
2015/04/10 职场文书
设备技术员岗位职责
2015/04/11 职场文书
机器人瓦力观后感
2015/06/12 职场文书
高中物理教学反思
2016/02/19 职场文书
SQLServer中exists和except用法介绍
2021/12/04 SQL Server