亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁(yè) > 系統(tǒng) > iOS > 正文

iOS中圖片的解壓縮到渲染過(guò)程詳解

2019-10-21 18:21:58
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

在移動(dòng)app開(kāi)發(fā)過(guò)程中,圖片往往是不可或缺的資源。從磁盤(pán)上加載一張圖片,到顯示到屏幕上,中間經(jīng)過(guò)了一些復(fù)雜的過(guò)程,其中非常重要的一步就是對(duì)圖片的解壓縮。下面來(lái)一起看看詳細(xì)的介紹吧

一.圖像從文件到屏幕過(guò)程

iOS,圖片,解壓縮,渲染

通常計(jì)算機(jī)在顯示是CPU與GPU協(xié)同合作完成一次渲染.接下來(lái)我們了解一下CPU/GPU等在這樣一次渲染過(guò)程中,具體的分工是什么?

  • CPU: 計(jì)算視圖frame,圖片解碼,需要繪制紋理圖片通過(guò)數(shù)據(jù)總線交給GPU
  • GPU: 紋理混合,頂點(diǎn)變換與計(jì)算,像素點(diǎn)的填充計(jì)算,渲染到幀緩沖區(qū)。
  • 時(shí)鐘信號(hào):垂直同步信號(hào)V-Sync / 水平同步信號(hào)H-Sync。
  • iOS設(shè)備雙緩沖機(jī)制:顯示系統(tǒng)通常會(huì)引入兩個(gè)幀緩沖區(qū),雙緩沖機(jī)制

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

對(duì)應(yīng)應(yīng)用來(lái)說(shuō),圖片是最占用手機(jī)內(nèi)存的資源,將一張圖片從磁盤(pán)中加載出來(lái),并最終顯示到屏幕上,中間其實(shí)經(jīng)過(guò)了一系列復(fù)雜的處理過(guò)程。

二.圖片加載的工作流程

1、假設(shè)我們使用 +imageWithContentsOfFile: 方法從磁盤(pán)中加載一張圖片,這個(gè)時(shí)候的圖片并沒(méi)有解壓縮;

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

3、接著一個(gè)隱式的 CATransaction 捕獲到了 UIImageView 圖層樹(shù)的變化;

4、在主線程的下一個(gè) runloop 到來(lái)時(shí),Core Animation 提交了這個(gè)隱式的 transaction ,這個(gè)過(guò)程可能會(huì)對(duì)圖片進(jìn)行 copy 操作,而受圖片是否字節(jié)對(duì)齊等因素的影響,這個(gè) copy 操作可能會(huì)涉及以下部分或全部步驟:

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

5、渲染流程

  • GPU獲取獲取圖片的坐標(biāo)
  • 將坐標(biāo)交給頂點(diǎn)著色器(頂點(diǎn)計(jì)算)
  • 將圖片光柵化(獲取圖片對(duì)應(yīng)屏幕上的像素點(diǎn))
  • 片元著色器計(jì)算(計(jì)算每個(gè)像素點(diǎn)的最終顯示的顏色值)
  • 從幀緩存區(qū)中渲染到屏幕上

我們提到了圖片的解壓縮是一個(gè)非常耗時(shí)的 CPU 操作,并且它默認(rèn)是在主線程中執(zhí)行的。那么當(dāng)需要加載的圖片比較多時(shí),就會(huì)對(duì)我們應(yīng)用的響應(yīng)性造成嚴(yán)重的影響,尤其是在快速滑動(dòng)的列表上,這個(gè)問(wèn)題會(huì)表現(xiàn)得更加突出。

三.為什么要解壓縮圖片

既然圖片的解壓縮需要消耗大量的 CPU 時(shí)間,那么我們?yōu)槭裁催€要對(duì)圖片進(jìn)行解壓縮呢?是否可以不經(jīng)過(guò)解壓縮,而直接將圖片顯示到屏幕上呢?答案是否定的。要想弄明白這個(gè)問(wèn)題,我們首先需要知道什么是位圖

