久久亚洲精品成人_国产精品欧美综合亚洲_亚洲va天堂va欧美ⅴa在线_91色视频在线观看_久久影院亚洲_一级黄色片播放_日韩av在线一区_精品一区二区在线看_老头吃奶性行交视频_日韩免费高清视频_天天操天天爽天天干_日本欧美在线视频

首頁 > 系統 > iOS > 正文

iOS中圖片的解壓縮到渲染過程詳解

2019-10-21 18:21:58
字體:
來源:轉載
供稿:網友

前言

在移動app開發過程中,圖片往往是不可或缺的資源。從磁盤上加載一張圖片,到顯示到屏幕上,中間經過了一些復雜的過程,其中非常重要的一步就是對圖片的解壓縮。下面來一起看看詳細的介紹吧

一.圖像從文件到屏幕過程

iOS,圖片,解壓縮,渲染

通常計算機在顯示是CPU與GPU協同合作完成一次渲染.接下來我們了解一下CPU/GPU等在這樣一次渲染過程中,具體的分工是什么?

  • CPU: 計算視圖frame,圖片解碼,需要繪制紋理圖片通過數據總線交給GPU
  • GPU: 紋理混合,頂點變換與計算,像素點的填充計算,渲染到幀緩沖區。
  • 時鐘信號:垂直同步信號V-Sync / 水平同步信號H-Sync。
  • iOS設備雙緩沖機制:顯示系統通常會引入兩個幀緩沖區,雙緩沖機制

圖片顯示到屏幕上是CPU與GPU的協作完成

對應應用來說,圖片是最占用手機內存的資源,將一張圖片從磁盤中加載出來,并最終顯示到屏幕上,中間其實經過了一系列復雜的處理過程。

二.圖片加載的工作流程

1、假設我們使用 +imageWithContentsOfFile: 方法從磁盤中加載一張圖片,這個時候的圖片并沒有解壓縮;

2、然后將生成的 UIImage 賦值給 UIImageView ;

3、接著一個隱式的 CATransaction 捕獲到了 UIImageView 圖層樹的變化;

4、在主線程的下一個 runloop 到來時,Core Animation 提交了這個隱式的 transaction ,這個過程可能會對圖片進行 copy 操作,而受圖片是否字節對齊等因素的影響,這個 copy 操作可能會涉及以下部分或全部步驟:

  • 分配內存緩沖區用于管理文件 IO 和解壓縮操作;
  • 將文件數據從磁盤讀到內存中;
  • 將壓縮的圖片數據解碼成未壓縮的位圖形式,這是一個非常耗時的 CPU 操作;
  • 最后 Core Animation 中CALayer使用未壓縮的位圖數據渲染 UIImageView 的圖層。
  • CPU計算好圖片的Frame,對圖片解壓之后.就會交給GPU來做圖片渲染

5、渲染流程

  • GPU獲取獲取圖片的坐標
  • 將坐標交給頂點著色器(頂點計算)
  • 將圖片光柵化(獲取圖片對應屏幕上的像素點)
  • 片元著色器計算(計算每個像素點的最終顯示的顏色值)
  • 從幀緩存區中渲染到屏幕上

我們提到了圖片的解壓縮是一個非常耗時的 CPU 操作,并且它默認是在主線程中執行的。那么當需要加載的圖片比較多時,就會對我們應用的響應性造成嚴重的影響,尤其是在快速滑動的列表上,這個問題會表現得更加突出。

三.為什么要解壓縮圖片

既然圖片的解壓縮需要消耗大量的 CPU 時間,那么我們為什么還要對圖片進行解壓縮呢?是否可以不經過解壓縮,而直接將圖片顯示到屏幕上呢?答案是否定的。要想弄明白這個問題,我們首先需要知道什么是位圖

其實,位圖就是一個像素數組,數組中的每個像素就代表著圖片中的一個點。我們在應用中經常用到的 JPEG 和 PNG 圖片就是位圖

大家可以嘗試

