日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

iOS繪圖

瀏覽:26日期:2022-09-17 13:42:08
介紹

說到iOS的繪圖肯定就是Core Graphics。

Core Graphics Framework是一套基于C的API框架,使用了Quartz作為繪圖引擎。它提供了低級別、輕量級、高保真度的2D渲染。該框架可以用于基于路徑的繪圖、變換、顏色管理、脫屏渲染,模板、漸變、遮蔽、圖像數據管理、圖像的創建、遮罩以及PDF文檔的創建、顯示和分析。

獲取圖形上下文

Core Graphics API所有的操作都在一個上下文中進行。所以在繪圖之前需要獲取該上下文并傳入執行渲染的函數中。如果你正在渲染一副在內存中的圖片,此時就需要傳入圖片所屬的上下文。獲得一個圖形上下文是我們完成繪圖任務的第一步,你可以將圖形上下文理解為一塊畫布。如果你沒有得到這塊畫布,那么你就無法完成任何繪圖操作。

獲取圖形上下文的幾種方式: 1.drawRect: 2.inContext: (-(void)drawInContext:(CGContextRef)ctx - (void)drawLayer:(CALayer*)layer inContext:(CGContextRef)ctx) 3.UIGraphicsBeginImageContextWithOptions

兩大繪圖框架: UIKit 像UIImage、NSString(繪制文本)、UIBezierPath(繪制形狀)、UIColor都知道如何繪制自己。 這些類提供了功能有限但使用方便的方法來讓我們完成繪圖任務。一般情況下,UIKit就是我們所需要的。 Core Graphics 這是一個繪圖專用的API族,它經常被稱為QuartZ或QuartZ 2D。Core Graphics是iOS上所有繪圖 功能的基石,包括UIKit。6種繪圖的形式

第一種UIKit框架drawRect:

在UIView的子類方法drawRect:中繪制一個藍色圓- (void) drawRect: (CGRect) rect { UIBezierPath* p = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0,0,100,100)]; [[UIColor blueColor] setFill]; [p fill]; }

第二種Core Graphics框架inContext:

- (void)drawRect:(CGRect)rect{ //當前上下文及畫布為當前view CGContextRef con = UIGraphicsGetCurrentContext(); CGContextAddEllipseInRect(con, CGRectMake(0,0,100,100)); CGContextSetFillColorWithColor(con, [UIColor blueColor].CGColor); CGContextFillPath(con);}

第三種UIKit框架inContext:

drawInContext:方法 @interface TestLayer : CALayer @end @implementation TestLayer - (void)drawInContext:(CGContextRef)ctx{ UIGraphicsPushContext(ctx); UIBezierPath* p = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0,0,100,100)]; [[UIColor blueColor] setFill]; [p fill]; UIGraphicsPopContext();} @end @implementation XXXViewController{- (void)viewDidLoad{ [super viewDidLoad]; //1.創建自定義的layer TestLayer *layer=[TestLayer layer]; //2.設置layer的屬性 layer.backgroundColor= [UIColor blackColor].CGColor; layer.frame=CGRectMake(100, 100, 200, 200); [layer setNeedsDisplay]; //3.添加layer [self.view.layer addSublayer:layer];} @end

drawLayer: inContext:方法 @interface MyLayerDelegate : NSObject @end @implementation MyLayerDelegate - (void)drawLayer:(CALayer*)layer inContext:(CGContextRef)ctx { UIGraphicsPushContext(ctx); UIBezierPath* p = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0,0,100,100)];[[UIColor blueColor] setFill];[p fill]; UIGraphicsPopContext(); } @end @implementation XXXViewController{MyLayerDelegate *_layerDeleagete; CALayer *_layer; } - (void)viewDidLoad{[super viewDidLoad];_layerDeleagete = [[MyLayerDelegate alloc] init]; //1.創建自定義的layer _layer=[CALayer layer]; //2.設置layer的屬性 _layer.backgroundColor= [UIColor blackColor].CGColor;_layer.frame=CGRectMake(100, 100, 200, 200);_layer.delegate = _layerDeleagete;[_layer setNeedsDisplay]; //3.添加layer [self.view.layer addSublayer:_layer]; } - (void)dealloc{_layer.delegate = nil; } @end

第四種Core Graphics框架inContext:

drawInContext:方法- (void)drawInContext:(CGContextRef)ctx{ CGContextAddEllipseInRect(ctx, CGRectMake(0,0,100,100)); CGContextSetFillColorWithColor(ctx, [UIColor blueColor].CGColor); CGContextFillPath(ctx);}

drawLayer: inContext:方法 - (void)drawLayer:(CALayer*)layer inContext:(CGContextRef)ctx { UIGraphicsPushContext(ctx); UIBezierPath* p = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0,0,100,100)];[[UIColor blueColor] setFill]; [p fill]; UIGraphicsPopContext(); }

