做网站需要的大图,网站建设广告图片,有没有接单做加工的网站,网站设计论文开题报告最近用ofo小黄车App的时候#xff0c;发现以前下方扫一扫变成了一个眼睛动的小黄人#xff0c;觉得蛮有意思的#xff0c;这里用HTML5仿一下效果。
ofo眼睛效果 效果分析
从效果中不难看出#xff0c;是使用陀螺仪事件实现的。
这里先来看一下HTML5中陀螺仪事件的一些概…最近用ofo小黄车App的时候发现以前下方扫一扫变成了一个眼睛动的小黄人觉得蛮有意思的这里用HTML5仿一下效果。
ofo眼睛效果 效果分析
从效果中不难看出是使用陀螺仪事件实现的。
这里先来看一下HTML5中陀螺仪事件的一些概念。
陀螺仪事件为deviceorientation这里主要获取事件中的alpha,beta,gamma。
aplha
行动装置水平放置时绕 Z 轴旋转的角度数值为 0 度到 360 度。
beta
行动装置水平放置时绕 X 轴旋转的角度数值为 -180 度到 180 度。
gamma
行动装置水平放置时绕 Y 轴旋转的角度数值为 -90 度到 90 度。 这里只需要用到beta和gamma。
将apk解压得到眼睛素材
代码实现
!DOCTYPE html
html langen
headmeta charsetUTF-8meta nameviewport contentwidthdevice-width, initial-scale1.0, maximum-scale1.0, user-scalablenotitleDocument/titlestyle#box{position: relative;width: 300px;margin: 0 auto;}#face{background-image: url(images/face.png);background-size: cover;width: 300px;height: 300px;position: absolute;}#eyeLeft{background-image: url(images/eye.png);background-size: cover;width: 40px;height: 40px;position: absolute;top: 90px;left: 100px;}#eyeRight{background-image: url(images/eye.png);background-size: cover;width: 40px;height: 40px;position: absolute;top: 90px;left: 190px;}#glass{background-image: url(images/glass.png);background-size: cover;width: 300px;height: 300px;position: absolute;}/style
/head
bodydiv idboxdiv idface/divdiv ideyeLeft/divdiv ideyeRight/divdiv idglass/divdiv idlog/div/div
script
use strict;/*
* author: 王乐平
* blog: http://blog.csdn.net/lecepin
* date:2017.7.17
*/var eyeLeftPosition {start: [70, 78],end: [100, 110]
};var eyeRightPosition {start: [150, 78],end: [190, 110]
};var eyeLeftCenterPosition {x: (eyeLeftPosition.end[0] - eyeLeftPosition.start[0]) / 2 eyeLeftPosition.start[0],y: (eyeLeftPosition.end[1] - eyeLeftPosition.start[1]) / 2 eyeLeftPosition.start[1]
};var eyeRightCenterPosition {x: (eyeRightPosition.end[0] - eyeRightPosition.start[0]) / 2 eyeRightPosition.start[0],y: (eyeRightPosition.end[1] - eyeRightPosition.start[1]) / 2 eyeRightPosition.start[1]
};var r 20;var eyeLeft document.querySelector(#eyeLeft);
var eyeRight document.querySelector(#eyeRight);if (window.DeviceOrientationEvent) {window.addEventListener(deviceorientation, function (event) {let {alpha, beta, gamma} event;eyeLeft.style.left eyeLeftCenterPosition.x gamma / 90 * r px;eyeRight.style.left eyeRightCenterPosition.x gamma / 90 * r px;eyeLeft.style.top eyeRight.style.top eyeLeftCenterPosition.y beta / 180 * r px;eyeRight.style.transform eyeLeft.style.transform eyeRight.style.WebkitTransform eyeLeft.style.WebkitTransform rotate( beta deg);}, false);
} else {document.querySelector(body).innerHTML 浏览器不支持DeviceOrientationEvent;
}
/script
/body
/html
最终效果 博客名称王乐平博客
CSDN博客地址http://blog.csdn.net/lecepin
更多专业前端知识请上
【猿2048】www.mk2048.com