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 相关文章推荐
JavaScript 指导方针
Apr 05 Javascript
Js操作Select大全(取值、设置选中等等)
Oct 29 Javascript
对Jquery中的ajax再封装,简化操作示例
Feb 12 Javascript
JavaScript 封装一个tab效果源码分享
Sep 15 Javascript
js实现滚动条滚动到页面底部继续加载
Dec 19 Javascript
Bootstrap自定义文件上传下载样式
May 26 Javascript
jQuery的Cookie封装,与PHP交互的简单实现
Oct 05 Javascript
使用yeoman构建angular应用的方法
Aug 14 Javascript
JS实现的判断方法、变量是否存在功能示例
Mar 28 Javascript
详解TypeScript+Vue 插件 vue-class-component的使用总结
Feb 18 Javascript
简单了解JavaScript弹窗实现代码
May 07 Javascript
jquery实现穿梭框功能
Jan 19 jQuery
一个简易的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的中问验证码
2006/11/25 PHP
php的一个登录的类 [推荐]
2007/03/16 PHP
微盾PHP脚本加密专家php解密算法
2020/09/13 PHP
支持中文的php加密解密类代码
2011/11/27 PHP
Web程序工作原理详解
2014/12/25 PHP
php打印一个边长为N的实心和空心菱型的方法
2015/03/02 PHP
php阳历转农历优化版
2016/08/08 PHP
php curl批处理实现可控并发异步操作示例
2018/05/09 PHP
js滚动条多种样式,推荐
2007/02/05 Javascript
JqGrid web打印实现代码
2011/05/31 Javascript
Javascript的数组与字典用法与遍历对象的属性技巧
2012/11/07 Javascript
JS用斜率判断鼠标进入DIV四个方向的方法
2016/11/07 Javascript
9个让JavaScript调试更简单的Console命令
2016/11/14 Javascript
AngularJS中的JSONP实例解析
2016/12/01 Javascript
浅谈node中的exports与module.exports的关系
2017/08/01 Javascript
元素全屏的设置与监听实例
2017/11/28 Javascript
利用vue开发一个所谓的数独方法实例
2017/12/21 Javascript
Node.js 使用AngularJS的方法示例
2018/05/11 Javascript
解决Angular4项目部署到服务器上刷新404的问题
2018/08/31 Javascript
实现elementUI表单的全局验证的方法步骤
2019/04/29 Javascript
python数据类型_字符串常用操作(详解)
2017/05/30 Python
Python双精度浮点数运算并分行显示操作示例
2017/07/21 Python
Python json模块dumps、loads操作示例
2018/09/06 Python
对python读取CT医学图像的实例详解
2019/01/24 Python
使用python爬取微博数据打造一颗“心”
2019/06/28 Python
对Python中画图时候的线类型详解
2019/07/07 Python
Python3 使用map()批量的转换数据类型,如str转float的实现
2019/11/29 Python
python集合能干吗
2020/07/19 Python
python 制作网站小说下载器
2021/02/20 Python
详解background属性的8个属性值(面试题)
2020/11/02 HTML / CSS
使用HTML5和CSS3制作一个模态框的示例
2018/03/07 HTML / CSS
PatPat德国:妈妈的每日优惠
2019/10/02 全球购物
Java中的类包括什么内容?设计时要注意哪些方面
2012/05/23 面试题
市委召开党的群众路线教育实践活动总结大会报告
2014/10/21 职场文书
悬空寺导游词
2015/02/05 职场文书
呼啸山庄读书笔记
2015/06/29 职场文书