UIImage *image = [UIImage imageNamed:@"text.png"];CFDataRef rawData = CGDataProviderCopyData(CGImageGetDataProvider(image.CGImage));

打印rawData,這里就是圖片的原始數據.

事實上,不管是 JPEG 還是 PNG 圖片,都是一種壓縮的位圖圖形格式。只不過 PNG 圖片是無損壓縮,并且支持 alpha 通道,而 JPEG 圖片則是有損壓縮,可以指定 0-100% 的壓縮比。值得一提的是,在蘋果的 SDK 中專門提供了兩個函數用來生成 PNG 和 JPEG 圖片:

// return image as PNG. May return nil if image has no CGImageRef or invalid bitmap formatUIKIT_EXTERN NSData * __nullable UIImagePNGRepresentation(UIImage * __nonnull image);// return image as JPEG. May return nil if image has no CGImageRef or invalid bitmap format. compression is 0(most)..1(least)       UIKIT_EXTERN NSData * __nullable UIImageJPEGRepresentation(UIImage * __nonnull image, CGFloat compressionQuality);

因此,在將磁盤中的圖片渲染到屏幕之前,必須先要得到圖片的原始像素數據,才能執行后續的繪制操作,這就是為什么需要對圖片解壓縮的原因。

四.解壓縮原理

既然圖片的解壓縮不可避免,而我們也不想讓它在主線程執行,影響我們應用的響應性,那么是否有比較好的解決方案呢?

我們前面已經提到了,當未解壓縮的圖片將要渲染到屏幕時,系統會在主線程對圖片進行解壓縮,而如果圖片已經解壓縮了,系統就不會再對圖片進行解壓縮。因此,也就有了業內的解決方案,在子線程提前對圖片進行強制解壓縮。

而強制解壓縮的原理就是對圖片進行重新繪制,得到一張新的解壓縮后的位圖。其中,用到的最核心的函數是 CGBitmapContextCreate :  

CG_EXTERN CGContextRef __nullable CGBitmapContextCreate(void * __nullable data, size_t width, size_t height, size_t bitsPerComponent, size_t bytesPerRow, CGColorSpaceRef cg_nullable space, uint32_t bitmapInfo) CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_2_0);
  • data :如果不為 NULL ,那么它應該指向一塊大小至少為 bytesPerRow * height 字節的內存;如果 為 NULL ,那么系統就會為我們自動分配和釋放所需的內存,所以一般指定 NULL 即可;
  • width 和height :位圖的寬度和高度,分別賦值為圖片的像素寬度和像素高度即可;
  • bitsPerComponent :像素的每個顏色分量使用的 bit 數,在 RGB 顏色空間下指定 8 即可;
  • bytesPerRow :位圖的每一行使用的字節數,大小至少為 width * bytes per pixel 字節。當我們指定 0/NULL 時,系統不僅會為我們自動計算,而且還會進行 cache line alignment 的優化
  • space :就是我們前面提到的顏色空間,一般使用 RGB 即可;
  • bitmapInfo :位圖的布局信息.kCGImageAlphaPremultipliedFirst

五.YYImage/SDWebImage開源框架實現

用于解壓縮圖片的函數 YYCGImageCreateDecodedCopy 存在于 YYImageCoder 類中,核心代碼如下

