javascript - 一个关于圆(角度)的JS动画问题
高洛峰
高洛峰 2017-04-10 17:25:55
[JavaScript讨论组]

现在我通过重力感应API 的得到 longitude,将手机平放在桌面时,将其进行旋转,其值是0增加到360。当到达360时,再转就会突变成0.

由于我是通过得到前后两次的旋转角度的差值,进行过渡动画。 可当到达360在转到0时, 前后两者的差值就会发生突变,造成过渡动画突变(旋转一周后再回到正常的位置)。

我的过渡动画是通过 transform: rotateY() 进行过渡的,因此有什么方法可以解决这种突变呢(即让360与0之间的转换平顺)?

// 我的过渡方法:
①第一次进入页面时,记录当前的 longitude值为 initLon
②手机旋转时,获取longitude值为 curLon,然后 disLon = curLon - initLon 得到差值,然后进行过渡运算。因此360与0之间的突变会导致动画过渡问题

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(3)
PHP中文网
function calcDisLon(initLon, curLon) {
  return (curLon + 360 + 180 - initLon) % 360 - 180; // [-180, 180)
}

console.log(calcDisLon(359, 1)); // 2
console.log(calcDisLon(1, 359)); // -2

假设每次执行动画的间隔足够短,不会出现角度值实际变化量的绝对值大于等于 180° 的情况

那么我们以 180° 为分界线,增量大于 180° 则认为其实际值为负,因而减去 360°

否则返回原先的值

怪我咯

使用JQ控制CSS3过渡

PHPz

动画的思路就是每一秒钟控制图案重绘60次,实现动画

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号