Quartz2D是跨平台的,同时支持iOS与Mac。

支持圆型裁剪,可以实现圆形头像等功能,也支持手势解锁、折线图等的制作。

对于复杂的UI界面,还可以通过Quartz2D将控件内部的结构画出来,可用于自定义控件。

实际上iOS大部分控件都是通过Quartz2D画出来的,一个重要价值是自定义view。

一些基础概念:

1.图形上下文(Graphics Context):是CGContextRef类型数据

能保存绘图信息、绘图状态,决定绘制的输出目标,可以输出到文件或者窗口。

绘制好的图像先保存到图形上下文,再显示到输出目标。

Tip:相同的图像,经过不同的图形上下文,就可以显示到不同的地方。

Quartz2D支持的类型:Bitmap、PDF、Window、Layer、Printer.

2.自定义view

拥有图形上下文,并且与view有关。

步骤:

1.新建一个类,继承自UIView。

2.实现drawRect: rect方法画图。

3.须知:

1.后面绘制的部分覆盖前面绘制的部分。

2.Quartz2D的API是纯C代码。

3.Quartz2D来自CoreGraphics框架。

4.数据类型和函数基本都是以CG开头。

重写UIView的drawRect方法,可以绘制图形,绘制直线的方法:

1.绘制直线

以CGContext开头的,MoveToPoint、AddLineToPoint以及StrokePath方法

Tip:如果要画独立的直线,只要多次使用MoveToPoint即可。

Tip:drawRect函数在View第一次显示到屏幕上的时候会调用一次,重绘时也会调用一次。

- (void)drawRect:(CGRect)rect {

    // 1.获得图形上下文
CGContextRef ctx = UIGraphicsGetCurrentContext();
// 2.拼接图形(路径)
// 2.1设定起点
CGContextMoveToPoint(ctx, 10, 10);
// 2.2添加一条线从起点到(100,100)
CGContextAddLineToPoint(ctx, 100, 100);
// 2.3从上次终点继续绘制
CGContextAddLineToPoint(ctx, 150, 40);
// 2.4回到起点,关闭路径
CGContextAddLineToPoint(ctx, 10, 10);
// 3.渲染显示到view上,stroke是空心的形式。
CGContextStrokePath(ctx); }

2.绘制矩形:

CGContextAddRect(ctx, CGRectMake(10, 10, 100, 100));

Tip:Stroke方法画的是空心图形,将Stroke换为Fill可得到填充图形。

3.设置状态的代码(颜色、粗细):

Tip:设置状态的代码一定要放在渲染的前面,放在绘制函数的前后都可以。

3.1设置线宽:

CGContextSetLineWidth(ctx, 10);

3.2设置颜色:有Stroke和Fill两种方式,注意小数是 x / 255.0。

CGContextSetRGBStrokeColor(ctx, 255/255.0, 125/255.0, 0.0, 1.0)

Tip:状态只在渲染的时候确定,因此多个状态不同的内容应该渲染多次。

3.3线段头尾样式(圆形):三中,Miter是默认的发射状(方形)、Round为圆形、Bevel为裁剪。

CGContextSetLineCap(ctx, kCGLineCapRound);

连接点样式:

CGContextSetLineJoin(ctx, kCGLineJoinRound);

Tip:如果使用多次渲染,那么之前绘制的路径尾就无法继续使用了,应该重新确立起点。

Tip:CMYK是印刷色彩颜色,由青、品红、黄、黑构成,RGB由红绿蓝构成。

设置颜色的一个简便方法:

使用UIColor对象的setStroke与setFill方法:如果写set则是全部设置。

[[UIColor redColor] setStroke];

4.绘制圆和椭圆:通过外接矩形确定。

    // 圆形
CGContextAddEllipseInRect(ctx, CGRectMake(10, 10, 60, 60));
// 椭圆
CGContextAddEllipseInRect(ctx, CGRectMake(100, 100, 100, 50));

5.绘制圆弧:

/**
* 绘制圆弧
*
* @param c#> 图形上下文 description#>
* @param x#> 圆心x description#>
* @param y#> 圆心y description#>
* @param radius#> 半径 description#>
* @param startAngle#> 起始角度 description#>
* @param endAngle#> 结束角度 description#>
* @param clockwise#> 圆弧生长方向 0顺 1逆 description#>
*
*/
CGContextAddArc(<#CGContextRef c#>, <#CGFloat x#>, <#CGFloat y#>, <#CGFloat radius#>, <#CGFloat startAngle#>, <#CGFloat endAngle#>, <#int clockwise#>);

需要注意的是角度为弧度,应该通过系统的宏来换算:M_PI_2表示二分之PI,M_1_PI表示0.1PI。

另外注意一点这里的角度和数学定义不同,顺时针为正角度,逆时针为负角度。

6.图片和文字结合:

Tip:Quartz2D的坐标系和数学上一致,但是UIKit框架做了转换,和屏幕坐标系一致都是左上角为(0,0),因此使用纯C语言绘制出来的东西是倒着的。

利用OC来绘制字符串不需要调用和上下文:

NSString *str = @"一段文字";
[str drawAtPoint:CGPointMake(0, 0) withAttributes:nil];

想把文字放到矩形框内,使用drawInRect,还可以自动换行。

withAttributes是对状态的设置,注意要传入字典。

参数已经定义成字符串常量:

NSMutableDictionary *attrs = [NSMutableDictionary dictionary];
attrs[NSForegroundColorAttributeName] = [UIColor whiteColor];
[str drawAtPoint:CGPointMake(0, 0) withAttributes:attrs];

常见的属性:

NSForegroundColorAttributeName为文字颜色。

NSFontAttributeName为字体。

图片的绘制:

直接绘制:

[UIImage imageNamed:@"me"];
[image drawInRect:CGRectMake(0, 0, 150, 150)];

平铺:

[UIImage imageNamed:@"me"];
[image drawAsPatternInRect:CGRectMake(0, 0, 150, 150)];

(四十七)Quartz2D引擎初步的更多相关文章

  1. NeHe OpenGL教程 第四十七课:CG顶点脚本

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  2. Gradle 1.12用户指南翻译——第四十七章. Build Init 插件

    本文由CSDN博客貌似掉线翻译,其他章节的翻译请参见: http://blog.csdn.net/column/details/gradle-translation.html 翻译项目请关注Githu ...

  3. Java进阶(四十七)Socket通信

    Java进阶(四十七)Socket通信   今天讲解一个 Hello Word 级别的 Java Socket 通信的例子.具体通讯过程如下: 先启动Server端,进入一个死循环以便一直监听某端口是 ...

  4. SQL注入之Sqli-labs系列第四十七关,第四十八关,第四十九关(ORDER BY注入)

    0x1 源码区别点 将id变为字符型:$sql = "SELECT * FROM users ORDER BY '$id'"; 0x2实例测试 (1)and rand相结合的方式 ...

  5. C# 优化程序的四十七种方法

    一.用属性代替可访问的字段 1..NET数据绑定只支持数据绑定,使用属性可以获得数据绑定的好处: 2.在属性的get和set访问器重可使用lock添加多线程的支持. 二.readonly(运行时常量) ...

  6. 《构建之法》第四&十七章读书笔记

     <构建之法>第四&十七章读书笔记 一.         前言 再次阅读<构建之法>,愈发被其中生动有趣的举例吸引.作为一本给予软件工程学生的书籍,其不以枯燥的理论知识 ...

  7. 使用Photon引擎进行unity网络游戏开发(四)——Photon引擎实现网络游戏逻辑

    使用Photon引擎进行unity网络游戏开发(四)--Photon引擎实现网络游戏逻辑 Photon PUN Unity 网络游戏开发 网络游戏逻辑处理与MasterClient 网络游戏逻辑处理: ...

  8. “全栈2019”Java第四十七章:继承与方法

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  9. 孤荷凌寒自学python第四十七天通用跨数据库同一数据库中复制数据表函数

    孤荷凌寒自学python第四十七天通用跨数据库同一数据库中复制数据表函数 (完整学习过程屏幕记录视频地址在文末) 今天继续建构自感觉用起来顺手些的自定义模块和类的代码. 今天打算完成的是通用的(至少目 ...

随机推荐

  1. WeihanLi.Npoi

    WeihanLi.Npoi Intro Npoi 扩展,适用于.netframework4.5及以上和netstandard2.0, .netframework基于NPOI, .netstandard ...

  2. python学习之路基础篇(第五篇)

    前四天课程回顾 1.python简介 2.python基本数据类型 类: int:整型 | str:字符串 | list:列表 |tuple:元组 |dict:字典 | set:集合 对象: li = ...

  3. windows上安装nodejs,升级npm,安装webpack指南

    安装nodejs https://nodejs.org/en/ 安装webpack和其他一些常用的 npm install -g node-gyp webpack coffee-script 监控 w ...

  4. Udemy上免费的angualr2视频教程分享

    福利大分享 本文作者:苏生米沿 本文地址:http://blog.csdn.net/sushengmiyan/article/details/52592518 一晚上听了10几节课程,整体感觉很不错的 ...

  5. Linux SWAP 交换分区配置说明

    一.SWAP 说明1.1 SWAP 概述        当系统的物理内存不够用的时候,就需要将物理内存中的一部分空间释放出来,以供当前运行的程序使用.那些被释放的空间可能来自一些很长时间没有什么操作的 ...

  6. 每CPU变量

    最好的同步技术是把设计不需要同步的临界资源放在首位,这是一种思维方法,因为每一种显式的同步原语都有不容忽视的性能开销.最简单也是最重要的同步技术包括把内核变量或数据结构声明为每CPU变量(per-cp ...

  7. Connection Reset By Peer 解析

    linux网络编程 Connection reset by peer错误服务器向客户端发送了数据,客户端没有接收就关闭了,服务器read就会发生Connection reset by peer错误.我 ...

  8. Android5.0特性阴影效果和裁剪

    阴影和剪裁 View的z属性 Material Design建议为了凸显布局的层次,建议使用阴影效果,并且Android L为了简化大家的工作,对View进行了扩展,能使大家非常方便的创建阴影效果: ...

  9. Android TV开发总结(六)构建一个TV app的直播节目实例

    请尊重分享成果,转载请注明出处:http://blog.csdn.net/hejjunlin/article/details/52966319 近年来,Android TV的迅速发展,传统的有线电视受 ...

  10. 数组中的数分为两组,让给出一个算法,使得两个组的和的差的绝对值最小,数组中的数的取值范围是0<x<100,元素个数也是大于0, 小于100 。

    比如a[]={2,4,5,6,7},得出的两组数{2,4,6}和{5,7},abs(sum(a1)-sum(a2))=0: 比如{2,5,6,10},abs(sum(2,10)-sum(5,6))=1 ...