requestAnimationFrame 疑问

2022-06-09 10:35:23 +08:00
 Kasumi20

已经有一个组件使用了 requestAnimationFrame ,正在以 60HZ 的频率绘制一个动画,现在另外一个组件又要使用 requestAnimationFrame 绘制动画,那它们的频率都会降低为 30HZ ,怎么让两个组件的频率都是 60HZ ?

1348 次点击
所在节点    JavaScript
6 条回复
thinkershare
2022-06-09 12:19:32 +08:00
并不会降为 30HZ, 不知道你怎么得到这个结论的!
Kasumi20
2022-06-09 14:01:15 +08:00
@thinkershare 为什么不会,一个全局的函数,它怎么知道是两个组件在调用
loolac
2022-06-09 15:10:33 +08:00
无需知道多少组件调用它,最终渲染时只需要知道调用后的如何影响渲染结果就可以。 `requestAnimationFrame`参数是回调函数,它只会在渲染时被执行。 每一帧被渲染前,你调用 n 次 `requestAnimationFrame`注册了 n 个回调函数, 那么这些函数在下一帧渲染时都会被执行。
thinkershare
2022-06-09 15:14:11 +08:00
@Kasumi20 你自己写个测试函数试一下不就知道了
peterczg
2022-06-09 17:54:48 +08:00
requestAnimationFrame 是浏览器异步宏任务的 API ,调用后只是注册回调队列,等屏幕刷新的时候会执行,是否掉帧执行,取决于回调函数的执行时间和当前 CPU 的负载状态,当浏览器没有在 1/60 s (一般的显示器是 60HZ )内执行完,就会阻塞下一次刷新的执行。

https://stackoverflow.com/questions/62911574/does-requestanimationframe-can-be-stuck-by-long-javascript
Al0rid4l
2022-06-10 09:22:55 +08:00
你搞错了 rAF 的机制, rAF 只是帮你把函数注册, 插入到每一帧渲染的间隔时间里执行, 只要你的任务执行时间不超过 1/60s, 那你多次调用 rAF 注册一百个函数也没问题, 只要这 100 个函数总执行时间不超过 1/60s, 那他们就依然都是 60Hz

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/858348

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX