麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > HTML > 正文

HTML5探秘:用requestAnimationFrame優(yōu)化Web動畫

2024-08-26 00:20:44
字體:
供稿:網(wǎng)友

requestAnimationFrame是什么?

在瀏覽器動畫程序中,我們通常使用一個定時器來循環(huán)每隔幾毫秒移動目標(biāo)物體一次,來讓它動起來。如今有一個好消息,瀏覽器開發(fā)商們決定:“嗨,為什么我們不在瀏覽器里提供這樣一個API呢,這樣一來我們可以為用戶優(yōu)化他們的動畫。”所以,這個requestAnimationFrame()函數(shù)就是針對動畫效果的API,你可以把它用在DOM上的風(fēng)格變化或畫布動畫或WebGL中。

使用requestAnimationFrame有什么好處?

瀏覽器可以優(yōu)化并行的動畫動作,更合理的重新排列動作序列,并把能夠合并的動作放在一個渲染周期內(nèi)完成,從而呈現(xiàn)出更流暢的動畫效果。比如,通過requestAnimationFrame(),JS動畫能夠和CSS動畫/變換或SVG SMIL動畫同步發(fā)生。另外,如果在一個瀏覽器標(biāo)簽頁里運(yùn)行一個動畫,當(dāng)這個標(biāo)簽頁不可見時,瀏覽器會暫停它,這會減少CPU,內(nèi)存的壓力,節(jié)省電池電量。

requestAnimationFrame的用法

// shim layer with setTimeout fallbackwindow.requestAnimFrame = (function(){  return  window.requestAnimationFrame       ||          window.webkitRequestAnimationFrame ||          window.mozRequestAnimationFrame    ||          function( callback ){            window.setTimeout(callback, 1000 / 60);          };})();// usage:// instead of setInterval(render, 16) ....(function animloop(){  requestAnimFrame(animloop);  render();})();// place the rAF *before* the render() to assure as close to// 60fps with the setTimeout fallback.

對requestAnimationFrame更牢靠的封裝

Opera瀏覽器的技術(shù)師Erik Möller 把這個函數(shù)進(jìn)行了封裝,使得它能更好的兼容各種瀏覽器。你可以讀一讀這篇文章,但基本上他的代碼就是判斷使用4ms還是16ms的延遲,來最佳匹配60fps。下面就是這段代碼,你可以使用它,但請注意,這段代碼里使用的是標(biāo)準(zhǔn)函數(shù),我給它加上了兼容各種瀏覽器引擎前綴。

(function() {    var lastTime = 0;    var vendors = ['webkit', 'moz'];    for(var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) {        window.requestAnimationFrame = window[vendors[x]+'RequestAnimationFrame'];        window.cancelAnimationFrame =          window[vendors[x]+'CancelAnimationFrame'] || window[vendors[x]+'CancelRequestAnimationFrame'];    }    if (!window.requestAnimationFrame)        window.requestAnimationFrame = function(callback, element) {            var currTime = new Date().getTime();            var timeToCall = Math.max(0, 16 - (currTime - lastTime));            var id = window.setTimeout(function() { callback(currTime + timeToCall); },              timeToCall);            lastTime = currTime + timeToCall;            return id;        };    if (!window.cancelAnimationFrame)        window.cancelAnimationFrame = function(id) {            clearTimeout(id);        };}());

我來看看使用requestAnimationFrame的效果

 requestAnimationFrame API

window.requestAnimationFrame(function(/* time */ time){  // time ~= +new Date // the unix time});

 回調(diào)函數(shù)里的參數(shù)可以傳入時間。

各種瀏覽器對requestAnimationFrame的支持情況
谷歌瀏覽器,火狐瀏覽器,IE10+都實(shí)現(xiàn)了這個函數(shù),即使你的瀏覽器很古老,上面的對requestAnimationFrame封裝也能讓這個方法在IE8/9上不出錯。


注:相關(guān)教程知識閱讀請移步到HTML教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 99精品电影 | 久久精品性视频 | 欧美视频国产精品 | 依人在线视频 | 在线中文字幕网站 | 婷婷中文字幕一区二区三区 | 欧美性生视频 | 欧洲黄色一级视频 | 国产精品午夜未成人免费观看 | 亚洲国产精品一 | 亚洲视频综合网 | 国产亚洲精品久久777777 | 日本免费不卡一区二区 | av视在线| av视屏| 精品中文字幕在线观看 | 国产一区二区三区在线视频 | 毛片免费在线观看视频 | 久久精品小短片 | 国产精品99一区二区 | 久久久久.com| 一级成人在线 | 精品二区在线观看 | 日韩激情 | 欧美日韩一区,二区,三区,久久精品 | 欧美 亚洲 激情 | 日本在线视频一区二区三区 | 亚洲性生活视频 | 精品中文一区 | 91精品国产日韩91久久久久久360 | 黄色特级片黄色特级片 | 99国产精品欲a| 国产成人小视频在线观看 | 国产精品视频1区 | 久久色伦理资源站 | 福利在线国产 | 日本高清无遮挡 | 一级α片免费看 | 99re色| 中文字幕精品在线观看 | 免费网站看v片在线a |