对于刚接触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画图的更多相关文章

  1. iOS开发 - Quartz2D画图

    Quartz 2D简单介绍 是一个二维画图引擎,同一时候支持iOS和Mac系统 Quartz 2D能完毕的工作 绘制图形 : 线条\三角形\矩形\圆\弧等 绘制文字 绘制\生成图片(图像) 读取\生成 ...

  2. 【iOS开发-80】Quartz2D画图简单介绍:直线/圆形/椭圆/方形以及上下文栈管理CGContextSaveGState/CGContextRestoreGState

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2Vpc3ViYW8=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ...

  3. IOS Quartz2D简介

    Quartz2D 简介( 后续会有相关应用) 第一部分 绘制直线 代码示例: - (void)drawRect:(CGRect)rect{ //获取图形上下文 CGContextRef cxConte ...

  4. iOS——Quartz2D

    0. 复习. 1.基本图形绘制 * 线段(线宽.线段样式) * 矩形(空心.实心.颜色) * 三角形.四边形等形状 1> 说明 - (void)drawRect:(CGRect)rect 什么时 ...

  5. iOS:quartz2D绘图 (动画)

    quartz2D可以用来绘制自己需要的图形,它们绘制出来的是一个静态的图形,那么如何绘制一个动态的图形呢?动态的图形就是动画,所谓动画,其实就是很多张图片在短时间内不停的切换所产生的一种视觉效果.qu ...

  6. iOS CGContextRef画图时的常用方法

    UIView的drawRect方法 CoreGraphics绘图 综述:描述系统会调用UIView的drawRect方法,所以coreGraphics的所有实现代码放在该函数内,setNeedsDis ...

  7. IOS Quartz2D 通过UIColor生成图片

    普通生成 示例代码: //这里实现普通生成图片的方法 - (void)drawRect:(CGRect)rect { CGRect cxRect = CGRectMake(, , , ); UIGra ...

  8. iOS CGContextRef 画图小结

    CGContextRef context = UIGraphicsGetCurrentContext(); //设置上下文 //画一条线 CGContextSetStrokeColorWithColo ...

  9. ios 贝塞尔画图

    CGContextRef context = UIGraphicsGetCurrentContext(); //写文字 CGContextSetRGBFillColor(context, 1, 0, ...

随机推荐

  1. vs2012运行项目提示无法连接 asp.net development server的解决方案

    更改本项目的.sln文件的端口号即可:如果还不行的话,多试几次:

  2. ASP.NET MVC路由

    ASP.NET MVC路由(四) 前言 在前面的篇幅中我们讲解路由系统在MVC中的运行过程以及粗略的原理,想必看过前面篇幅的朋友应该对路由有个概念性的了解了,本篇来讲解区域,在读完本篇后不会肯定的让你 ...

  3. 如何使ActionBar不那么单调

    此时我没有生产博客,此时我只是优秀博客的搬运工! 博客原址,有兴趣的可以查看一下. 详情如下: 使ActionBar不那么单调 回到2013年5月份,每一个人都发觉了Play Music中Action ...

  4. Ubuntu下的截图工具

    转载自:http://os.yesky.com/88/8733088.shtml 相信大家对于屏幕截图(或称抓图)应该不会陌生,在Windows平台上,我们可以使用许多第三方的专业抓图软件如SnagI ...

  5. 高并发非自增ID如何设计?

    博友们一起来讨论下高并发非自增ID如何设计? 底层是很重要的,我最近设计底层,通用底层. 我想跟大家谈论下这个话题: 如何在高并发环境下设计出一套好用的非自增ID的添加操作的解决方案?更新的操作我随机 ...

  6. OpenStack调研

    OpenStack调研:OpenStack是什么.版本演变.组件关系(Havana).同类产品及个人感想 一点调研资料,比较浅,只是觉得部分内容比较有用,记在这里: 首先,关于云计算,要理解什么是SA ...

  7. What skills are needed for machine learning jobs

    What skills are needed for machine learning jobs?机器学习工作必须技能 原文: http://www.quora.com/Machine-Learnin ...

  8. SQLSERVER数据库自动备份工具SQLBackupAndFTP(功能全面)

    挺好用的SQLSERVER数据库自动备份工具SQLBackupAndFTP(功能全面) 这个工具主要就是自动备份数据库,一键还原数据库,发送备份数据库日志报告到邮箱,自动压缩备份好的数据库 定期执行数 ...

  9. C# 根据时间创建文件夹

    string file = ((fileNameIndex)index).ToString(); if (!Directory.Exists(HttpContext.Current.Server.Ma ...

  10. CC.NET模板简化配置

    [Hello CC.NET]巧用模板简化配置 从 <[Hello CC.NET]CC.NET 实现自动化集成> 到 <[Hello CC.NET]自动化发布时 Web.config ...