成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

你可能不了解的動(dòng)畫神器之requestAnimationFrame及其兼容寫法

shengguo / 1243人閱讀

摘要:就是為動(dòng)畫而生的,用于改變樣式或。例如同時(shí)進(jìn)行的如下任務(wù)基于的動(dòng)畫動(dòng)畫。而且,當(dāng)正在執(zhí)行動(dòng)畫的標(biāo)簽頁(yè)不可見時(shí),瀏覽器并不會(huì)一直運(yùn)行它,這就意味著更少的和內(nèi)存的使用,從而延長(zhǎng)電池壽命。我同時(shí)也修正了方法名稱內(nèi)核的瀏覽器已更改過(guò)。

介紹

此篇文章翻譯自paul_irish( 就職于Google Chrome團(tuán)隊(duì)工程師)

文中提到對(duì)requestAnimationFrame的polyfill非常不錯(cuò),可以直接拿來(lái)用

原文鏈接:requestAnimationFrame for Smart Animating

什么是requestAnimationFrame?

你可能用過(guò)定時(shí)器實(shí)現(xiàn)動(dòng)畫(通過(guò)每隔一段時(shí)間去改變?cè)兀?。瀏覽器給我們帶來(lái)了個(gè)好消息“為什么不提供一個(gè)API給開發(fā)者,來(lái)使一些事情更高效呢”。requestAnimationFrame就是為動(dòng)畫而生的API,用于改變dom樣式、canvas或WebGL。

我為什么要使用它?

瀏覽器能夠?qū)⒉l(fā)動(dòng)畫優(yōu)化為單個(gè)事件流和重繪周期中,從而更流暢。例如同時(shí)進(jìn)行的如下任務(wù):基于js的動(dòng)畫、css動(dòng)畫、SVG SMIL。而且,當(dāng)正在執(zhí)行動(dòng)畫的標(biāo)簽頁(yè)不可見時(shí),瀏覽器并不會(huì)一直運(yùn)行它,這就意味著更少的CPU、 GPU和內(nèi)存的使用,從而延長(zhǎng)電池壽命。

天啦嚕,我可以吹噓自己的網(wǎng)站對(duì)電池更友好?

是的大兄弟Totes McGoats(此人跟作者是啥關(guān)系~)

我應(yīng)該如何使用它?

下面這段是一個(gè)簡(jiǎn)單的requestAnimationFrame兼容寫法,當(dāng)瀏覽器不支持時(shí)回退到setTimeout的實(shí)現(xiàn)方式:

// shim layer with setTimeout fallback
window.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.
更加健壯的polyfill

以下代碼是Opera工程師Erik M?ller所寫更加健壯的polyfill。你可以閱讀下,尤其是在處理4-16ms的延遲時(shí)間這段代碼,從而使幀率更接近60fps。你會(huì)喜歡上它的,請(qǐng)注意他使用的標(biāo)準(zhǔn)方法名。我同時(shí)也修正了cancel方法名稱(WebKit內(nèi)核的瀏覽器已更改過(guò))。

(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);
        };
}());
來(lái)看看它的效果

http://jsfiddle.net/XQpzU/435...

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

該回調(diào)函數(shù)將當(dāng)前時(shí)間作為參數(shù)傳遞,也正是你說(shuō)需要的。

(此文寫于2011年,下面介紹了不同瀏覽器實(shí)現(xiàn)上的差異)
Is it ready?
Right now, the Webkit implementation (available in Nightly Safari and Chrome Dev Channel) and the Mozilla one (available in FF4) differ slightly. Mozilla’s has a bug which caps potential framerates at about 30fps.Actually, “It’s currently capped at 1000/(16 + N) fps, where N is the number of ms it takes your callback to execute. If your callback takes 1000ms to execute, then it’s capped at under 1fps. If your callback takes 1ms to execute, you get about 60fps.” (thx, Boris) It’ll be fixed though, probably for the next release after FF4 ships. Also Chrome 10 doesn’t have the time parameter (added in m11), FF currently ignores the element argument.

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/51903.html