第五種UIKit框架UIGraphicsBeginImageContextWithOptions

@implementation XXXViewController - (void)viewDidLoad{ [super viewDidLoad]; UIGraphicsBeginImageContextWithOptions(CGSizeMake(100,100), NO, 0); UIBezierPath* p = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0,0,100,100)]; [[UIColor blueColor] setFill]; [p fill]; UIImage* im = UIGraphicsGetImageFromCurrentImageContext(); UIGraphicsEndImageContext(); /*---------------------------------*/ UIImageView *imageView = [[UIImageView alloc] initWithFrame:CGRectMake(100, 100, 100, 100)]; [imageView setImage:im]; [self.view addSubview:imageView];} @end

第六種Core Graphics框架UIGraphicsBeginImageContextWithOptions

@implementation XXXViewController - (void)viewDidLoad{ [super viewDidLoad]; UIGraphicsBeginImageContextWithOptions(CGSizeMake(100,100), NO, 0); CGContextRef con = UIGraphicsGetCurrentContext(); CGContextAddEllipseInRect(con, CGRectMake(0,0,100,100)); CGContextSetFillColorWithColor(con, [UIColor blueColor].CGColor); CGContextFillPath(con); UIImage* im = UIGraphicsGetImageFromCurrentImageContext(); UIGraphicsEndImageContext(); /*---------------------------------*/ UIImageView *imageView = [[UIImageView alloc] initWithFrame:CGRectMake(100, 100, 100, 100)]; [imageView setImage:im]; [self.view addSubview:imageView];}注意

使用- (void)drawRect:(CGRect)rect需要注意的地方

以下方法調用drawRect

1.如果在UIView初始化時沒有設置rect大小,將直接導致drawRect不被自動調用。

2.該方法在調用sizeThatFits后被調用,所以可以先調用sizeToFit計算出size。然后系統自動調用drawRect:方法。

3.通過設置contentMode屬性值為UIViewContentModeRedraw。那么將在每次設置或更改frame的時候自動調用drawRect:。

4.直接調用setNeedsDisplay,或者setNeedsDisplayInRect:觸發drawRect:,但是有個前提條件是rect不能為0.

若要實時畫圖,不能使用gestureRecognizer,只能使用touchbegan等方法來掉用setNeedsDisplay實時刷新屏幕

問題比如當在一個view上繪制一條線之類的,是直接用addsubView添加一個UIView控件好,還是在drawRect:里用繪圖代碼繪制一條線好?哪種更高效,或者一樣?源碼,應用場景

以上六種方式繪制圓的代碼繪圖代碼比較常用就是圖表繪畫板這兩種場景。

兩個可以學習的源碼:圖表:BEMSimpleLineGraph繪畫板:Brushes