其實(shí),位圖就是一個(gè)像素?cái)?shù)組,數(shù)組中的每個(gè)像素就代表著圖片中的一個(gè)點(diǎn)。我們?cè)趹?yīng)用中經(jīng)常用到的 JPEG 和 PNG 圖片就是位圖

大家可以嘗試

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

打印rawData,這里就是圖片的原始數(shù)據(jù).

事實(shí)上,不管是 JPEG 還是 PNG 圖片,都是一種壓縮的位圖圖形格式。只不過(guò) PNG 圖片是無(wú)損壓縮,并且支持 alpha 通道,而 JPEG 圖片則是有損壓縮,可以指定 0-100% 的壓縮比。值得一提的是,在蘋(píng)果的 SDK 中專(zhuān)門(mén)提供了兩個(gè)函數(shù)用來(lái)生成 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);

因此,在將磁盤(pán)中的圖片渲染到屏幕之前,必須先要得到圖片的原始像素?cái)?shù)據(jù),才能執(zhí)行后續(xù)的繪制操作,這就是為什么需要對(duì)圖片解壓縮的原因。

四.解壓縮原理

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

我們前面已經(jīng)提到了,當(dāng)未解壓縮的圖片將要渲染到屏幕時(shí),系統(tǒng)會(huì)在主線程對(duì)圖片進(jìn)行解壓縮,而如果圖片已經(jīng)解壓縮了,系統(tǒng)就不會(huì)再對(duì)圖片進(jìn)行解壓縮。因此,也就有了業(yè)內(nèi)的解決方案,在子線程提前對(duì)圖片進(jìn)行強(qiáng)制解壓縮。

而強(qiáng)制解壓縮的原理就是對(duì)圖片進(jìn)行重新繪制,得到一張新的解壓縮后的位圖。其中,用到的最核心的函數(shù)是 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 ,那么它應(yīng)該指向一塊大小至少為 bytesPerRow * height 字節(jié)的內(nèi)存;如果 為 NULL ,那么系統(tǒng)就會(huì)為我們自動(dòng)分配和釋放所需的內(nèi)存,所以一般指定 NULL 即可;
  • width 和height :位圖的寬度和高度,分別賦值為圖片的像素寬度和像素高度即可;
  • bitsPerComponent :像素的每個(gè)顏色分量使用的 bit 數(shù),在 RGB 顏色空間下指定 8 即可;
  • bytesPerRow :位圖的每一行使用的字節(jié)數(shù),大小至少為 width * bytes per pixel 字節(jié)。當(dāng)我們指定 0/NULL 時(shí),系統(tǒng)不僅會(huì)為我們自動(dòng)計(jì)算,而且還會(huì)進(jìn)行 cache line alignment 的優(yōu)化
  • space :就是我們前面提到的顏色空間,一般使用 RGB 即可;
  • bitmapInfo :位圖的布局信息.kCGImageAlphaPremultipliedFirst

五.YYImage/SDWebImage開(kāi)源框架實(shí)現(xiàn)

用于解壓縮圖片的函數(shù) YYCGImageCreateDecodedCopy 存在于 YYImageCoder 類(lèi)中,核心代碼如下

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 {  ... }}

它接受一個(gè)原始的位圖參數(shù) imageRef ,最終返回一個(gè)新的解壓縮后的位圖 newImage ,中間主要經(jīng)過(guò)了以下三個(gè)步驟:

  • 使用 CGBitmapContextCreate 函數(shù)創(chuàng)建一個(gè)位圖上下文;
  • 使用 CGContextDrawImage 函數(shù)將原始位圖繪制到上下文中;
  • 使用 CGBitmapContextCreateImage 函數(shù)創(chuàng)建一張新的解壓縮后的位圖。

事實(shí)上,SDWebImage 中對(duì)圖片的解壓縮過(guò)程與上述完全一致,只是傳遞給 CGBitmapContextCreate 函數(shù)的部分參數(shù)存在細(xì)微的差別

性能對(duì)比:

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

總結(jié)

