IOS 性能優(yōu)化中離屏渲染
GPU屏幕渲染有以下兩種方式:
On-Screen Rendering
意為當前屏幕渲染,指的是GPU的渲染操作是在當前用于顯示的屏幕緩沖區(qū)中進行。
Off-Screen Rendering
意為離屏渲染,指的是GPU在當前屏幕緩沖區(qū)以外新開辟一個緩沖區(qū)進行渲染操作。
特殊的離屏渲染:
如果將不在GPU的當前屏幕緩沖區(qū)中進行的渲染都稱為離屏渲染,那么就還有另一種特殊的“離屏渲染”方式: CPU渲染。
如果我們重寫了drawRect方法,并且使用任何Core Graphics的技術進行了繪制操作,就涉及到了CPU渲染。整個渲染過程由CPU在App內(nèi) 同步地
完成,渲染得到的bitmap最后再交由GPU用于顯示。(CPU渲染—>GPU顯示)
什么時候會喚起離屏渲染:
當使用圓角,陰影,遮罩的時候,圖層屬性的混合體被指定為在未預合成之前不能直接在屏幕中繪制,所以就需要屏幕外渲染被喚起。
為什么離屏渲染會造成性能消耗:
屏幕外渲染并不意味著軟件繪制,但是它意味著圖層必須在被顯示之前在一個屏幕外上下文中被渲染(不論CPU還是GPU)。
所以當使用離屏渲染的時候會很容易造成性能消耗,因為在OPENGL里離屏渲染會單獨在內(nèi)存中創(chuàng)建一個屏幕外緩沖區(qū)并進行渲染,而屏幕外緩沖區(qū)跟當前屏幕緩沖區(qū)上下文切換是很耗性能的。
使用Instruments來監(jiān)測離屏渲染
Instruments的Core Animation工具中有幾個和離屏渲染相關的檢查選項:
Color Offscreen-Rendered Yellow
開啟后會把那些需要離屏渲染的圖層高亮成黃色,這就意味著黃色圖層可能存在性能問題。
Color Hits Green and Misses Red
如果shouldRasterize被設置成YES,對應的渲染結(jié)果會被緩存,如果圖層是綠色,就表示這些緩存被復用;如果是紅色就表示緩存會被重復創(chuàng)建,這就表示該處存在性能問題了。
iOS版本上的優(yōu)化
iOS 9.0 之前UIimageView跟UIButton設置圓角都會觸發(fā)離屏渲染。
iOS 9.0 之后UIButton設置圓角會觸發(fā)離屏渲染,而UIImageView里png圖片設置圓角不會觸發(fā)離屏渲染了,如果設置其他陰影效果之類的還是會觸發(fā)離屏渲染的。
這可能是蘋果也意識到離屏渲染會產(chǎn)生性能問題,所以能不產(chǎn)生離屏渲染的地方蘋果也就不用離屏渲染了。
通過此文,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
iOS App開發(fā)中使用設計模式中的單例模式的實例解析
單例模式是最簡單和基本的一種設計模式,下面我們就簡單解讀一下iOS中單例設計模式的用法,示例代碼還是為傳統(tǒng)的Objective-C,主要為了體現(xiàn)單例模式的思想,需要的朋友可以參考下2016-05-05IOS中使用UIWebView 加載網(wǎng)頁、文件、 html的方法
UIWebView 是用來加載加載網(wǎng)頁數(shù)據(jù)的一個框,接下來通過本文給大家介紹IOS中使用UIWebView 加載網(wǎng)頁、文件、 html的方法,對本文詳情感興趣的朋友一起學習吧2016-02-02iOS開發(fā)tips-UINavigationBar的切換效果
這篇文章主要為大家詳細介紹了iOS開發(fā)tips-UINavigationBar的切換效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11iOS開發(fā)中#import、#include和@class的區(qū)別解析
這篇文章主要介紹了iOS開發(fā)中#import、#include和@class的區(qū)別解析,非常不錯,具有參考借鑒價值,感興趣的朋友一起學習吧2016-08-08