相關(guān)文章

  • 可能了解動(dòng)畫神器requestAnimationFrame及其兼容寫法

    摘要:就是為動(dòng)畫而生的,用于改變樣式或。例如同時(shí)進(jìn)行的如下任務(wù)基于的動(dòng)畫動(dòng)畫。而且,當(dāng)正在執(zhí)行動(dòng)畫的標(biāo)簽頁(yè)不可見時(shí),瀏覽器并不會(huì)一直運(yùn)行它,這就意味著更少的和內(nèi)存的使用,從而延長(zhǎng)電池壽命。我同時(shí)也修正了方法名稱內(nèi)核的瀏覽器已更改過(guò)。 介紹 此篇文章翻譯自paul_irish( 就職于Google Chrome團(tuán)隊(duì)工程師) 文中提到對(duì)requestAnimationFrame的polyfil...

    MAX_zuo 評(píng)論0 收藏0
  • 可能了解動(dòng)畫神器requestAnimationFrame及其兼容寫法

    摘要:就是為動(dòng)畫而生的,用于改變樣式或。例如同時(shí)進(jìn)行的如下任務(wù)基于的動(dòng)畫動(dòng)畫。而且,當(dāng)正在執(zhí)行動(dòng)畫的標(biāo)簽頁(yè)不可見時(shí),瀏覽器并不會(huì)一直運(yùn)行它,這就意味著更少的和內(nèi)存的使用,從而延長(zhǎng)電池壽命。我同時(shí)也修正了方法名稱內(nèi)核的瀏覽器已更改過(guò)。 介紹 此篇文章翻譯自paul_irish( 就職于Google Chrome團(tuán)隊(duì)工程師) 文中提到對(duì)requestAnimationFrame的polyfil...

    keke 評(píng)論0 收藏0
  • 可能了解動(dòng)畫神器requestAnimationFrame及其兼容寫法

    摘要:就是為動(dòng)畫而生的,用于改變樣式或。例如同時(shí)進(jìn)行的如下任務(wù)基于的動(dòng)畫動(dòng)畫。而且,當(dāng)正在執(zhí)行動(dòng)畫的標(biāo)簽頁(yè)不可見時(shí),瀏覽器并不會(huì)一直運(yùn)行它,這就意味著更少的和內(nèi)存的使用,從而延長(zhǎng)電池壽命。我同時(shí)也修正了方法名稱內(nèi)核的瀏覽器已更改過(guò)。 介紹 此篇文章翻譯自paul_irish( 就職于Google Chrome團(tuán)隊(duì)工程師) 文中提到對(duì)requestAnimationFrame的polyfil...

    taohonghui 評(píng)論0 收藏0
  • 可能了解動(dòng)畫神器requestAnimationFrame及其兼容寫法

    摘要:就是為動(dòng)畫而生的,用于改變樣式或。例如同時(shí)進(jìn)行的如下任務(wù)基于的動(dòng)畫動(dòng)畫。而且,當(dāng)正在執(zhí)行動(dòng)畫的標(biāo)簽頁(yè)不可見時(shí),瀏覽器并不會(huì)一直運(yùn)行它,這就意味著更少的和內(nèi)存的使用,從而延長(zhǎng)電池壽命。我同時(shí)也修正了方法名稱內(nèi)核的瀏覽器已更改過(guò)。 介紹 此篇文章翻譯自paul_irish( 就職于Google Chrome團(tuán)隊(duì)工程師) 文中提到對(duì)requestAnimationFrame的polyfil...

    xiangzhihong 評(píng)論0 收藏0
  • 可能了解動(dòng)畫神器requestAnimationFrame及其兼容寫法

    摘要:就是為動(dòng)畫而生的,用于改變樣式或。例如同時(shí)進(jìn)行的如下任務(wù)基于的動(dòng)畫動(dòng)畫。而且,當(dāng)正在執(zhí)行動(dòng)畫的標(biāo)簽頁(yè)不可見時(shí),瀏覽器并不會(huì)一直運(yùn)行它,這就意味著更少的和內(nèi)存的使用,從而延長(zhǎng)電池壽命。我同時(shí)也修正了方法名稱內(nèi)核的瀏覽器已更改過(guò)。 介紹 此篇文章翻譯自paul_irish( 就職于Google Chrome團(tuán)隊(duì)工程師) 文中提到對(duì)requestAnimationFrame的polyfil...

    haoguo 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<