成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

了解iPhone雙緩沖機制內(nèi)幕爆料

移動開發(fā) iOS
本文主要來介紹iPhone雙緩沖機制所謂“屏幕雙緩沖”是指在內(nèi)存中建立一個“圖形設備上下文的緩存”,所有的繪圖操作都在這個“圖形上下文緩存”上進行,來看內(nèi)容。

iPhone雙緩沖機制是本文要介紹的內(nèi)容,相信大多數(shù)人都知道,所謂“屏幕雙緩沖”是指在內(nèi)存中建立一個“圖形設備上下文的緩存”,所有的繪圖操作都在這個“圖形上下文緩存”上進行,在需要顯示這個“圖形上下文”的時候,再次把它更新到屏幕設備上。

iPhone平臺提供了這樣一個API:

  1. CGContextRef CGBitmapContextCreate (  
  2.    void *data,  
  3.    size_t width,  
  4.    size_t height,  
  5.    size_t bitsPerComponent,  
  6.    size_t bytesPerRow,  
  7.    CGColorSpaceRef colorspace,  
  8.    CGBitmapInfo bitmapInfo  
  9. ); 

這個API各個參數(shù)的意義如下:

參數(shù)data指向繪圖操作被渲染的內(nèi)存區(qū)域,這個內(nèi)存區(qū)域大小應該為(bytesPerRow*height)個字節(jié)。如果對繪制操作被渲染的內(nèi)存區(qū)域并無特別的要求,那么可以傳遞NULL給參數(shù)date。

參數(shù)width代表被渲染內(nèi)存區(qū)域的寬度。

參數(shù)height代表被渲染內(nèi)存區(qū)域的高度。

參數(shù)bitsPerComponent被渲染內(nèi)存區(qū)域中組件在屏幕每個像素點上需要使用的bits位,舉例來說,如果使用32-bit像素和RGB顏色格式,那么RGBA顏色格式中每個組件在屏幕每個像素點上需要使用的bits位就為32/4=8。

參數(shù)bytesPerRow代表被渲染內(nèi)存區(qū)域中每行所使用的bytes位數(shù)。

參數(shù)colorspace用于被渲染內(nèi)存區(qū)域的“位圖上下文”。

參數(shù)bitmapInfo指定被渲染內(nèi)存區(qū)域的“視圖”是否包含一個alpha(透視)通道以及每個像素相應的位置,除此之外還可以指定組件式是浮點值還是整數(shù)值。

從接口定義中可以看出,當調(diào)用這個函數(shù)時,系統(tǒng)會創(chuàng)建一個“視圖繪制環(huán)境”,這個“視圖繪制環(huán)境”就是讀者定義的一個“視圖上下文”。當讀者在這個“視圖上下文”進行繪制操作時,系統(tǒng)會在定義的渲染內(nèi)存區(qū)域中把繪制操作渲染成位圖數(shù)據(jù)。“視圖上下文”的像素格式由三個參數(shù)來定義,也就是每個組件占用的bits位數(shù)、colorspace以及alpha(透視),而alpha值指定了每個像素的不透明度。

根據(jù)上面講述的知識點,筆者定義了被渲染內(nèi)存區(qū)域如下:

  1. imageData = malloc((iFrame.size.width)*(iFrame.size.height)*32); 

筆者這里在屏幕每個像素上使用了32-bits來表示RGBA顏色格式,那么參數(shù)bitsPerComponent就為32/4=8,各個參數(shù)的定義如下:

  1. iDevice = CGBitmapContextCreate(imageData,iFrame.size.width,  
  2. iFrame.size.height,8,32*(iFrame.size.width),iColorSpace,kCGImageAlphaPremultipliedLast); 

這里筆者獲取iColorSpace的方法如下:

  1. iColorSpace = CGColorSpaceCreateDeviceRGB();  
  2. CGColorSpaceCreateDeviceRGB() 

方法可以獲取設備無關(guān)的RGB顏色空間,這個顏色空間需要調(diào)用CGColorSpaceRelease()進行釋放。

在創(chuàng)建成功被渲染的內(nèi)存區(qū)域的視圖上下文”iDevice后,那么讀者就可以在這個被渲染的內(nèi)存區(qū)域的“位圖上下文”上進行繪制操作了,正如上面所講的,所有的繪制操作將在被渲染的內(nèi)存區(qū)域中被渲染成位圖數(shù)據(jù),繪制操作如下:

  1. // 繪制圖片  
  2. CGContextDrawImage(iDevice, CGRectMake(0, 0, iFrame.size.width, iFrame.size.height), aImage);  
  3. // 繪制半透明矩形  
  4. CGRect rt;  
  5. rt.origin.x = 100;  
  6. rt.origin.y = 20;  
  7. rt.size.width = 200;  
  8. rt.size.height = 200;  
  9. CGContextSaveGState(iDevice);  
  10. CGContextSetRGBFillColor(iDevice, 1.0, 1.0, 1.0, 0.5);  
  11. CGContextFillRect(iDevice, rt);  
  12. CGContextRestoreGState(iDevice);  
  13. CGContextStrokePath(iDevice);  
  14. // 繪制直線  
  15. CGContextSetRGBStrokeColor(iDevice, 1.0, 0.0, 0.0, 1.0);  
  16. CGPoint pt0, pt1;  
  17. CGPoint points[2];  
  18. pt0.x = 10;  
  19. pt0.y = 250;  
  20. pt1.x = 310;  
  21. pt1.y = 250;  
  22. points[0] = pt0;  
  23. points[1] = pt1;  
  24. CGContextAddLines(iDevice, points, 2);  
  25. CGContextStrokePath(iDevice); 