CGImageRef YYCGImageCreateDecodedCopy(CGImageRef imageRef, BOOL decodeForDisplay) { ... if (decodeForDisplay) { // decode with redraw (may lose some precision)  CGImageAlphaInfo alphaInfo = CGImageGetAlphaInfo(imageRef) & kCGBitmapAlphaInfoMask;  BOOL hasAlpha = NO;  if (alphaInfo == kCGImageAlphaPremultipliedLast ||   alphaInfo == kCGImageAlphaPremultipliedFirst ||   alphaInfo == kCGImageAlphaLast ||   alphaInfo == kCGImageAlphaFirst) {   hasAlpha = YES;  }  // BGRA8888 (premultiplied) or BGRX8888  // same as UIGraphicsBeginImageContext() and -[UIView drawRect:]  CGBitmapInfo bitmapInfo = kCGBitmapByteOrder32Host;  bitmapInfo |= hasAlpha ? kCGImageAlphaPremultipliedFirst : kCGImageAlphaNoneSkipFirst;  CGContextRef context = CGBitmapContextCreate(NULL, width, height, 8, 0, YYCGColorSpaceGetDeviceRGB(), bitmapInfo);  if (!context) return NULL;  CGContextDrawImage(context, CGRectMake(0, 0, width, height), imageRef); // decode  CGImageRef newImage = CGBitmapContextCreateImage(context);  CFRelease(context);  return newImage; } else {  ... }}

它接受一個原始的位圖參數 imageRef ,最終返回一個新的解壓縮后的位圖 newImage ,中間主要經過了以下三個步驟:

  • 使用 CGBitmapContextCreate 函數創建一個位圖上下文;
  • 使用 CGContextDrawImage 函數將原始位圖繪制到上下文中;
  • 使用 CGBitmapContextCreateImage 函數創建一張新的解壓縮后的位圖。

事實上,SDWebImage 中對圖片的解壓縮過程與上述完全一致,只是傳遞給 CGBitmapContextCreate 函數的部分參數存在細微的差別

性能對比:

  • 在解壓PNG圖片,SDWebImage>YYImage
  • 在解壓JPEG圖片,SDWebImage<YYImage

總結

1、圖片文件只有在確認要顯示時,CPU才會對齊進行解壓縮.因為解壓是非常消耗性能的事情.解壓過的圖片就不會重復解壓,會緩存起來.

2、圖片渲染到屏幕的過程: 讀取文件->計算Frame->圖片解碼->解碼后紋理圖片位圖數據通過數據總線交給GPU->GPU獲取圖片Frame->頂點變換計算->光柵化->根據紋理坐標獲取每個像素點的顏色值(如果出現透明值需要將每個像素點的顏色*透明度值)->渲染到幀緩存區->渲染到屏幕

3、面試中如果能按照這個邏輯闡述,應該沒有大的問題.不過,如果細問到離屏渲染和渲染中的細節處理.就需要掌握OpenGL ES/Metal 這個2個圖形處理API. 面試過程可能會遇到不在自己技術能力范圍問題,盡量知之為知之不知為不知.

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
日本欧美中文字幕| 日韩精品电影在线| 性一交一乱一伧国产女士spa| 欧美一区二区影院| 亚洲天堂免费在线| 6080午夜不卡| 亚洲国产精品自拍| 国产午夜久久久久| 国产+成+人+亚洲欧洲自线| 亚洲xxx在线| 波多野结衣人妻| 国产中文字幕久久| 51调教丨国产调教视频| 亚洲综合在线网站| 男人的天堂狠狠干| 亚洲亚洲精品三区日韩精品在线视频| 99在线观看| 国产精品美女www| 性欧美视频videos6一9| 久久精品国产一区二区三区 | 国产一区二区动漫| 精品91自产拍在线观看一区| 在线观看av不卡| 夜夜嗨av一区二区三区中文字幕 | 一级黄色片视频| 国产无遮挡又黄又爽在线观看| 精品国产sm最大网站免费看 | 六月激情综合网| 中文有码久久| 伊人狠狠色丁香综合尤物| 精品毛片久久久久久| 91在线视频精品| 国产免费成人av| 国产成人在线播放| 欧美在线性视频| 青青草成人在线| 欧美最猛性xxxx| 欧美有码在线视频| 欧美在线www| 欧美亚洲第一区| 日韩av电影在线播放| 国内精品久久久久久影视8| 久久精品99久久久久久久久| 美女av一区二区三区| 久久影视电视剧免费网站清宫辞电视| 日韩中文字幕在线视频| 正在播放欧美视频| 欧美极品美女视频网站在线观看免费 | 亚洲精品综合精品自拍| 亚洲乱码国产乱码精品精| 亚洲片国产一区一级在线观看| 亚洲视频电影图片偷拍一区| 久久影视电视剧免费网站清宫辞电视| 97国产在线视频| 国产欧美在线观看| 九色一区二区| 大地资源网在线观看免费官网| 久久精品xxx| 色国产在线视频| 亚洲欧美日本一区| 日本熟妇毛耸耸xxxxxx| 国产一区二区在线视频观看| 久久精品成人| 337p粉嫩大胆色噜噜噜噜亚洲| 中文字幕中文字幕在线一区| 午夜成人免费电影| 欧美精品一区二区三区高清aⅴ| 精品国产一区二区三区久久狼5月| 久久久久久久爱| 99re在线播放| 日本福利视频网站| 少妇性l交大片7724com| 中文字幕资源站| 一本色道久久综合无码人妻| 蜜桃视频一区二区三区在线观看| 91啪九色porn原创视频在线观看| 亚洲国产精品久久不卡毛片| 日韩视频在线永久播放| 色综合久久88| 国内视频一区| 欧美激情国产精品日韩| 免费在线观看a视频| 一起草av在线| 风间由美一区二区三区在线观看| 亚洲一级片在线观看| 日韩av中文在线| 国产有码在线一区二区视频| 蜜臀av.com| 伊人网综合视频| www..com国产| 国产在线精品一区二区| 亚洲国产成人av| 亚洲日韩第一页| 91夜夜未满十八勿入爽爽影院| 日本a级片在线观看| 日b视频在线观看| 国产精品高潮呻吟av| 97se亚洲国产综合自在线观| 欧美区一区二区三区| 欧美高清电影在线看| 欧美一进一出视频| 日本道中文字幕| 一级做a爱片性色毛片| 粉嫩av一区二区三区粉嫩| 一本到三区不卡视频| 久久久精品一区二区三区| 麻豆精品传媒视频| 日本免费福利视频| 亚洲第一视频在线| 亚洲精品美国一| 日韩一级裸体免费视频| 日韩aⅴ视频一区二区三区| 人妻少妇偷人精品久久久任期| 久久久成人免费视频| a在线播放不卡| 欧美xingq一区二区| 成人网中文字幕| 黄色三级视频片| 日韩精品一区二区亚洲av观看| 成人国产精品免费网站| 精品国产伦理网| www.久久草| 婷婷五月精品中文字幕| 久久精品日韩欧美| 欧美色视频在线观看| 国产噜噜噜噜噜久久久久久久久 | 欧美一区二区视频在线播放| 中文字幕在线观看二区| 精品一区二区免费在线观看| 91精品啪在线观看国产60岁| 成人亲热视频网站| 五月天丁香社区| 天堂成人国产精品一区| 欧美日韩免费视频| 亚洲综合日韩在线| 国产一卡二卡三卡四卡| 蜜桃91丨九色丨蝌蚪91桃色| 欧美高清dvd| 国产伦精品一区二区三区免| 中文字幕在线看高清电影| 另类专区欧美蜜桃臀第一页| 精品美女一区二区| 亚洲高清资源综合久久精品| 放荡的美妇在线播放| 久久综合九色综合欧美98| 色悠悠久久久久| 欧美这里只有精品| 一区二区的视频| 欧美中文字幕亚洲一区二区va在线| 国产综合在线观看视频| 伊人网在线视频观看| www.av亚洲| 欧美高清在线视频观看不卡| 欧美成人乱码一二三四区免费| 性一交一乱一乱一视频| 欧美男同性恋视频网站| 日本免费一区二区三区| 日韩黄色三级视频| 亚洲高清视频的网址| 91情侣偷在线精品国产| 纪美影视在线观看电视版使用方法| av男人天堂一区| 97色在线视频| 日韩精品卡通动漫网站| 日本成人午夜影院| 国产成人av电影在线播放| 最近更新的2019中文字幕 | 国产欧美日韩在线| 日本精品久久中文字幕佐佐木| 少妇丰满尤物大尺度写真| 丁香啪啪综合成人亚洲小说 | 欧美sm美女调教| 亚洲欧美99| 一区不卡在线观看| 日韩免费性生活视频播放| 国产性生活免费视频| 99久久婷婷国产一区二区三区| 欧美日本一道本在线视频| 在线视频亚洲自拍| 乱子伦一区二区三区| 这里是久久伊人| 黄色污污在线观看| 深爱五月激情五月| 精品国产依人香蕉在线精品| 女教师高潮黄又色视频| 久久久噜噜噜久久中文字幕色伊伊 | 日韩久久一区二区| 俄罗斯精品一区二区三区| 亚洲影院在线播放| 日韩色视频在线观看| 国产日韩成人内射视频| 国产一区二区三区久久久| 97人人爽人人喊人人模波多 | 亚洲色图第一页| 中文字幕日韩久久| 久久久综合九色合综国产精品| 国产欧美一区二区三区在线看 | 色婷婷国产精品免| 欧美日韩一区二区三区| 干日本少妇视频| 日本欧美久久久久免费播放网| 欧美国产一区二区三区| 四虎影院中文字幕| 欧美日韩中文字幕精品| 无码少妇一区二区三区芒果| 久久久久久一级片| 免费看国产精品一二区视频| 天天摸夜夜添狠狠添婷婷| 久久综合九色九九| 久久中文免费视频| 日韩精品一区二区三区老鸭窝 | 亚洲人精品午夜在线观看| 99精品视频免费版的特色功能| 国产精品美女一区二区| 人偷久久久久久久偷女厕| 日日夜夜精品视频免费| 国产精品成人一区二区| 免费精品一区二区| 一区二区三区国产视频| 亚洲一区视频在线播放| 7777精品伊人久久久大香线蕉完整版 | 亚洲午夜激情免费视频| 好吊一区二区三区视频| 在线亚洲欧美专区二区| 亚洲自拍第三页| 色偷偷88欧美精品久久久| 免费看国产黄色片| 亚洲综合免费观看高清完整版 | 国产精品三区www17con| 少妇高潮一区二区三区99小说| 青青草原成人在线视频| 无码人妻av一区二区三区波多野| 久久精品久久久久电影| 欧美黄色免费观看| 伊人伊成久久人综合网站 | 精品视频在线播放免| 自拍偷拍亚洲天堂| 欧美少妇一区二区| 国模无码视频一区| 欧美本精品男人aⅴ天堂| av黄色在线免费观看| 精品日产卡一卡二卡麻豆| 手机看片福利视频| 亚洲国产精品热久久| 中文字幕人妻一区二| 亚洲免费电影在线观看| 久久久美女视频| 欧美精品在线极品| 国产精品主播一区二区| 日本欧美一级片| 美女网站久久| 欧美日韩在线播放一区二区| 99久久久精品| 高清在线观看免费| 午夜视频久久久久久| 99国产精品免费视频| 欧美乱妇15p| 人与动物性xxxx| 深夜精品寂寞黄网站在线观看| 五月婷婷六月婷婷| 成人观看高清在线观看免费| 日韩和的一区二区| 视频一区二区在线| 亚洲日本电影在线| 亚洲成人av免费观看| 精品久久人人做人人爽| 可以在线观看av的网站| 欧美一区二三区| 麻豆精品蜜桃视频网站| 四虎4hu永久免费入口| 狠狠躁夜夜躁人人爽天天天天97| 欧美xxxx×黑人性爽| 一个色综合导航| 国产又粗又长又黄| 精品卡一卡二| 中文字幕中文乱码欧美一区二区| 亚洲在线观看网站| 亚洲欧美国产视频| 国产一区二区波多野结衣| dy888夜精品国产专区| 国产精品电影院| 搡老熟女老女人一区二区| 日韩天堂在线视频| 美女尤物久久精品| 中文字幕色呦呦| 欧美色男人天堂| 狠狠躁夜夜躁人人爽天天高潮| 国产一区深夜福利| 久久精品一区八戒影视| 日本黄色大片在线观看| 最新国产精品亚洲| 视频一区视频二区中文| 亚洲熟女乱色一区二区三区| 亚洲成人黄色在线| 亚洲精品视频91| 成人在线观看毛片| 日韩欧美电影一二三| 91国内精品视频| 亚洲免费久久| 欧美一区日韩一区| 亚洲无码久久久久| 伊人久久大香线蕉成人综合网| 欧美日韩一级片在线观看| 国产视频1区2区| 日韩.欧美.亚洲| 欧美日韩久久久| 国产又黄又粗又长| 日韩视频在线观看视频| 日韩色在线观看| 可以免费看毛片的网站| 日韩小视频在线播放| 国产亚洲美女精品久久久| 日韩专区欧美专区| 亚洲成人福利在线| 久久久久久久一区二区| 97精品久久久午夜一区二区三区| 男男做爰猛烈叫床爽爽小说 | 国产专区欧美精品| 久久精品一卡二卡| 欧美一级大片在线观看| 国产精品人妖ts系列视频| 国产盗摄一区二区三区在线| 国产v亚洲v天堂无码| 黄色成人在线播放| 91av国产精品| 日本999视频| 97色在线观看| 亚洲欧洲日本在线| 国产一级av毛片| 亚洲午夜精品一区二区三区| 精品国产免费视频| 狠狠色丁香久久婷婷综合丁香| 少妇伦子伦精品无吗| 午夜精品久久久久久99热软件| 中文字幕亚洲区| 免费在线不卡视频| 精品国产一区二区三区无码| 中文字幕日韩av综合精品| youjizz久久| 国产高潮流白浆| 欧美一区二区视频在线| 日韩国产中文字幕| 99精品国产热久久91蜜凸| 日韩av毛片在线观看| 日韩妆和欧美的一区二区| 亚洲国产欧美精品| 99久久精品国产毛片| 国产成人精品亚洲男人的天堂| 综合视频免费看| 久久精品电影网| 日韩码欧中文字| 国产孕妇孕交大片孕| 亚洲欧美另类动漫| 国产精品福利在线观看| 91国模大尺度私拍在线视频| 视频精品一区二区| 夫妇露脸对白88av| 黄色网络在线观看| 九九热这里只有在线精品视| 一二三区精品视频| 天天干天天插天天操| 美女脱光内衣内裤| 久久久国产精华液999999| 久久69精品久久久久久国产越南| 夜夜爽夜夜爽精品视频| 天堂av资源在线| 亚洲精品国产精品国自产网站| 亚洲成色www久久网站| 久久91亚洲人成电影网站| 精品毛片网大全| 国内精品不卡在线| 日韩av片在线播放| 九九精品久久久| 精品国产一区二区三区麻豆免费观看完整版| 精品国产免费视频| 国产精品青草久久| 亚洲精品国产一区二| 亚洲av熟女国产一区二区性色 | 国产美女91呻吟求| 91精品一区二区三区在线观看| 99re视频精品| 国产精品一二三四五区| 色婷婷免费视频| 中文字幕中文字幕99| 97成人精品视频在线观看| 欧美日韩精品免费观看视频| 99久久综合狠狠综合久久| 国产巨乳在线观看| 91ts人妖另类精品系列| 免费欧美一级视频| av一区观看| 欧美国产视频日韩| 日韩视频免费观看高清完整版 | 日本亚洲自拍| 午夜欧美不卡精品aaaaa| 91麻豆精品国产91久久久久久久久| 99久久精品99国产精品| 亚洲黄色在线免费观看| 欧美成人精品一区二区免费看片| 国产福利精品一区二区三区| 日韩精品另类天天更新| 国产精彩精品视频| 国产亚洲欧洲黄色| 欧美性色xo影院| 久久久精品tv| 久久超碰97中文字幕| 国产精品乱码一区二区| 中文字幕在线有码| 亚洲美女精品视频| 哪个网站能看毛片|