iOS Quartz2D画图
对于刚接触Quartz2D的同学来说,先了解 上下文 的概念,再从最基础的画线来具体体验Quartz2D的画图步骤
介绍Quart2D :是苹果官方的二维(平面)绘图引擎,同时支持iOS和macOS系统,它的API是纯C语言的,它可以绘制图形、绘制文字、绘制图片、截图、自定义UI控件
在iOS开发中,Quartz2D最常用来自定义UI控件。
Quartz2D画图步骤: 1:获取图形上下文对象 2 向图形上下文对象中添加路径,绘图属性等等 3 渲染(把图形上下文中的路径绘制到对应的输出设备上)
介绍图形上下文(Graphics Context):是一个CGContextRef类型的数据。对于初学者,不要抱有很大压力,说白了就是我们小时候画图的时候,先要有草稿纸,在草稿纸先描绘一下,再誊抄到画板上,上下文其实就好比草稿纸。
图形上下文主要包含以下几个信息:1绘图路径(各种各样的图形:直线,三角形,圆形....) 2绘图状态:(颜色,线宽,样式,旋转...) 3输出目标:(绘制到什么地方去?UIView,图片,pdf...) 所以,相同的绘图序列,制定不同的上下文,就可以吧图形绘制到不同的目标上。如果概念大家看不明白的话,那就在代码中体验上下文的作用。
下面介绍5种绘图方式,大家慢慢体会
首先做一些准备工作:
接下来,打开自定义的类HFView.m文件,在-(void)drawRect:(CGRect)rect;方法中绘图
为什么要在这个方法里面绘图。1因为只有在这个方法中才可以获得图形上下文,在别的方法中无法获取到上下文,

并且-(void)drawRect:(CGRect)rect;无法在别的方法中调用,因为只有系统自己调用这个方法才能获取上下文,自己手动调用是获取不到上下文的

总结:绘图代码之所以写在-(void)drawRect:(CGRect)rect方法中,是因为:1 只有在这个方法中才能获取到上下文,2 这个方法只有系统调用的时候,才能获取上下文,自己在别的方法中手动调用,是获取不到上下文的。
下面,开始编写代码:
第一种:纯C语言,直接将路径添加到上下文中

第二种:纯C语言,先创建C路径,再添加到上下文里面

第三种:C语言,嵌套OC路径

第四种:C语言 C路径嵌套OC路径

第五种 纯OC [大家可以体验面向对象的简单了]

以上为大家介绍了5中绘图方式,后面绘制图片,绘制文字,用的更多的是C路径OC路径一起使用,因为有一些功能,纯OC是无法实现的,所以大家着重练习使用第三种方式。
下面介绍一下绘图属性设置:
首先介绍C路径属性设置


线条属性设置有上面几种,感兴趣的同学可以试试,每个效果是什么样子的。
下面介绍OC路径的属性设置


开始的时候我们就说过,上下文中除了保存路径,还有绘图属性和输出目标,当渲染方法执行的时候,上下文栈会做出什么事情呢?
下面我们就来学习一下上下文栈的原理

写代码验证上面的推理

证明了我们的推理是正确地,上下文栈的原理也是这样子的。
下面给大家介绍常见图形的绘制方法,每种图形用一种方式绘制,感兴趣的同学可以尝试使用另外的方法绘制,熟练掌握几种绘图方法,让大家更深的体会Quartz2D 的绘图步骤
三角形的绘制:纯C语言,直接将路径添加到上下文中

也可以这样写

直角矩形 纯OC方式

圆角矩形,

因为OC路径有直接的类创建方法,使用起来更加方便,所以使用OC的
圆形,有很多方式,修改一下圆角矩形的数据就可以了

弧线的绘制


扇形的绘制 在弧线的基础上添加两条线


