iOS界面卡頓之離屏渲染

? ?導(dǎo)讀:

離屏渲染在開發(fā)中帶來(lái)界面卡頓問題一直讓開發(fā)者們頭疼.今天在這里寫一遍關(guān)于離屏渲染的博文.希望大家有所收獲

現(xiàn)在的iOS開發(fā)越來(lái)越注重App性能和用戶體驗(yàn)了.

性能優(yōu)化和內(nèi)存管理是iOS面試中必問的兩道面試題.也是編程中最難的部分之一

要想知道如何解決界面卡頓問題,那你必須對(duì)離屏渲染有所了解

要想成為一個(gè)高級(jí)iOS程序員,你必須學(xué)會(huì)如何性能優(yōu)化,內(nèi)存優(yōu)化

讀懂了這篇文章,掌握離屏渲染的原理,讓你的App從此遠(yuǎn)離卡頓.


OpenGL中,GPU屏幕渲染有以下兩種方式:

一.On-Screen Rendering

? ? ? 意為當(dāng)前屏幕渲染,指的是GPU的渲染操作是在當(dāng)前用于顯示的屏幕緩沖區(qū)中進(jìn)行橙喘。

當(dāng)前屏幕渲染是不需要額外創(chuàng)建新的緩存.也不需要開啟新的上下文.相較與離屏渲染,性能更好.

? ? ? 但是受當(dāng)前屏幕渲染的局限因素限制(只有自身上下文,屏幕緩存有限等),很對(duì)圖形渲染,當(dāng)前屏幕渲染是解決不了的.這時(shí)必須使用到離屏渲染.如何正確的使用離屏渲染,下面會(huì)為你詳細(xì)描述

二.Off-Screen Rendering

? ? ? 意為離屏渲染彩扔,指的是GPU在當(dāng)前屏幕緩沖區(qū)以外新開辟一個(gè)緩沖區(qū)進(jìn)行渲染操作煮仇。

特殊的“離屏渲染”:CPU渲染

? ? ? 如果我們重 寫了drawRect方法岖食,并且使用任何Core Graphics的技術(shù)進(jìn)行了繪制操作啸胧,就涉及到了CPU渲染铛绰。整個(gè)渲染過程由CPU在App內(nèi)同步地完成诈茧,渲染得到的bitmap(位圖)最后再交由GPU用于 顯示。

普通的離屏渲染

相比于當(dāng)前屏幕渲染捂掰,離屏渲染的代價(jià)是很高的敢会,主要體現(xiàn)在兩個(gè)方面:

1.創(chuàng)建新緩沖區(qū)

要想進(jìn)行離屏渲染,首先要?jiǎng)?chuàng)建一個(gè)新的緩沖區(qū)这嚣。

2.上下文切換

離屏渲染的整個(gè)過程鸥昏,需要多次切換上下文環(huán)境:先是從當(dāng)前屏幕(On-Screen)切換到離屏(Off-Screen);等到離屏渲染結(jié)束以后姐帚,將離屏緩沖區(qū)的渲染結(jié)果顯示到屏幕上有需要將上下文環(huán)境從離屏切換到當(dāng)前屏幕吏垮。而上下文環(huán)境的切換是要付出很大代價(jià)的。

設(shè)置了以下屬性時(shí)罐旗,都會(huì)觸發(fā)離屏繪制:

1.shouldRasterize(光柵化)

2.masks(遮罩)

3.shadows(陰影)

4.edge antialiasing(抗鋸齒)

5.group opacity(不透明)

需要注意的是膳汪,如果shouldRasterize被設(shè)置成YES,在觸發(fā)離屏繪制的同時(shí)九秀,會(huì)將光柵化后的內(nèi)容緩存起來(lái)旅敷,如果對(duì)應(yīng)的layer及其sublayers沒有發(fā)生改變,在下一幀的時(shí)候可以直接復(fù)用颤霎。這將在很大程度上提升渲染性能媳谁。

而其它屬性如果是開啟的,就不會(huì)有緩存友酱,離屏繪制會(huì)在每一幀都發(fā)生晴音。

在開發(fā)時(shí)需要根據(jù)實(shí)際情況來(lái)選擇最優(yōu)的實(shí)現(xiàn)方式,盡量使用On-Screen Rendering缔杉。簡(jiǎn)單的Off-Screen Rendering可以考慮使用Core Graphics讓CPU來(lái)渲染锤躁。


如何抉擇

現(xiàn)在擺在我們面前得有三個(gè)選擇:當(dāng)前屏幕渲染、離屏渲染或详、CPU渲染系羞,該用哪個(gè)呢郭计?這需要根據(jù)具體的使用場(chǎng)景來(lái)決定。

盡量使用當(dāng)前屏幕渲染

鑒于離屏渲染椒振、CPU渲染可能帶來(lái)的性能問題昭伸,一般情況下,我們要盡量使用當(dāng)前屏幕渲染澎迎。

離屏渲染 VS CPU渲染