1、圖片文件只有在確認(rèn)要顯示時(shí),CPU才會(huì)對(duì)齊進(jìn)行解壓縮.因?yàn)榻鈮菏欠浅O男阅艿氖虑?解壓過(guò)的圖片就不會(huì)重復(fù)解壓,會(huì)緩存起來(lái).

2、圖片渲染到屏幕的過(guò)程: 讀取文件->計(jì)算Frame->圖片解碼->解碼后紋理圖片位圖數(shù)據(jù)通過(guò)數(shù)據(jù)總線交給GPU->GPU獲取圖片F(xiàn)rame->頂點(diǎn)變換計(jì)算->光柵化->根據(jù)紋理坐標(biāo)獲取每個(gè)像素點(diǎn)的顏色值(如果出現(xiàn)透明值需要將每個(gè)像素點(diǎn)的顏色*透明度值)->渲染到幀緩存區(qū)->渲染到屏幕

3、面試中如果能按照這個(gè)邏輯闡述,應(yīng)該沒(méi)有大的問(wèn)題.不過(guò),如果細(xì)問(wèn)到離屏渲染和渲染中的細(xì)節(jié)處理.就需要掌握OpenGL ES/Metal 這個(gè)2個(gè)圖形處理API. 面試過(guò)程可能會(huì)遇到不在自己技術(shù)能力范圍問(wèn)題,盡量知之為知之不知為不知.

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)VEVB武林網(wǎng)的支持。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到IOS開(kāi)發(fā)頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
色播在线视频| 国产乱视频在线观看| 日本在线一二三| 很黄很污的网站| 这里只有精品免费| 中文字幕av网站| www.成人在线视频| 在线观看视频你懂的| 亚洲精品wwww| 五月亚洲婷婷| 久久亚洲二区| 色悠悠国产精品| 三级中文字幕在线观看| 国产精品白嫩初高中害羞小美女| 在线观看日韩毛片| 日本中文字幕二区| 欧美精品一二三区| 久久精品一区蜜桃臀影院| 成人欧美一区二区三区在线播放| 妞干网福利视频| 日本午夜精品理论片a级appf发布| 日韩av在线播放资源| 无码黑人精品一区二区| 国产精品白嫩白嫩大学美女| 少妇一级黄色片| 综合伊思人在钱三区| 成人免费看片视频在线观看| 99久久国产综合精品五月天喷水| 国产精品美女高潮无套| 波多野结衣av一区二区全免费观看| 粉嫩av一区二区夜夜嗨| 日韩va亚洲va欧洲va国产| 日韩精品在线中文字幕| 国产性猛交xxxx免费看久久| 国产大片一区| 国产私人尤物无码不卡| 国产盗摄一区二区三区在线| 欧美一区国产二区| 日本精品专区| 婷婷国产在线| 在线观看免费播放网址成人| www国产在线| 国产精品久久久久久久7电影| 欧美日本亚洲韩国国产| 久久综合九色99| 欧美一区二区三区在线播放| 欧美国产一二三区| 中文字幕在线观看1| 欧美久久久久久一卡四| 亚洲一区视频在线播放| 丁香桃色午夜亚洲一区二区三区| 先锋影音在av资源看片| 国产最新精品视频| 国内精品久久久久国产| 老司机久久99久久精品播放免费| 国产成人精品视频免费看| 成人做爰69片免费看网站| 青青国产在线视频| 91jq激情在线观看| 黑丝美女久久久| 亚洲黄色av女优在线观看| 国产91色蝌蚪视频| 亚洲一本二本| 国产福利短视频| 91网站最新网址| 女厕盗摄一区二区三区| 国产一区二区三区免费在线| 欧美大片在线免费观看| 老牛影视av一区二区在线观看| 日韩免费小视频| 老熟妇精品一区二区三区| 国产富婆一级全黄大片| 成人性生生活性生交12| 99re视频| 99精产国品一二三产品香蕉| 人妻91麻豆一区二区三区| 久草福利资源在线| 国产精品高清无码在线观看| 中文字幕成人在线| 女人抽搐喷水高潮国产精品| 久久影院一区二区| 久久一本精品| 国产精品一级在线观看| 久久久久久久久久久久| 91在线视频导航| freehdxxxx护士| 国产免费内射又粗又爽密桃视频| 天堂аⅴ在线最新版在线| 韩国毛片一区二区三区| 欧美乱妇高清无乱码| 99青春婷婷视频| 亚洲一区二区高清视频| 免费在线观看黄视频| 欧美精品1区| 久久电影网电视剧免费观看| 天天爱天天做天天操| 色呦呦中文字幕| 美国一区二区三区在线播放| 影音先锋国产精品| 91国产精品视频在线观看| 欧美日韩视频在线| 2019中文字幕在线视频| 中文字幕人妻一区二区三区| 国产成人免费在线视频| 免费网站看黄yyy222| 一本色道久久88亚洲精品综合| 一区二区三区四区在线免费视频| av不卡免费电影| 久久久91精品国产一区二区三区| 国产一区二区三区的电影| 日本成人在线电影网| 国内精品卡一卡二卡三| 久久久精品国产免大香伊| 亚洲婷婷综合色高清在线| av网址在线免费观看| 国产精品女主播一区二区三区| 欧美午夜精品一区| 网友自拍亚洲| 婷婷激情五月综合| 18欧美乱大交| 欧美一区二区在线播放| 国产一区二区三区免费在线| 奇米影视888狠狠狠| 亚洲一区二区三区美女| 天天操 夜夜操| 精品国产一区二区三区久久久蜜臀| 亚洲三级中文字幕| 春色校园综合激情亚洲| 亚洲天堂网av在线| hitomi一区二区三区精品| 国产极品视频在线观看| 免费欧美一级视频| 精品国产日本| 一区二区在线免费观看| 国产秀色在线www免费观看| 成人a免费在线看| 亚洲色成人www永久在线观看| 丁香花在线观看完整版电影| 在线观看不卡| av在线不卡免费观看| 国产精彩视频在线| 久草视频视频在线播放| 午夜精品一区二区三区视频免费看| 欧美日韩国产激情| 伊人影院在线播放| 在线高清一区| 亚洲欧洲美洲在线综合| 日韩三级电影网站| 美女一区二区久久| 亚洲成人观看| 成人资源www网在线最新版| 992tv成人国产福利在线| 亚洲激情网址| 亚洲综合在线一区二区| 日韩国产一区| 国产综合图区| 亚洲欧美成人一区| 久久久久久国产精品一区| 成人免费视频a| 成人不用播放器| 日韩欧美亚洲一区二区三区| 国产综合精品久久| 国产精品视频网站在线观看| 欧美黄色免费网址| 午夜一级在线看亚洲| 国产综合久久久久久鬼色| 国产精品一区二区久久精品| 久久久久9999亚洲精品| 久久五月天婷婷| 国产一区亚洲二区| 成人一区在线观看| 日韩大片在线播放| 国产乱叫456| 欧美一级黄色录像| 日本精品在线观看视频| 免费看日批视频| 日韩影院二区| 人人超碰在线| 欧美最顶级的aⅴ艳星| 老司机在线视频二区| 福利电影导航| 亚州av影院| 免费黄色地址| 午夜精品在线视频| 99久久99久久精品免费看小说.| 国产成人精品一区二区三区网站观看| 日本免费高清一区| 久久er热在这里只有精品66| 国产伦精品一区二区三区免费优势| 日韩电影免费| 亚洲欧美日韩高清在线| 麻豆视频观看网址久久| 国产一区二区播放| 亚洲va在线va天堂成人| 91久久久久久久久久久久| 国产精品久久久久久久久免费樱桃| 亚洲精品中文字幕在线播放| 91影院在线播放| 欧美丝袜丝交足nylons| 色婷婷久久一区二区| 国产青草视频在线观看| 日本在线免费播放| 久久成人激情视频| 国产一区二区在线视频观看| 日韩免费观看高清完整版在线观看| 色久综合一二码| 欧美午夜精品久久久久久孕妇| 国产午夜在线视频| 一本久道在线| 国产精品成人99一区无码| 国产午夜在线观看| 女囚岛在线观看| 欧美激情国产日韩| 成年网址网站在线观看| 在线看国产视频| 成人情视频高清免费观看电影| 亚洲国产成人高清精品| 欧美三级伦理在线| 91资源在线播放| 三级在线看中文字幕完整版| 特级黄色片视频| 粉嫩精品一区二区三区在线观看| 天天综合色天天综合| 在线天堂www在线国语对白| 国产成人视屏| 欧美日韩不卡在线| 性xxxx丰满孕妇xxxx另类| 欧美性视频精品| 777色狠狠一区二区三区| 亚洲国产精品精华液网站| japanese国产精品| 日韩**中文字幕毛片| 97色婷婷成人综合在线观看| 国产午夜精品视频免费不卡69堂| 欧美熟妇乱码在线一区| 国产又爽又黄的激情精品视频| 亚洲变态欧美另类捆绑| 久久国产精品高清一区二区三区| 再深点灬舒服灬太大了添少妇视频| 爱情岛论坛亚洲品质自拍视频网站| 欧美天堂在线视频| 九色成人国产蝌蚪91| 在线观看小视频| 成人a'v在线播放| 久久久国产精品x99av| 日本熟女一区二区| 极品白嫩少妇无套内谢| 欧美另类z0zxhd电影| 国产日韩一区二区三区在线| 在线一区二区三区| 成人在线播放免费观看| 久久伊人免费视频| 黄色大片网站在线观看| 午夜日韩av| 亚洲aⅴ天堂av在线电影软件| 91高清国产视频| 国产成人av免费看| 中文字幕有码在线播放| 男女私大尺度视频| 91网址在线播放| 99久久婷婷国产综合| 中文字幕久精品免费视频| 777午夜精品电影免费看| 高h视频在线| 欧美暴力调教| 日本在线免费观看视频| 一区二区三区小说| 国产精品丝袜高跟| 老**午夜毛片一区二区三区| 国产美女精品在线观看| 富二代精品短视频| 僵尸世界大战2 在线播放| 欧洲vodafone精品| 日本妇女一区| 国产成人一区二区三区别| 国产一区二区三区免费视频| 成人亚洲一区二区| 偷拍视频一区二区三区| 浅井舞香一区二区| 亚洲高清一区二区三区| 黄色在线视频网站| 黄网站app在线观看| 欧美在线se| 亚洲在线免费| 欧美日韩精品免费观看视一区二区| 欧美影院精品一区| 又粗又大的机巴好爽欧美| 香蕉久久夜色精品国产使用方法| 懂色av蜜桃av| 欧美又粗又大又长| 91九色国产ts另类人妖| 色资源在线观看| 高潮精品一区videoshd| 人人精品久久| 久久中文字幕av一区二区不卡| 一本一道久久a久久| 精品国产一区三区| 欧美日本精品一区二区三区| 青青草免费观看免费视频在线| 日韩免费视频在线观看| 色综合天天综合网天天看片| 欧美精品18+| 欧美精品在线播放| 日本一区二区三区四区五区| 国产日韩在线免费| 欧美一区第一页| 一本色道久久综合无码人妻| 欧美日产一区二区三区在线观看| 亚洲精品国产九九九| 天天干天天做天天操| 国产精品亚洲第五区在线| 欧美黄色高清视频| 久久精品青草| 国产乱码精品一区二三赶尸艳谈| 国产精品亚洲а∨天堂免在线| 99在线首页视频| 视频1区2区3区| 国产国语**毛片高清视频| 香蕉久久一区二区不卡无毒影院| 欧美大陆国产| 欧美刺激午夜性久久久久久久| 好吊色视频一区二区三区| 青青青在线视频| 精品一区二区视频| 日韩高清一区在线| 精品国产成人av在线免| 亚洲级视频在线观看免费1级| 欧美国产精品中文字幕|