给大家介绍了Quartz2D的简单使用,以及简单图形的绘制。希望对大家有帮助
iOS Quartz2D画图的更多相关文章
- iOS开发 - Quartz2D画图
Quartz 2D简单介绍 是一个二维画图引擎,同一时候支持iOS和Mac系统 Quartz 2D能完毕的工作 绘制图形 : 线条\三角形\矩形\圆\弧等 绘制文字 绘制\生成图片(图像) 读取\生成 ...
- 【iOS开发-80】Quartz2D画图简单介绍:直线/圆形/椭圆/方形以及上下文栈管理CGContextSaveGState/CGContextRestoreGState
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2Vpc3ViYW8=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ...
- IOS Quartz2D简介
Quartz2D 简介( 后续会有相关应用) 第一部分 绘制直线 代码示例: - (void)drawRect:(CGRect)rect{ //获取图形上下文 CGContextRef cxConte ...
- iOS——Quartz2D
0. 复习. 1.基本图形绘制 * 线段(线宽.线段样式) * 矩形(空心.实心.颜色) * 三角形.四边形等形状 1> 说明 - (void)drawRect:(CGRect)rect 什么时 ...
- iOS:quartz2D绘图 (动画)
quartz2D可以用来绘制自己需要的图形,它们绘制出来的是一个静态的图形,那么如何绘制一个动态的图形呢?动态的图形就是动画,所谓动画,其实就是很多张图片在短时间内不停的切换所产生的一种视觉效果.qu ...
- iOS CGContextRef画图时的常用方法
UIView的drawRect方法 CoreGraphics绘图 综述:描述系统会调用UIView的drawRect方法,所以coreGraphics的所有实现代码放在该函数内,setNeedsDis ...
- IOS Quartz2D 通过UIColor生成图片
普通生成 示例代码: //这里实现普通生成图片的方法 - (void)drawRect:(CGRect)rect { CGRect cxRect = CGRectMake(, , , ); UIGra ...
- iOS CGContextRef 画图小结
CGContextRef context = UIGraphicsGetCurrentContext(); //设置上下文 //画一条线 CGContextSetStrokeColorWithColo ...
- ios 贝塞尔画图
CGContextRef context = UIGraphicsGetCurrentContext(); //写文字 CGContextSetRGBFillColor(context, 1, 0, ...
随机推荐
- GLFW3出error adding symbols: DSO missing from command line解决
背景:使用OpenGL的GLFW3.1库的时候,使用其中一些代码 报error adding symbols: DSO missing from command line 因为使用的是Qcreator ...
- Javascript实例技巧精选(8)—计算当月剩余天数
>>点击这里下载完整html源码<< 截图如下: 利用Javascript在网页上计算当前月份的剩余天数,相应代码如下: <script language="J ...
- vim复制
关于vim复制剪贴粘贴命令的总结 最近在使用vim,感觉很好很强大,但是在使用复制剪切粘贴命令是,碰到了一些小困惑,网上找了一些资料感觉很不全,讲的也不好,遂自己进行实践并总结了. 首先是剪切(删 ...
- Asycn/Await 异步编程初窥(二)
经过总过4天的学习和实践,做完了 WinForm 下 .Net 4.5 的基本异步应用,实现了一个 Http 协议下载的测试程序,为以后使用 .Net 4.5 积累知识和经验.这个小程序完成这样几个作 ...
- 鸟哥的LINUX私房菜基础篇第三版 阅读笔记 二
Linux档案与目录管理 1.一些比较特殊的目录,需要用力的记下来 . 代表当前层目录 .. 代表上一层目录 - 代表前一个工作目录 (这个好屌!其他的 ...
- slxna,游戏页面切到后台回来后返回sl页面导致sl页面无响应,解决方法。
slxna在wp7上表现很好,因为那会xna还是微软的亲儿子.但是到wp8时代,微软丢弃xna,不管不问了.但是丢之前没有把兼容搞的完美,以致有很多隐秘的坑,说不定就踩到了. 我这个游戏的sl页面用了 ...
- OpenCV3.0.0+win10 64位+vs2015环境的下载,安装,配置
操作系统:WIN10 pro 64 软件版本:VS2015+OpenCV3.0.0 1. 下载安装 http://opencv.org/ https://www.visualstudio.com/ ...
- c# 在datagridview中添加comboboxcolumn 绑定数据库读取显示数据
datagridview中的comboboxcolumn 从绑定的数据库中读取显示时,只需要注意一点,就是sql语句加个 CStr() 字符串转换函数即可,如下: SELECT CStr(XXX) a ...
- 使用ResourceDictionary管理Logical Resources
WPF整理-使用ResourceDictionary管理Logical Resources “Logical resources may be of various types, such as br ...
- MFC注册表操作
注册表简介 有时程序中要存些设置信息,一个方法就是创建一些普通的txt或xml文件,然后保存进去就行了.另一办法就是保存到注册表里.注册表是由windows维护的一个小数据库.里面也会保存window ...