Quartz2D

Quartz2D

quartz2D 是一个二维绘图引擎,同时支持iOS和Mac OS X系统 (跨平台,纯C语言的)。包含在core Graphics框架中

Quartz 2D能完成的工作

  • 绘制图形

  • 绘制文字

  • 绘制\生成图片

Quartz 2D 绘图主要步骤

  • 获取图形上下文对象

CGContextRef ctx = UIGraphicsGetCurrentContext()

  • 拼接路径,同时向图形上下文添加路径

CGContextMoveToPoint(ctx,50,50);

CGContextAddLineToPoint(ctx,100,100);

注意Add操作的时候,画笔是不抬起来的,move操作画笔才会抬起来

  • 渲染

CGContextStrokePath(ctx);

什么是图形上下文

是一个CGContextRef类型的数据

图形上下文主要包括如下信息

  • 绘图路径(各种各样的图形)

  • 绘图状态(颜色、线宽、样式、旋转、缩放、移动)

  • 输入目标(会知道什么地方去?UIView、图片、PDF、打印机等)


绘图的方式

绘图的第二种方法:

  1. 获取图形上下文

CGContextRef ctx = UIGraphicsGetCurrentContext()

  1. 拼接路径

CGMutablepathRef path = CGPathCreateMutable();

CGPathMoveToPoint(path,NULL,50,50);

CGPathAddLineToPoint(path,NULL,100,100);

  1. 把路径添加到上下文中

CGContextAddPath(ctx,path)

  1. 渲染

CGContextStrokePath(ctx);

绘图的第三种方法

  1. 获取上下文

CGContextRef ctx = UIGraphicsGetCurrentContext();

  1. 拼接路径

UIBezierPath *path = [UIBezierPath alloc] init];

[path moveToPoint:CGPointMake(50,50)];

[path addLineToPoint:CGPointMake(100,100)];

  1. 把路径添加到上下文中

CGContextAddPath(ctx,path.CGPath);

  1. 渲染

