在 iOS 开发过程中,有时我们可能需要自己用代码绘制应用的部分内容,这时候就需要和绘图系统打交道了。 iOS 的绘图系统很强大,我们可以用它来做很多事情;另一方面 Apple 做了很多艰苦卓绝的工作,使得大多数情况下我们可以很轻松完成绘制任务。
大多数人应该都有过绘画的经历,这和 iOS 中的绘画很类似,我相信最开始研究计算机图形学的先驱肯定汲取了很多绘画的精髓,所以我们联系绘画来理解 iOS 中的绘画会很有帮助。
当我们在现实生活中绘画时,我们会思考些什么?有些事情是肯定会要考虑的,比如,要画什么内容?画到哪里?用什么东西画?怎么画?在 iOS 中绘画,我们同样要考虑这些问题,只不过这时要和 Apple 定义的术语联系起来,因为我们在她定义的世界里,所以就要按她的规则来行事。
要画什么内容是由应用的需求决定的,所以不在我们讨论的范围,我们重点关注画到哪里?用什么东西画?怎么画这些问题。iOS 上图形软件技术栈大致是这样的:UIKit graphics > Core Graphics(Quartz 2D), Core Animation > OpenGL ES。
Open GL ES 是移动版本的 OpenGL, 它能实现高性能的 2D 和 3D 图形绘制,它不是 Apple 的成果,却是 iOS 图形技术的基石。Apple 在它之上抽象封装了 Core Graphics, Core Animation 等库。大多数应用开发者主要和 2D 图形打交道,所以我们主要使用 Core Graphics,Core Animation。Core Animation 主要为应用提供动画支持,UIKit graphics 的功能相对简单,所以这里我们聚焦 Core Graphics,也称为 Quartz。
上面也可以用来回答用什么画这个问题,即我们可以用 UIKit graphics, Core Graphics, Core Animation, OpenGL ES 画,如果我们主要是绘制 2D 图形,那么使用 Core Graphics 是比较正确的选择。
画到哪里
画到哪里在 iOS 中对应 Graphic Context,我们不妨翻译为图形上下文。在 iOS 应用中有如下可用的图形上下文:bitmap graphics context,PDF graphics context,window graphics context 和 layer context。
怎么画
在 iOS 中绘画通常是先拿到一个图形上下文,然后配置它的状态,之后给它添加绘图元素,还可以给绘图元素添加效果,最后绘制或填充绘图元素。使用 layer context 绘制时稍微有点区别,它是先绘制到 layer context,之后可以使用这个整体去绘制,有点类似印章盖印。
图形上下文
window graphics context
在 iOS 应用中得到 window graphics context 的方法是继承 UIView, 并实现 drawRect:
方法,在该方法里调用 UIGraphicsGetCurrentContext 函数。
bitmap graphics context
UIGraphicsBeginImageContextWithOptions 和 CGBitmapContextCreate 都可以创建 bitmap graphics context, 我们应该优先使用 UIGraphicsBeginImageContextWithOptions, 它的抽象程度更高。
PDF graphics context
CGPDFContextCreateWithURL 和 CGPDFContextCreate 可以用来创建 PDF graphics context.
layer context
layer context 要用已有的 graphics context 调用 CGLayerCreateWithContext 来创建。
图形上下文状态
参数 |
备注 |
Current transformation matrix (CTM) |
Transforms |
Clipping area |
Paths |
Line: width, join, cap, dash, miter limit |
Paths |
Accuracy of curve estimation (flatness) |
Paths |
Anti-aliasing setting |
Graphics Contexts |
Color: fill and stroke settings |
Color and Color Spaces |
Alpha value (transparency) |
Color and Color Spaces |
Rendering intent |
Color and Color Spaces |
Color space: fill and stroke settings |
Color and Color Spaces |
Text: font, font size, character spacing, text drawing mode |
Text |
Blend mode |
Paths and Bitmap Images and Image Masks |
绘图元素
点,线,圆弧,曲线,路径,椭圆和矩形是提供的绘图元素,可以用它们组合出我们的目标图形。
效果
效果有阴影,渐变,透明图层。
阴影
Follow these steps to paint with shadows:
- Save the graphics state.
- Call the function CGContextSetShadow, passing the appropriate values.
- Perform all the drawing to which you want to apply shadows.
- Restore the graphics state.
Follow these steps to paint with colored shadows:
- Save the graphics state.
- Create a CGColorSpace object to ensure that Quartz interprets the shadow color values correctly.
- Create a CGColor object that specifies the shadow color you want to use.
- Call the function CGContextSetShadowWithColor, passing the appropriate values.
- Perform all the drawing to which you want to apply shadows.
- Restore the graphics state.
渐变
渐变有线性渐变和角度渐变。CGGradient 和 CGShading 都可以用来实现添加渐变,CGGradient 粗放点,但我们可以少写点代码;CGShading 更细腻,可以根据具体情况选择使用。
透明图层
Painting to a transparency layer requires three steps:
- Call the function CGContextBeginTransparencyLayer.
- Draw the items you want to composite in the transparency layer.
- Call the function CGContextEndTransparencyLayer.
绘制、填充
Core Graphics 提供了很多绘制和填充函数,它们的名字通常包含 stroke 或 fill,调用它们可以完成绘制和填充。
继续阅读