《iOS Core Animation》讀書筆記

CALayer

UIView = 繪制 + 響應觸摸事件

  • 負責屏幕和顯示信姓,不負責觸摸事件響應鏈
  • UIView是其高級封裝
  • 和UIView層級一一對應

UIView未暴露CALayer的接口

  • 陰影,圓角蚁孔,帶顏色的邊框
  • 3D變換
  • 非矩形范圍
  • 透明遮罩
  • 多級非線性動畫

圖形和幾何

frame:外部坐標苟鸯,父圖層坐標,大小為邊與xy軸平行能完全容納圖層的最小矩形

bounds:內(nèi)部坐標,自身坐標纪隙,大小為圖層大小的矩形

anchorPoint:錨點,旋轉(zhuǎn)基點扛或,左上角{0绵咱,0},右下角{1熙兔,1}

center(CALayer的position):anchorPoint在父圖層的坐標

視覺效果

拉伸過濾

以正確比例和1:1像素顯示圖片在屏幕上的好處

  • 畫質(zhì)好悲伶,像素無壓縮拉伸
  • 更好使用內(nèi)存
  • 性能好,無需額外計算

CAShapeLayer

矢量圖像而不是bitmap繪制圖層子類

優(yōu)點:

  • 渲染快速住涉,硬件加速
  • 高效使用內(nèi)存麸锉,占用小
  • 不受邊界裁剪,可在邊界外繪制
  • 不會出現(xiàn)像素化

CATextLayer

CALayer的子類舆声,幾乎擁有UILabel所有繪制特性

渲染快于UILabel花沉,運用Core text

性能調(diào)優(yōu)

動畫和圖層被單獨的渲染服務進程處理

動畫發(fā)生過程
  1. 布局
  2. 顯示
  3. 準備-發(fā)送動畫數(shù)據(jù)到渲染服務
  4. 提交-打包圖層和動畫屬性發(fā)送到渲染服務
  5. 對所有圖層屬性計算中間值柳爽,設置OpenGL幾何形狀(紋理化三角形)進行渲染
  6. 在屏幕上渲染可見三角形(GPU執(zhí)行,前面都在CPU)
可能影響GPU繪制的情況
  • 過多幾何結(jié)構(gòu)
  • 重繪-重疊半透明圖層
  • 離屏渲染-為屏幕外渲染的圖片分配額外內(nèi)存碱屁,切換屏幕內(nèi)外的繪制上下文
  • 過大的圖片
可能影響CPU計算的情況
  • 布局計算-自動布局
  • 視圖懶加載-涉及IO的圖片顯示
  • Core Graphics繪制-drawRect(為支持圖層任意繪制需要在內(nèi)存中創(chuàng)建一個等大小的寄宿圖)
  • 解壓圖片
圖像IO
  • 線程加載-合適的后臺線程
  • 分辨率交換-移動時低分辨率磷脯,靜態(tài)時加載高分辨率
  • 緩存-考慮因素:合適緩存鍵、緩存時機娩脾、失效赵誓、回收
  • 圖像格式
文本

盡可能避免改變文本的frame,因為需要重繪

光柵化

將圖層及其所有效果繪制成一個屏幕外的圖像并緩存柿赊,避免運用在內(nèi)容不斷變動的圖層上

離屏渲染

在混合復雜效果無法直接渲染時俩功,會通過分步渲染,會把分布渲染的結(jié)果臨時儲存在屏幕外的內(nèi)存中等待組合渲染

影響性能在于

  • 為臨時儲存部分渲染結(jié)果分配內(nèi)存
  • 進行將渲染結(jié)果從屏幕內(nèi)-外的上下文切換

圖層的屬性觸發(fā)離屏渲染

  • 圓角+maskToBounds
  • 圖層蒙版
  • 陰影
圖層混合
  • 設定固定不透明的背景顏色
  • 設置layer的opaue屬性默認為YES(非view的)
顏色格式

蘋果的GPU只解析32bit的顏色格式闹瞧,其余的格式CPU會先進行顏色格式轉(zhuǎn)換绑雄,再讓GPU渲染。

圖像大小縮放

image和imageView的大小盡量保持一致奥邮,避免在改變view大小時重復計算縮放

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末万牺,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子洽腺,更是在濱河造成了極大的恐慌脚粟,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蘸朋,死亡現(xiàn)場離奇詭異核无,居然都是意外死亡,警方通過查閱死者的電腦和手機藕坯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進店門团南,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人炼彪,你說我怎么就攤上這事吐根。” “怎么了辐马?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵拷橘,是天一觀的道長。 經(jīng)常有香客問我喜爷,道長冗疮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任檩帐,我火速辦了婚禮术幔,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘轿塔。我一直安慰自己特愿,他們只是感情好仲墨,可當我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布勾缭。 她就那樣靜靜地躺著揍障,像睡著了一般。 火紅的嫁衣襯著肌膚如雪俩由。 梳的紋絲不亂的頭發(fā)上毒嫡,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天,我揣著相機與錄音幻梯,去河邊找鬼兜畸。 笑死,一個胖子當著我的面吹牛碘梢,可吹牛的內(nèi)容都是我干的咬摇。 我是一名探鬼主播,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼煞躬,長吁一口氣:“原來是場噩夢啊……” “哼肛鹏!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起恩沛,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤在扰,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后雷客,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體芒珠,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年搅裙,在試婚紗的時候發(fā)現(xiàn)自己被綠了皱卓。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡部逮,死狀恐怖娜汁,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情甥啄,我是刑警寧澤存炮,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站蜈漓,受9級特大地震影響穆桂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜融虽,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一享完、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧有额,春花似錦般又、人聲如沸彼绷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽寄悯。三九已至,卻和暖如春堕义,著一層夾襖步出監(jiān)牢的瞬間猜旬,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工倦卖, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留洒擦,地道東北人。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓怕膛,卻偏偏與公主長得像熟嫩,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子褐捻,可洞房花燭夜當晚...
    茶點故事閱讀 45,037評論 2 355

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