iOS学习——Quartz2D学习(1)

本文以问答形式主要讲述Quartz2D的相关内容,参考内容是网上下载的学习视频资料。

1、什么是Quartz2D?

  他是一个二维的绘图引擎,同时支持iOS和Mac系统

2、Quartz2D能完成的工作

  画基本线条,绘制文字,图片,截图,自定义UIView.

3、Quartz2D在开发中的价值

  当我们的控件样式极其复杂时,可以把控件内部的结构给画出画,就是自定义控件.

4、什么是图形上下文

图形上下文是用来保存用户绘制的内容状态,并决定绘制到哪个地方的.

用户把绘制好的内容先保存到图形上下文,

然后根据选择的图形上下文的不同,绘制的内容显示到地方也不相同,即输出目标也不相同.

5、上下文的类型有哪些?

图形上下文的类型有:

Bitmap Graphics Context(位图上下文)

PDF Graphics Context

Window Graphics Context

Layer Graphics Context(图层上下文,自定义UIView取得上下文就是图层上下文.

UIView之所以能够显示就是因为他内部有一个图层)

Printer Graphics Context

6.如何自定义UIView,步骤是什么?

首先得要有上下文,有了上下文才能决定把绘制的东西显示到哪个地方去.CGContextRef ctx = UIGraphicsGetCurrentContext();

其次就是这个上下文必须得和View相关联.才能将内容绘制到View上面.在DrawRect方法方法里

步骤:

1.要先自定定UIView

2.实现DrawRect方法

3.在DrawRect方法中取得跟View相关联的上下文.

4.绘制路径(描述路径长什么样).

5.把描述好的路径保存到上下文(即:添加路径到上下文)

6.把上下文的内容渲染到View

7、DrawRect方法作用?什么时候调用.

DrawRect作用:专用在这个方法当中绘图的.只有在这个方法当中才能取得跟View相关联的上下文.

DrawRect是系统自己调用的, 它是当View显示的时候自动调用.

8、画线(基本步骤描述)

//1.获取跟View相关联的上下文
CGContextRef ctx = UIGraphicsGetCurrentContext();
//2.绘制路径
UIBezierPath *path = [UIBezierPath bezierPath];
  //2.1设置起点
    [path moveToPoint:CGPointMake(10, 125)];
     //2.2添加一根线到某个点
    [path addLineToPoint:CGPointMake(200, 125)];
//3.把路径添加到上下文
CGContextAddPath(ctx,path.CGPath);
//4.把上下文的内容渲染到View上面.
CGContextStrokePath(ctx);

9、 想要再添加一根线怎么办?

第一种方法:重新设置起点,添加一根线到某个点,一个UIBezierPath路径上面可以有多条线.

第二种方法:直接在原来的基础上添加线.把上一条的终点当做下一条线的起点.添加一根线到某个点直接在下面addLineToPoint:

10、怎么样设置线的宽度,颜色,样式?

设置这些样式,我们称为是修改图形上下文的状态.

设置线宽:CGContextSetLineWidth(ctx, 20);

设置线段的连接样式: CGContextSetLineJoin(ctx, kCGLineJoinRound);

添加顶角样式:CGContextSetLineCap(ctx, kCGLineCapRound);

设置线的颜色: [[UIColor redColor] setStroke];

11、如何画曲线?

画曲线方法比较特殊需要一个控制点来决定曲线的弯曲程度.画曲线方法为:

//先设置一个曲线的起点
[path moveToPoint:CGPointMake(10, 125)];
//再添加到个点到曲线的终点.同时还须要一个controlPoint(控件点决定曲线弯曲的方法程序)
[path addQuadCurveToPoint:CGPointMake(240, 125) controlPoint:CGPointMake(125, 10)];

12、如何画矩形,圆角矩形?

画矩形直接利用UIBezierPath给我们封装好的路径方法bezierPathWithRect:CGRectMake(x, y, width,height)

(x,y)点决定了矩形左上角的点在哪个位置
(width,height)是矩形的宽度高度

圆角矩形的画法多了一个参数,cornerRadius, bezierPathWithRoundedRect: cornerRadius:

cornerRadius它是矩形的圆角半径.

通过圆角矩形可以画一个圆.当矩形是正方形的时候,把圆角半径设为宽度的一半,就是一个圆.

bezierPathWithRoundedRect:CGRectMake(10, 100, 50, 50) cornerRadius:25

13、如果画椭圆,圆?

画椭圆的方法为:bezierPathWithOvalInRect:CGRectMake(x, y, width,height)

前两个参数(x,y)分别代码圆的圆心

后面两个参数(width,height)分别代表圆的宽度,与高度.

宽高都相等时,画的是一个正圆, 不相等时画的是一个椭圆

bezierPathWithOvalInRect:CGRectMake(10, 100, 50, 50)

14、如何利用渲染BezierPath对象的内容?

当创建一个UIBezierPath对象之后,我们可以使用它的strokefill方法在current graphics context中去渲染它,这两个方法的底层的实现,就是获取上下文,拼接路径,把路径添加到上下文,渲染到View。在调用这些方法之前,我们要进行一些其他的任务去确保正确的绘制path,以及path的设置。

使用UIColor类的方法去stroke和fill想要的颜色。

使用strokefill方法进行渲染时,不需要我们手动去获取上下文了,这两个方法会自定获取view的上下文,然后在该view上绘制渲染path对应的路径,stroke是绘制线,fill是填充path对应的封闭区域。

//设置矩形路径 path
UIBezierPath *path = [UIBezierPath bezierPathWithRect:CGRectMake(10, 100, 50, 50)];
//设置边框颜色
[[UIColor greenColor] setStroke];
//设置填充颜色
[[UIColor redColor] setFill];
//设置边框的线宽
path.lineWidth = 5;
//画边框
[path stroke];
//填充内部
[path fill];

15、如何画圆弧?

首先要确定圆才能确定圆弧,圆孤它就圆上的一个角度嘛。还是使用UIBezierPath的自带的初始化方法。bezierPathWithArcCenter:(CGPoint) radius:(CGFloat) startAngle:(CGFloat) endAngle:(CGFloat) clockwise:(BOOL)

center:圆心

radius:圆的半径

startAngle:起始角度

endAngle:终点角度

clockwise:Yes顺时针,No逆时针

注意:startAngle角度的位置是从圆的最右侧为0度,即时钟的三点钟方向为起点

//逆时针画一个半圆
UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:CGPointMake(125, 125) radius:100 startAngle:0 endAngle:M_PI clockwise:NO];
[path stroke];

//4分之1圆孤
UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:CGPointMake(125, 125) radius:100 startAngle:0 endAngle:-M_PI_2 clockwise:NO];
 [path stroke];

16、如何画扇形

扇形就是在圆弧的基础上进行填充,但是填充需要一个封闭的路径才能填充,所以画扇形的方法为:

1.先画一个圆弧

2.再添加一个一根线到圆心:

3.然后封闭路径:[path closePath],该方法会自动从路径的终点到路径的起点封闭起来,形成一个封闭的路径

4.最后进行填充:[path fill];

//画1/4圆示例
//画圆弧
UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:CGPointMake(125, 125) radius:100 startAngle:0 endAngle:-M_PI_2 clockwise:NO];
//添加一根线到圆心
[path addLineToPoint:CGPointMake(125, 125)];
//关闭路径,从路径的终点到路径的起点
[path closePath];
//画扇形边框
[path stroke];
//用填充的话,它会默认做一个封闭路径,从路径的终点到起点.
[path fill];

原文地址:https://www.cnblogs.com/mukekeheart/p/9340570.html

时间: 2024-08-03 02:16:35

iOS学习——Quartz2D学习(1)的相关文章

iOS NSString的学习熟悉