`CGContextStrokePath(ctx);

绘图的第四种方式

  1. 获取上下文

  2. 路径

CGMutablePathRef path = CGPathCreateMutable();

CGPathMoveToPoint(path,NULL,50,50);

CGPathAddLineToPoint(path,NULL.100,100);

%%把c的path转成oc的path

UIBezierPath *path1 = [UIBezierPath bezierPathWithCGPath:path];

[path1 addLineToPoint:CGPointMake(150,50)];

  1. 添加到上下文中

CGContextAddPath(ctx,path1.CGPath);

  1. 渲染

CGContextStrokePath(ctx);

绘图的第五种方法

  • 路径

UIBezierPath *path = [UIZBezierPath bezierPath];

[path movePoint:CGPointMake(50,50);]

[paht addLineToPoint:CGPointMake(100,100)]

  • 渲染

[path stroke];

drawrect概述

为什么要把代码写在drawrect中

因为drawrect可以获取正确的上下文

drawrect的rect参数的含义

rect就是当前view的bounds

drawrect什么时候会被调用

  1. 当这个view第一次显示的时候

  2. 重绘的时候

如何重绘

  1. 调用当前view的setNeedsDisplay方法

  2. 调用当前view的setNeedsDisplayInRect, rect表示刷新区域

为什么不能手动调用drawrect

手动调用可能获取不到正确的上下文

圆角半径误差

圆角半径有1/3的误差 在大于圆角半径的2/3 都是一个圆形

椭圆画法

OC: -� bezierPathWithOvalInRect:CGRectMake();

C : CGContextRef ctx = UIGraphicsGetCurrentPath();

弧的画法

OC

UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:CGPointMake() radius: startAngle: endAngle: clockwise:]

arcCenter : 圆心

radius : 半径

startAngle : 起始位置

endAngle : 终止位置

clockwise : 是否顺时针

C

CGContextAddArc(ctx,150,150,100,-M_PI_2,M_PI_2,0); clockwise 在C中iOS环境下是反的:在Mac OS X中是正常的

设置样式(C)

设置线宽

CGContextSetLineWidth(上下文,线宽);

连接处的样式

CGContextSetLineJoin(上下文,kCGLineJoinxxx);

kCGLineJoinMiter 默认

kCGLineJoinRound 圆角

kCGLineJoinBevel 切角

设置头尾的样式

CGContextSetLineCap(上线下文,kCGLineCapxxx);

  • kCGLineCapButt 默认

  • kCGlineCapRound 圆角

  • kCGlineCapSquare 比默认长一个线宽的距离

设置线的颜色

CGContextSetRGBStrokeColor(上下文,color)

[[UIColor redColor] setStroke]也可以设置颜色

设置样式(OC)

线宽

[path setLineWidth:30];

头尾的样式

[path setLineCapStyle:kCGLineCapRound];

连接处的样式

[path setLineJoinStyle:kCGLineJoinRound];

颜色

[[UIColor redColor] setStroke];

画三角形

除了普通的画法,将先单纯的连接起来还有一种关闭路径的方法

CGContextClosePath(ctx);{在最后的位置和起始的位置连成一条线}

在OC中[path closePath]

渲染(C)

分为两大种

一种是stroke 一种是fill (填充)

CGContextStrokePath();

CGContextFillPath();

CGContextDrawPath(ctx,kCGPathFill) = CGContextFillPath(cox);两句话等价 都是填充渲染

stroke(描边)同理

渲染(OC)

[path stroke];

[path fill];

既填充又描边两句话都执行一次

奇偶填充

说明被覆盖过奇数次的点填充,被覆盖过偶数次的不填充

C语言

CGContextDrowPath(ctx,kCGPathEoFill)

OC语言

path.useEvenOddFillRule = YES;

[path fill];

矩阵操作

注意该操作 是对于上下文进行操作的 要在对路径操作之前执行

平移

CGContextTranslateCTM();

旋转

CGContextRotateCTM();

缩放

CGContextScaleCTM();

图形上下文栈

创建完成上下文后 保存上下文 ,在需要的时候再恢复

CGContextSaveGState(ctx); 备份

CGContextRestoreGState();恢复

注意 这是一个栈 需要入栈和出栈

绘制文字

[(NSString *) drawAtPoint: withAttribute:]从指定位置开始绘制文字

[(NSString *) drawAtRect: withAttribute:]

attribute 传一个字典,这个字典中有文字个各种属性

NSDictionary *dict = @{NSFontAttributeName : [UIFont systemFontOfSize:(NSInteger)],

NSForegroundColorAttributeName : [UIColor redColor]::前背景::

NSBackgroundColorAttribute : [UIColor blueColor]::后背景::

NSUnderLineStyleAttributeName : @(3)}`::下划线::

NSShadow *shadow = [NSShadow alloc] init

shadow.shadowOffset = CGSizeMake(50,59)阴影的偏移量

绘制图片

UIImage *image = [UIImage imageNamed:@"m"];

[image drawAtPoint:]从指定的点开始绘制

[image drawInRect:];绘制到指定的区域(拉伸)

[image drawAsPatternInRect :]平铺到指定区域

通过UIColor设置view的背景图片

[UIColor colorWithPatternImge:];

裁剪图片

首先添加裁剪区域 在画图片

bitmap上下文

注意有开启 有关闭 栈模式 需要自己开启 可以在viewController中开启

UIGraphicsBeginImageContext();开启一个图片类型的图形上下文

UIGraphicsEndImageContext();关闭图片类型的图形上下文

bitmap画图

  1. 开始图片类型的图形上下文

UIGraphicsBeginImageContext();

UIGraphicsBeginImageContextWithOptions( size,(BOOL)opaque,scale Factor)scaleFactor一般情况写0 自动适配屏幕的缩放因子

  1. 获取当前上下文

CGContextRef ctx = UIGraphicsGetCurrentPath();

  1. 路径 添加到图片类型图型上下文中

CGContextAddArc();

  1. 渲染

CGContextStrokePath()

  1. 通过图片类型的图形上下文获取图片

UIImage *image = UIGraphicsGetImageFromCurrentImageContext();

  1. 关闭图片类型的图形上下

UIGraphicsEndImageContext();

将图片保存到沙盒中

  1. 把image对象转成data

NSData *data = UIImagePNGRrepresentation(image);

  1. 再通过data write to file

[data writeToFile:@"filePath" atomically :YES];

将图片保存到相册中去

UIImageWriteToSavedPhotosAlbum();

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容