淺談利用緩存來優(yōu)化HTML5 Canvas程序的性能_第1頁
已閱讀5頁,還剩3頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、淺談利用緩存來優(yōu)化html5 canvas程序的性能canvas玩多了后,就會(huì)自動(dòng)的要開頭考慮性能問題了。怎么優(yōu)化canvas的動(dòng)畫呢?【用法緩存】用法緩存也就是用離屏canvas舉行預(yù)渲染了,原理很容易,就是先繪制到一個(gè)離屏canvas中,然后再通過drawimage把離屏canvas畫到主canvas中。可能看到這無數(shù)人就會(huì)誤會(huì),這不是寫嬉戲里面用的無數(shù)的雙緩沖機(jī)制么?其實(shí)不然,雙緩沖機(jī)制是嬉戲編程中為了防止畫面閃耀,因此會(huì)有一個(gè)顯示在用戶面前的畫布以及一個(gè)后臺(tái)畫布,舉行繪制時(shí)會(huì)先將畫面內(nèi)容繪制到后臺(tái)畫布中,再將后臺(tái)畫布里的數(shù)據(jù)繪制到前臺(tái)畫布中。這就是雙緩沖,但是canvas中是沒有雙緩沖

2、的,由于現(xiàn)代掃瞄器基本上都是內(nèi)置了雙緩沖機(jī)制。所以,用法離屏canvas并不是雙緩沖,而是把離屏canvas當(dāng)成一個(gè)緩存區(qū)。把需要重復(fù)繪制的畫面數(shù)據(jù)舉行緩存起來,削減調(diào)用canvas的api的消耗。盡人皆知,調(diào)用canvas的api很消耗性能,所以,當(dāng)我們要繪制一些重復(fù)的畫面數(shù)據(jù)時(shí),妥當(dāng)利用離屏canvas對(duì)性能方面有很大的提升,可以看下下面的demo1 、 沒用法緩存2、 用法了緩存但是沒有設(shè)置離屏canvas的寬高 3 、 用法了緩存但是沒有設(shè)置離屏canvas的寬高 4 、 用法了緩存且設(shè)置了離屏canvas的寬高可以看到上面的demo的性能不一樣,下面分析一下緣由:為了實(shí)現(xiàn)每個(gè)圈的樣式

3、,所以繪制圈圈時(shí)我用了循環(huán)繪制,假如沒用啟用緩存,當(dāng)頁面的圈圈數(shù)量達(dá)到一定時(shí),動(dòng)畫每一幀就要大量調(diào)用canvas的api,要舉行大量的計(jì)算,這樣再好的掃瞄器也會(huì)被拖垮啦。xml/html code復(fù)制內(nèi)容到剪貼板ctx.save(); var j=0; ctx.linewidth = borderwidth; for(var i=1;i body padding:0; margin:0; overflow: hidden; cas display: block; background-color:rgba(0,0,0,0); margin:auto; border:1px solid; 測試

4、掃瞄器不支持canvas 1000個(gè)圈圈對(duì)象也不卡 var testbox = function() var canvas = document.getelementbyid("cas"), ctx = canvas.getcontext(&39;2d&39;), borderwidth = 2, balls = ; var ball = function(x , y , vx , vy , usecache) this.x = x; this.y = y; this.vx = vx; this.vy = vy; this.r = getz(getrandom(20,40)

5、; this.color = ; this.cachecanvas = document.createelement("canvas"); thisthis.cachectx = this.cachecanvas.getcontext("2d"); this.cachecanvas.width = 2*this.r; this.cachecanvas.height = 2*this.r; var num = getz(this.r/borderwidth); for(var j=0;j(canvas.width-this.r)|this.x(canvas

6、.height-this.r)|this.y 離屏canvas還有一個(gè)注重事項(xiàng),假如你做的效果是會(huì)將對(duì)象不停地創(chuàng)建和銷毀,請(qǐng)慎重用法離屏canvas,起碼不要像我上面寫的那樣給每個(gè)對(duì)象的屬性綁定離屏canvas。由于假如這樣綁定,當(dāng)對(duì)象被銷毀時(shí),離屏canvas也會(huì)被銷毀,而大量的離屏canvas不停地被創(chuàng)建和銷毀,會(huì)導(dǎo)致canvas buffer耗費(fèi)大量gpu資源,簡單造成掃瞄器崩潰或者嚴(yán)峻卡幀現(xiàn)象。解決方法就是弄一個(gè)離屏canvas數(shù)組,預(yù)先裝進(jìn)足夠數(shù)量的離屏canvas,僅將仍然存活的對(duì)象緩存起來,當(dāng)對(duì)象被銷毀時(shí),再解除緩存。這樣就不會(huì)導(dǎo)致離屏canvas被銷毀了。 【用法request

7、animationframe】這個(gè)就不詳細(xì)說明了,估量無數(shù)人都知道,這個(gè)才是做動(dòng)畫的最佳循環(huán),而不是settimeout或者setinterval。挺直貼出兼容性寫法:xml/html code復(fù)制內(nèi)容到剪貼板window.raf = (function() return window.requestanimationframe | window.webkitrequestanimationframe | window.mozrequestanimationframe | window.orequestanimationframe | window.msrequestanimationfram

8、e | function (callback) window.settimeout(callback, 1000 / 60); ; )(); 【避開浮點(diǎn)運(yùn)算】雖然javascript提供了很便利的一些取整辦法,像math.floor,math.ceil,parseint,但是,國外友人做過測試,parseint這個(gè)辦法做了一些額外的工作(比如檢測數(shù)據(jù)是不是有效的數(shù)值,parseint 甚至先將參數(shù)轉(zhuǎn)換成了字符串!),所以,挺直用parseint的話相對(duì)來說比較消耗性能,那怎樣取整呢,可以挺直用老外寫的很巧妙的辦法了:javascript code復(fù)制內(nèi)容到剪貼板1.rounded = (0.5

9、 + somenum) | 0;2.rounded = (0.5 + somenum); 3.rounded = (0.5 + somenum) 0; 運(yùn)算符不懂的可以挺直戳: 里面有具體說明【盡量削減canvasapi的調(diào)用】作粒子效果時(shí),盡量少用法圓,最好用法方形,由于粒子太小,所以方形看上去也跟圓差不多。至于緣由,很簡單理解,我們畫一個(gè)圓需要三個(gè)步驟:先beginpath,然后用arc畫弧,再用fill舉行填充才干產(chǎn)生一個(gè)圓。但是畫方形,只需要一個(gè)fillrect就可以了。雖然只是差了兩個(gè)調(diào)用,當(dāng)粒子對(duì)象數(shù)量達(dá)到一定時(shí),這性能差距就會(huì)顯示出來了。還有一些其他注重事項(xiàng),我就不一一列舉了,由于谷歌上一搜也挺多的。我這也算是一個(gè)給自己做下記錄,主要是記錄緩存的使用。想要提升canvas的性能最主要的還是得注重代碼的結(jié)構(gòu),削減不須要的ap

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論