对于字符串频繁的切割,合并,插入等操作,优先使用NSMutableString类. 这里讨论的是NSString.然后就是贴代码: 1 -(void)stringDemo{ 2 NSLog(@"____________________________"); 3 4 NSString *string = [[NSString alloc] initWithString:@"Hi,woods!"]; 5 NSLog(@"%@", string); 6

IOS开发---菜鸟学习之路--(二)-数据获取

http://www.cnblogs.com/PleaseInputEnglish/p/3432024.html IOS开发---菜鸟学习之路--(二)-数据获取,布布扣,bubuko.com

iOS开发如何学习前端(1)

iOS开发如何学习前端(1) 我为何学前端?因为无聊. 概念 前端大概三大块. HTML CSS JavaScript 基本上每个概念在iOS中都有对应的.HTML请想象成只能拉Autolayout或者设置Frame的ViewController.好比你在网页上放了一个Button,如果用HTML你就可以设置他的摆放位置,在哪哪个控件里.但是你不可以设置大小,颜色,圆角之类的属性.CSS专门负责HTML管不了的这些颜色啊,大小啊之类的属性.JavaScript主要负责响应事件,你把它想象成iOS

0811 iOS开发需要学习哪些内容

1.iOS开发需要学习哪些内容? 2.开发步骤 3.框架 为了方便开发者开发出强大的功能,苹果提供了各种各样的框架 [1]UIKit:创建和管理应用程序的用户界面 [2]QuartzCore:提供动画特效以及通过硬件进行渲染的能力 [3]CoreGraphics:提供2D绘制的基于C的API [4]CoreLocation:使用GPS和WIFI获取位置信息 [5]MapKit:为应用程序提供内嵌地图的接口 [6]AVFoundation:音频.视频处理 [7]--

关于iOS开发的学习

关于iOS开发的学习,打个比方就像把汽车分解:    最底层的原料有塑料,钢铁    再用这些底层的东西造出来发动机,座椅    最后再加上写螺丝,胶水等,把汽车就拼起来了iOS基本都是英文的资料,也由于封闭,文档写的相当好.在遇到新框架的时候:    弄明白框架的功能    去文档里搜搜 框架的 Programming Guide 很有用    要弄明白框架类的继承结构写iOS的程序不一定都是用OBJC,很多框架是用C写的.学习iOS开发基础可以按照下面两个方面学:    基础 (原料 钢铁 

IOS图层Layer学习笔记(二)—— CALayer(上)

IOS图层Layer学习笔记(二)-- CALayer(上) 简介 CALayer是所有图层的基类.主要是一些基本显示属性(位置.锚点.颜色.透明度等).层次关系(子图层和父图层).基本动画等. 接下来分别从常用属性.类方法和实例方法来介绍CALayer的使用.顺序是按头文件的排序来. 常用属性 bounds CGRect,Animatable.控制layer的大小,其中x和y无效果,默认是(0,0). position CGPoint,Animatable.控制layer锚点在父图层的位置.

ios 控制器 modal 学习

5.12 为了给学生改论文,在UPC上登录了Windows 8.1,晚上正常关机.今日切换登陆Ubuntu 14.04分区,发现原来可以正常访问的windows下的NTFS分区都被锁死,提示如下错误: Error mounting /dev/sda2 at /media/love/Mis Archiivos: Command-line `mount -t "ntfs" -o "uhelper=udisks2,nodev,nosuid,uid=1000,gid=1000,dma

78.iOS最全学习资源汇总

目录: 第一部分: iOS 学习资源整理(包括视频/教程/博客/书记/插件/社区/网站) 第一部分: iOS 各大牛博客列表 第一部分: iOS github 上托管的各类第三方 ---------------------------------------------------------------------------------------------------------------------------------- iOS 学习最全资料 这份学习资料是为 iOS 初学者所准

Deep Learning(深度学习)学习笔记整理系列七

Deep Learning(深度学习)学习笔记整理系列 声明: 1)该Deep Learning的学习系列是整理自网上很大牛和机器学习专家所无私奉献的资料的.具体引用的资料请看参考文献.具体的版本声明也参考原文献. 2)本文仅供学术交流,非商用.所以每一部分具体的参考资料并没有详细对应.如果某部分不小心侵犯了大家的利益,还望海涵,并联系博主删除. 3)本人才疏学浅,整理总结的时候难免出错,还望各位前辈不吝指正,谢谢. 4)阅读本文需要机器学习.计算机视觉.神经网络等等基础(如果没有也没关系了,没