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模拟面向对象全解(一、类型及传递)
Jul 13 Javascript
Jquery中删除元素的实现代码
Dec 29 Javascript
flash调用js中的方法,让js传递变量给flash的办法及思路
Aug 07 Javascript
js(JavaScript)实现TAB标签切换效果的简单实例
Feb 26 Javascript
js操作数组函数实例小结
Dec 10 Javascript
Bootstrap中的表单验证插件bootstrapValidator使用方法整理(推荐)
Jun 21 Javascript
解决vue项目报错webpackJsonp is not defined问题
Mar 14 Javascript
jQuery pager.js 插件动态分页功能实例分析
Aug 02 jQuery
解决小程序无法触发SESSION问题
Feb 03 Javascript
vue实现导航菜单和编辑文本的示例代码
Jul 04 Javascript
JS如何在不同平台实现多语言方式
Jul 16 Javascript
js实现飞机大战游戏
Aug 26 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之第二天
2006/10/09 PHP
PHP 时间日期操作实战
2011/08/26 PHP
PHP基于文件存储实现缓存的方法
2015/07/20 PHP
Yii框架函数简单用法分析
2019/09/09 PHP
漂亮的提示信息(带箭头)
2007/03/21 Javascript
用正则表达式 动态创建/增加css style script 兼容IE firefox
2009/03/10 Javascript
jquery 最简单的属性菜单
2009/10/08 Javascript
JQuery获取元素文档大小、偏移和位置和滚动条位置的方法集合
2010/01/12 Javascript
老鱼 浅谈javascript面向对象编程
2010/03/04 Javascript
js鼠标滑过弹出层的定位IE6bug解决办法
2012/12/26 Javascript
js的onload事件及初始化按钮事件示例代码
2013/09/25 Javascript
在JavaScript中重写jQuery对象的方法实例教程
2014/08/25 Javascript
jQuery获得包含margin的outerWidth和outerHeight的方法
2015/03/25 Javascript
微信小程序商品到详情的实现
2017/06/27 Javascript
微信小程序checkbox组件使用详解
2018/01/31 Javascript
layui 地区三级联动 form select 渲染的实例
2019/09/27 Javascript
python中根据字符串调用函数的实现方法
2016/06/12 Python
TensorFlow模型保存和提取的方法
2018/03/08 Python
python找出完数的方法
2018/11/12 Python
python使用Plotly绘图工具绘制水平条形图
2020/03/25 Python
Pytorch抽取网络层的Feature Map(Vgg)实例
2019/08/20 Python
python装饰器使用实例详解
2019/12/14 Python
利用keras加载训练好的.H5文件,并实现预测图片
2020/01/24 Python
PyCharm配置anaconda环境的步骤详解
2020/07/31 Python
Python 读取位于包中的数据文件
2020/08/07 Python
python调用百度AI接口实现人流量统计
2021/02/03 Python
英国虚拟主机服务商:eUKhost
2016/08/16 全球购物
全球独特生活方式产品和礼品购物网站:AHAlife
2018/09/18 全球购物
俄罗斯马克西多姆家居用品网上商店:Максидом
2020/02/06 全球购物
护士岗位职责
2014/02/16 职场文书
函授本科个人自我鉴定
2014/03/25 职场文书
2014年护士个人工作总结
2014/11/11 职场文书
2015年春训学习心得体会范文
2015/03/09 职场文书
反腐倡廉学习心得体会范文
2015/08/15 职场文书
高考满分作文赏析(2篇)
2019/08/12 职场文书
详解flex:1什么意思
2022/07/23 HTML / CSS