由于GPU的浮點(diǎn)運(yùn)算能力比CPU強(qiáng)庐杨,CPU渲染的效率可能不如離屏渲染;但如果僅僅是實(shí)現(xiàn)一個(gè)簡(jiǎn)單的效果夹供,直接使用CPU渲染的效率又可能比離屏渲染好,畢竟普通的離屏渲染要涉及到緩沖區(qū)創(chuàng)建和上下文切換等耗時(shí)操作灵份。普通的離屏繪制是發(fā)生在繪制服務(wù)(是獨(dú)立的處理過程)并且同時(shí)通過GPU執(zhí)行。當(dāng)OpengGL的繪制程序在繪制每個(gè)layer的時(shí)候哮洽,有可能因?yàn)榘嘧訉蛹?jí)關(guān)系而必須停下來(lái)把他們合成到一個(gè)單獨(dú)的緩存里填渠。你可能認(rèn)為GPU應(yīng)該總是比CPU牛逼一點(diǎn),但是在這里我們還是需要慎重的考慮一下鸟辅。因?yàn)閷?duì)GPU來(lái)說揭蜒,從當(dāng)前屏幕(on-screen)到離屏(off-screen)上下文環(huán)境的來(lái)回切換,代價(jià)是非常大的剔桨。因此對(duì)一些簡(jiǎn)單的繪制過程來(lái)說,這個(gè)過程有可能用CoreGraphics徙融,全部用CPU來(lái)完成反而會(huì)比GPU做得更好洒缀。所以如果你正在嘗試處理一些復(fù)雜的層級(jí),并且在猶豫到底用-[CALayer?setShouldRasterize:]?還是通過CoreGraphics來(lái)繪制層級(jí)上的所有內(nèi)容欺冀,唯一的方法就是測(cè)試并且進(jìn)行權(quán)衡树绩。

總之,具體的選擇應(yīng)該由性能測(cè)試結(jié)果來(lái)決定隐轩。

簡(jiǎn)而言之:

如果覺得前面的過于抽象,沒看懂,不要緊,把下面的看懂就能正確的解決離屏渲染帶來(lái)的界面卡頓的問題了

1.盡量使用當(dāng)前屏幕渲染,能不使用離屏渲染則盡量不用,你應(yīng)當(dāng)盡量避免使用 layer 的 border饺饭、corner、shadow职车、mask 等技術(shù).

2.必須離屏渲染時(shí),相對(duì)簡(jiǎn)單的視圖應(yīng)該使用cpu渲染,相對(duì)復(fù)雜的視圖則使用一般的離屏渲染.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末瘫俊,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子悴灵,更是在濱河造成了極大的恐慌扛芽,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件积瞒,死亡現(xiàn)場(chǎng)離奇詭異川尖,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)茫孔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門叮喳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)被芳,“玉大人,你說我怎么就攤上這事馍悟∨媳簦” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵赋朦,是天一觀的道長(zhǎng)篓冲。 經(jīng)常有香客問我,道長(zhǎng)宠哄,這世上最難降的妖魔是什么壹将? 我笑而不...
    開封第一講書人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮毛嫉,結(jié)果婚禮上诽俯,老公的妹妹穿的比我還像新娘。我一直安慰自己承粤,他們只是感情好暴区,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著辛臊,像睡著了一般仙粱。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上彻舰,一...
    開封第一講書人閱讀 49,185評(píng)論 1 284
  • 那天伐割,我揣著相機(jī)與錄音,去河邊找鬼刃唤。 笑死隔心,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的尚胞。 我是一名探鬼主播硬霍,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼笼裳!你這毒婦竟也來(lái)了唯卖?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤躬柬,失蹤者是張志新(化名)和其女友劉穎耐床,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體楔脯,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡撩轰,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片堪嫂。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡偎箫,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出皆串,到底是詐尸還是另有隱情淹办,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布恶复,位于F島的核電站怜森,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏谤牡。R本人自食惡果不足惜副硅,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望翅萤。 院中可真熱鬧恐疲,春花似錦、人聲如沸套么。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)胚泌。三九已至省咨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間玷室,已是汗流浹背零蓉。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留阵苇,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓感论,卻偏偏與公主長(zhǎng)得像绅项,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子比肄,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容

  • 相比于當(dāng)前屏幕渲染快耿,離屏渲染的代價(jià)是很高的,這也是iOS移動(dòng)端優(yōu)化的必要部分芳绩。 OpenGL中掀亥,GPU屏幕渲染有以...
    一個(gè)人在路上走下去閱讀 8,839評(píng)論 0 74
  • Core Animation工具用來(lái)監(jiān)測(cè)Core Animation性能。它給我們提供了周期性的FPS妥色,并且考慮到...
    F麥子閱讀 819評(píng)論 0 1
  • 在進(jìn)行iOS的應(yīng)用開發(fā)過程中搪花,有時(shí)候會(huì)出現(xiàn)卡頓的問題,雖然iOS設(shè)備的性能越來(lái)越高,但是卡頓的問題還是有可能會(huì)出現(xiàn)...
    飛魚灣閱讀 4,349評(píng)論 0 24
  • 這一系列的文章會(huì)從幾個(gè)方面對(duì) ASDK 在性能調(diào)優(yōu)方面策略的實(shí)現(xiàn)進(jìn)行分析撮竿,幫助讀者理解 ASDK 如何做到使復(fù)雜的...
    Draveness閱讀 7,612評(píng)論 8 110
  • array_sum() 迭代計(jì)算數(shù)組鍵值的總和返回計(jì)算的結(jié)果幢踏,不影響原有鍵值髓需; 基礎(chǔ)語(yǔ)法:number array...
    彭曉華閱讀 268評(píng)論 0 0