標簽: IOS
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
午夜久久av| 91麻豆精品| 久久免费精品| 精品视频在线观看网站| 国产欧美日韩视频在线| 国产激情综合| 成人自拍av| 国产精品免费看| 日本成人中文字幕| 精品少妇av| 欧美高清不卡| 亚洲久久视频| 精品欧美日韩精品| 精品一区亚洲| 日韩精品免费视频一区二区三区| 国产精品尤物| 丝袜美腿诱惑一区二区三区| aa国产精品| 日韩av网站免费在线| 国产精品激情电影| 福利在线免费视频| 午夜在线观看免费一区| 日韩美女国产精品| 成人国产精品久久| 亚洲激情欧美| 国产精品一线| 欧洲激情综合| 国产精品亲子伦av一区二区三区| 91免费精品| 一本综合精品| 在线一区av| 日本成人在线视频网站| 日韩精品电影| 国产日韩中文在线中文字幕 | 国产精品红桃| 午夜久久久久| 麻豆国产精品777777在线| 精品日韩毛片| 美女视频一区在线观看| 婷婷中文字幕一区| 久久不见久久见免费视频7| 亚洲精品1区2区| 国内自拍视频一区二区三区| 免费观看久久久4p| av一区在线| 国产福利资源一区| 久久性天堂网| 日韩在线综合| 国产精品一二| 中文一区一区三区免费在线观 | 国内不卡的一区二区三区中文字幕| 99视频一区| 久久久久久夜| 久久国内精品自在自线400部| 国产专区一区| 高清一区二区| 亚洲一区二区三区四区五区午夜 | 给我免费播放日韩视频| 亚洲综合精品| 欧美精品91| 在线精品一区二区| 美女久久久久| 在线一区视频观看| 久久午夜影院| 国产亚洲精品美女久久| 欧美另类专区| 久久国产日本精品| av资源中文在线天堂| 国产精品久久久久久久久久白浆 | 国产欧美日韩视频在线| 亚洲欧美日韩国产| 999久久久国产精品| 国内精品伊人| 美女在线视频一区| 国产欧美丝祙| 国产一区 二区| 日本不卡一二三区黄网| 午夜亚洲精品| 欧美日韩日本国产亚洲在线| 日本少妇一区| 99tv成人| 欧美日韩一二| 精品视频国内| 九九99久久精品在免费线bt| 欧美1区二区| 国产极品一区| 久久69成人| 成人在线视频免费看| 免费在线观看一区| 久久久久黄色| 成人免费一区| 国产不卡精品| 91看片一区| 亚洲涩涩在线| 久久精品高清| 激情六月综合| 91九色精品| 国产91精品对白在线播放| 99精品一区| 狠狠爱成人网| 亚洲深深色噜噜狠狠爱网站 | 日韩综合精品| 久久九九精品| 久久午夜影视| 青青草国产成人99久久| 国产精品日韩精品中文字幕| 国产一区二区三区不卡视频网站| 日韩中文欧美| 日韩一级欧洲| 亚洲精品美女| 一区二区精品| 国产精品成人**免费视频 | 久久国产精品美女| 日本一区二区免费高清| 欧美日韩视频免费观看| 性欧美69xoxoxoxo| 综合激情在线| 国产精品a级| 女生影院久久| 性欧美精品高清| 蜜臀久久99精品久久久画质超高清| 日韩中文字幕区一区有砖一区| 欧美一区免费| 欧洲一区二区三区精品| 久久裸体视频| 蜜臀久久久99精品久久久久久| 欧美日韩1区2区3区| 精品久久久网| 不卡在线一区| 久久精品97| 久久国产亚洲| 日韩精品a在线观看91| 水蜜桃久久夜色精品一区| 婷婷久久一区| 国产美女久久| 极品裸体白嫩激情啪啪国产精品| 亚洲一二三区视频| 国语对白精品一区二区| 99xxxx成人网| 久久精品99久久久| 精品三级久久| 91成人精品在线| 91精品国产成人观看| 日本电影久久久| 中文字幕在线官网| 四虎精品永久免费| 日韩精品一区二区三区免费观看| 亚洲一区二区三区四区电影| 日本黄色精品| 亚洲美女久久| 国产99精品| 老司机精品视频网| 亚洲制服少妇| 色在线视频观看| 日韩精品一级二级 | 亚洲视频二区| 欧美精品日日操| 91精品丝袜国产高跟在线| 99热国内精品| 老司机精品视频网| 日韩精品中文字幕一区二区| 蜜桃精品在线| 精品一区二区三区在线观看视频| 日韩中文字幕麻豆| 成人日韩在线| 欧美久久精品| 亚洲免费影院| 欧美天堂视频| 国产精品啊v在线| 一区二区三区四区日韩| 久久一区二区三区喷水| 激情久久一区二区| 欧美日韩一区二区国产| 蜜臀va亚洲va欧美va天堂| 久久一区二区三区电影| 日韩1区在线| 精品视频一区二区三区在线观看 | 国产精品午夜av| 日本大胆欧美人术艺术动态| 亚洲三级欧美| 精品国产网站| 国产精品亚洲综合久久| 亚洲69av| 蜜臀久久99精品久久久久久9| 亚洲国产一区二区在线观看 | 久久精品国产999大香线蕉| 日韩有吗在线观看| 亚洲午夜av| 亚洲一级特黄| 国产一区亚洲| 欧美日韩国产在线观看网站| 成人精品亚洲| 久久精品亚洲人成影院 | 国内精品美女在线观看| 国产精品一区二区中文字幕| 日本va欧美va瓶| 日本欧美在线| 午夜性色一区二区三区免费视频| 亚洲一区国产一区| 久久国产精品99国产|