可見,在被渲染的內(nèi)存區(qū)域的“位圖上下文”中可以進行圖片、矩形、直線等各種繪制操作,這些操作被渲染成位圖數(shù)據(jù),讀者可以通過如下方法獲取到這個被渲染的“位圖”:

  1. -(void)drawRect:(CGRect)rect {  
  2.     // Drawing code  
  3.          UIGraphicsGetCurrentContext();        
  4.          UIImage* iImage = [UIImage imageNamed:@"merry.png"];  
  5.          [iOffScreenBitmap DrawImage:iImage.CGImage];  
  6.          UIImage* iImage_1 = [UIImage imageWithCGImage:[iOffScreenBitmap Gc]];  
  7.          [iImage_1 drawInRect:CGRectMake(0, 0, 120, 160)];  

上面的代碼中,通過iOffScreenBitmap的DrawImage:CGImageRef方法把圖片merry.png繪制到屏幕雙緩沖中,并接著進行了矩形、直線繪制,然后通過CGBitmapContextCreateImage:CGConotextRef方法獲取“視圖上下文”的“視圖快照(snapshot)”image_1,***把這個“視圖快照”更新到屏幕上,從而實現(xiàn)屏幕雙緩沖的技術(shù),效果如下:

了解iPhone雙緩沖機制內(nèi)幕爆料

小結(jié)了解iPhone雙緩沖機制內(nèi)幕爆料的內(nèi)容介紹完了,希望本文對你有所幫助!

責任編輯:zhaolei 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2011-07-21 17:05:31

iPhone 屏幕 緩沖

2011-02-28 16:03:39

微軟

2016-12-14 14:29:30

Java動態(tài)綁定機制

2011-08-05 14:25:11

iPhone 架構(gòu) 音頻

2019-09-18 11:03:01

數(shù)據(jù)存儲數(shù)據(jù)庫

2011-08-02 18:07:03

iPhone 內(nèi)省 Cocoa

2020-10-20 15:42:11

蘋果iPhoneTouch ID

2012-05-21 22:12:01

2023-10-09 23:01:09

MySQL數(shù)據(jù)庫

2017-06-04 23:57:10

TiDBSQL存儲數(shù)據(jù)

2017-06-04 23:58:08

TiDB數(shù)據(jù)庫存儲

2017-06-09 08:00:38

TiDB調(diào)度數(shù)據(jù)庫

2011-08-04 17:36:24

iPhone 重繪 繪圖

2011-08-04 17:19:49

iPhone開發(fā) Xcode 文檔

2011-08-10 11:07:34

MySQL查詢緩沖

2010-04-08 15:43:28

Oracle緩沖塊

2018-09-12 16:44:45

iPhone蘋果雙卡雙待

2022-04-25 09:03:16

JavaScript代碼

2018-09-21 10:48:37

蘋果iPhone手機

2011-08-16 19:02:23

iPhone開發(fā)繪圖
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 精品日韩一区 | 亚洲+变态+欧美+另类+精品 | 中文字幕免费视频 | 久一久| 国产精品不卡一区 | 日韩在线一区二区 | 插插插干干干 | 成人精品在线视频 | 夜夜操天天艹 | 国产精品国产a | 91精品久久久久久久久中文字幕 | 欧洲精品在线观看 | 99久久99 | 国产精品中文字幕在线 | 久久综合久久综合久久 | 日韩有码一区 | 91精品国产综合久久久久久丝袜 | 亚洲毛片 | 91porn国产成人福利 | 国产精品视频在线观看 | www.色午夜.com | 成人深夜福利网站 | 欧美国产日韩在线观看 | 国产精品国产亚洲精品看不卡15 | av影音| 99视频入口 | 免费不卡视频 | 日韩精品久久久久 | av网站观看 | 成人av在线网站 | 日本久久久久久久久 | 成人免费淫片aa视频免费 | 亚洲 欧美 综合 | 日本一区二区不卡 | 欧美成人影院 | 国产精品91视频 | 国产福利在线 | 欧美区在线 | 欧美日韩综合一区 | 在线视频一区二区 | 亚洲第一av网站 |