HTML5实现眼睛移动效果的示例

这篇文章主要介绍了基于html5陀螺仪实现ofo首页眼睛移动效果的示例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

最近用ofo小黄车App的时候,发现以前下方扫一扫变成了一个眼睛动的小黄人,觉得蛮有意思的,这里用HTML5仿一下效果。

ofo眼睛效果

HTML5实现眼睛移动效果的示例

效果分析

从效果中不难看出,是使用陀螺仪事件实现的。

立即学习“前端免费学习笔记(深入)”;

这里先来看一下HTML5中陀螺仪事件的一些概念。

陀螺仪事件为deviceorientation,这里主要获取事件中的alpha,beta,gamma。

aplha

行动装置水平放置时,绕 Z 轴旋转的角度,数值为 0 度到 360 度。

HTML5实现眼睛移动效果的示例

beta

行动装置水平放置时,绕 X 轴旋转的角度,数值为 -180 度到 180 度。

HTML5实现眼睛移动效果的示例

gamma

行动装置水平放置时,绕 Z 轴旋转的角度,数值为 -90 度到 90 度。

HTML5实现眼睛移动效果的示例

这里,只需要用到beta和gamma。

将apk解压,得到眼睛素材:

HTML5实现眼睛移动效果的示例

代码实现

nbsp;html>      Document      #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;    }    

    

    

    

    

    

  'use strict';/** author: 王乐平* 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';}

登录后复制

最终效果

 

HTML5实现眼睛移动效果的示例

以上就是HTML5实现眼睛移动效果的示例的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2909936.html

(0)
上一篇 2025年3月11日 04:27:18
下一篇 2025年2月23日 06:14:37

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • html5碎片式图片切换制作方法详解

    本篇文章主要介绍了html5教你做炫酷的碎片式图片切换 (canvas) ,具有一定参考价值,有兴趣的可以了解一下 前言 老规矩,先上源码。图片区域是可以点击的,动画会从点击的位置开始发生。 本来这个效果是我3年前做的,只是当是是用无数个 …

    2025年3月11日 编程技术
    200
  • HTML5制作贪吃蛇游戏

    本篇文章主要介绍了h5 canvas实现贪吃蛇小游戏,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 本文介绍了H5 canvas实现贪吃蛇小游戏,分享给大家,具体如下: 实现效果如下 实现思路: ps:这个只是…

    2025年3月11日
    200
  • HTML5加载时的等待动画效果制作

    这篇文章通过实例代码给大家介绍了html5等待加载动画效果的完美解决方案,感兴趣的朋友参考下吧 废话不多说了,直接给大家贴代码了,具体代码如下所示:      100 登录后复制   *{margin:0;padding:0;}    .l…

    2025年3月11日
    200
  • HTML5 IndexedDB本地储存

    indexeddb 是一种低级api,用于客户端存储大量结构化数据(包括, 文件/ blobs)。下面通过本文重点给大家介绍html5本地存储之indexeddb的相关知识,感兴趣的朋友一起看看吧 IndexedDB 是一种低级API,用于…

    编程技术 2025年3月11日
    200
  • HTML5通过api实现拖放排序的实例教程

    html5 中提供了直接拖放的 api,极大的方便我们实现拖放效果,不需要去写一大堆的 js,只需要通过监听元素的拖放事件就能实现各种拖放功能。 前言 html5 中提供了直接拖放的 api,极大的方便我们实现拖放效果,不需要去写一大堆的 …

    编程技术 2025年3月11日
    200
  • 解决在HTML5中的video标签无法播放视频的方法

    这篇文章主要给大家介绍了关于解决html5中video标签无法播放mp4问题的办法,文中介绍的非常详细,相信会对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。 前言 最近发现了一个问题,在手机录制了一个1.mp4文…

    2025年3月11日
    200
  • Html5新增标签总结

    这篇文章给大家整理了html5新增的九个标签,非常不错,需要的朋友参考下 今天新学习了9个标签、 简单的说就是一个音频标签,他的主要常用属性有src=””音频的路径 controls=”controls&…

    编程技术 2025年3月11日
    200
  • HTML5讲解之拖拽事件dragstart、drag和dragend

    [导读] 拖拽事件  通过拖拽事件,咱们就可以控制拖拽很多东西了。其中什么元素或者是哪里发生了拖拽事件是最关键的。有些事件是在被拖动的元素上触发,有些事件是在放置目标上触发的。拖动某元素时候,触发的事件有: 拖拽事件     通过拖拽事件,…

    2025年3月11日
    200
  • HTML5实现移动端自适应的几种方法介绍

    这篇文章主要介绍了html5 移动页面自适应手机屏幕四类方法总结,非常具有实用价值,需要的朋友可以参考下 1、使用meta标签:viewport H5移动端页面自适应普遍使用的方法,理论上讲使用这个标签是可以适应所有尺寸的屏幕的,但是各设备…

    2025年3月11日
    200
  • HTML5使用四种方法实现移动页面自适应手机屏幕的方法总结

    这篇文章主要介绍了html5 移动页面自适应手机屏幕四类方法总结,非常具有实用价值,需要的朋友可以参考下 1、使用meta标签:viewport H5移动端页面自适应普遍使用的方法,理论上讲使用这个标签是可以适应所有尺寸的屏幕的,但是各设备…

    2025年3月11日
    200

发表回复

登录后才能评论