封装CoreGraphics的API简化绘图操作

效果

说明

1. 将CoreGraphics的API接口抽象为对象,让绘图变得简单易懂

2. 简化常用的绘制操作

3. 源码长期更新

源码

https://github.com/YouXianMing/CGContextObject

//
// CGContextObject.h
// DrawRect
//
// Created by YouXianMing on 15/7/2.
// Copyright (c) 2015年 YouXianMing. All rights reserved.
// #import <Foundation/Foundation.h>
#import <CoreGraphics/CoreGraphics.h>
#import "RGBColor.h"
#import "GradientColor.h"
@class CGContextObject; typedef void(^CGContextObjectDrawBlock_t)(CGContextObject *contextObject); @interface CGContextObject : NSObject /**
* 操作句柄
*/
@property (nonatomic) CGContextRef context; /**
* 线头样式
*/
@property (nonatomic) CGLineCap lineCap; /**
* 线条宽度
*/
@property (nonatomic) CGFloat lineWidth; /**
* 线条颜色
*/
@property (nonatomic, strong) RGBColor *strokeColor; /**
* 填充颜色
*/
@property (nonatomic, strong) RGBColor *fillColor; /**
* 由context进行初始化
*
* @param context 绘制句柄
*
* @return 绘制对象
*/
- (instancetype)initWithCGContext:(CGContextRef)context; #pragma mark - 绘制操作流程
/**
* 开始path
*/
- (void)beginPath; /**
* 关闭path
*/
- (void)closePath; /**
* 线条绘制
*/
- (void)strokePath; /**
* 填充绘制
*/
- (void)fillPath; /**
* 线条绘制 + 填充绘制
*/
- (void)strokeAndFillPath; /**
* 绘制线条用block (beginPath + closePath + 你绘制的代码 + strokePath)
*
* @param block 绘制用block
*/
- (void)drawStrokeBlock:(CGContextObjectDrawBlock_t)block; /**
* 填充区域用block (beginPath + closePath + 你绘制的代码 + fillPath)
*
* @param block 填充用block
*/
- (void)drawFillBlock:(CGContextObjectDrawBlock_t)block; /**
* 绘制加填充
*
* @param block 绘制加填充用block
*/
- (void)drawStrokeAndFillBlock:(CGContextObjectDrawBlock_t)block; /**
* 绘制线条用block (beginPath + closePath + 你绘制的代码 + strokePath)
*
* @param block 绘制用block
* @param closePath 是否关闭曲线
*/
- (void)drawStrokeBlock:(CGContextObjectDrawBlock_t)block closePath:(BOOL)closePath; /**
* 填充区域用block (beginPath + closePath + 你绘制的代码 + fillPath)
*
* @param block 绘制用block
* @param closePath 是否关闭曲线
*/
- (void)drawFillBlock:(CGContextObjectDrawBlock_t)block closePath:(BOOL)closePath; /**
* 绘制加填充
*
* @param block 绘制用block
* @param closePath 是否关闭曲线
*/
- (void)drawStrokeAndFillBlock:(CGContextObjectDrawBlock_t)block closePath:(BOOL)closePath; #pragma mark - 绘制图片API - (void)drawImage:(UIImage *)image atPoint:(CGPoint)point;
- (void)drawImage:(UIImage *)image atPoint:(CGPoint)point blendMode:(CGBlendMode)blendMode alpha:(CGFloat)alpha;
- (void)drawImage:(UIImage *)image inRect:(CGRect)rect;
- (void)drawImage:(UIImage *)image inRect:(CGRect)rect blendMode:(CGBlendMode)blendMode alpha:(CGFloat)alpha;
- (void)drawImage:(UIImage *)image asPatternInRect:(CGRect)rect; #pragma mark - 保存操作 /**
* 将当前设置存取到栈区中(入栈操作)
*/
- (void)saveStateToStack; /**
* 从栈区中取出之前保存的设置(出栈操作)
*/
- (void)restoreStateFromStack; #pragma mark - 图形绘制API
/**
* 移动到起始点
*
* @param point 起始点
*/
- (void)moveToStartPoint:(CGPoint)point; /**
* 添加一个点(与上一个点直线相连)
*
* @param point 点
*/
- (void)addLineToPoint:(CGPoint)point; /**
* 添加二次贝塞尔曲线
*
* @param point 结束点
* @param pointOne 控制点1
* @param pointTwo 控制点2
*/
- (void)addCurveToPoint:(CGPoint)point controlPointOne:(CGPoint)pointOne controlPointTwo:(CGPoint)pointTwo; /**
* 添加一次贝塞尔曲线
*
* @param point 结束点
* @param controlPoint 控制点
*/
- (void)addQuadCurveToPoint:(CGPoint)point controlPoint:(CGPoint)controlPoint; /**
* 在指定的区域填充彩色的矩形(此为直接绘制)
*
* @param rect 指定的区域
* @param gradientColor 渐变色对象
*/
- (void)drawLinearGradientAtClipToRect:(CGRect)rect gradientColor:(GradientColor *)gradientColor; #pragma mark -
/**
* 添加一个矩形
*
* @param rect
*/
- (void)addRect:(CGRect)rect; /**
* 在给定的矩形中绘制椭圆
*
* @param rect
*/
- (void)addEllipseInRect:(CGRect)rect; /**
* 将string绘制在指定的点上
*
* @param string 字符串
* @param point 点
* @param attributes 富文本设置(可以为空)
*/
- (void)drawString:(NSString *)string atPoint:(CGPoint)point withAttributes:(NSDictionary *)attributes; /**
* 将string绘制在制定的区域
*
* @param string 字符串
* @param rect 区域
* @param attributes 富文本设置(可以为空)
*/
- (void)drawString:(NSString *)string inRect:(CGRect)rect withAttributes:(NSDictionary *)attributes; /**
* 将富文本绘制在制定的点上
*
* @param string 富文本
* @param point 点
*/
- (void)drawAttributedString:(NSAttributedString *)string atPoint:(CGPoint)point; /**
* 将富文本绘制在制定的矩形中
*
* @param string 富文本
* @param rect 矩形
*/
- (void)drawAttributedString:(NSAttributedString *)string inRect:(CGRect)rect; @end
//
// CGContextObject.m
// DrawRect
//
// Created by YouXianMing on 15/7/2.
// Copyright (c) 2015年 YouXianMing. All rights reserved.
// #import "CGContextObject.h" @interface CGContextObject () @end @implementation CGContextObject - (instancetype)initWithCGContext:(CGContextRef)context { self = [super init];
if (self) { self.context = context;
} return self;
} - (void)moveToStartPoint:(CGPoint)point { if (_context) {
CGContextMoveToPoint(_context, point.x, point.y);
}
} - (void)addLineToPoint:(CGPoint)point { if (_context) {
CGContextAddLineToPoint(_context, point.x, point.y);
}
} - (void)addCurveToPoint:(CGPoint)point controlPointOne:(CGPoint)pointOne controlPointTwo:(CGPoint)pointTwo { if (_context) {
CGContextAddCurveToPoint(_context, pointOne.x, pointOne.y, pointTwo.x, pointTwo.y, point.x, point.y);
}
} - (void)addQuadCurveToPoint:(CGPoint)point controlPoint:(CGPoint)controlPoint { if (_context) {
CGContextAddQuadCurveToPoint(_context, controlPoint.x, controlPoint.y, point.x, point.y);
}
} - (void)drawLinearGradientAtClipToRect:(CGRect)rect gradientColor:(GradientColor *)gradientColor { [self saveStateToStack]; if (_context) { CGContextClipToRect(_context, rect); CGContextDrawLinearGradient(_context,
gradientColor.gradientRef,
gradientColor.gradientStartPoint,
gradientColor.gradientEndPoint, kCGGradientDrawsBeforeStartLocation);
} [self restoreStateFromStack];
} - (void)addRect:(CGRect)rect { if (_context) {
CGContextAddRect(_context, rect);
}
} - (void)addEllipseInRect:(CGRect)rect { if (_context) {
CGContextAddEllipseInRect(_context, rect);
}
} - (void)drawString:(NSString *)string atPoint:(CGPoint)point withAttributes:(NSDictionary *)attributes { [string drawAtPoint:point withAttributes:attributes];
} - (void)drawString:(NSString *)string inRect:(CGRect)rect withAttributes:(NSDictionary *)attributes { [string drawInRect:rect withAttributes:attributes];
} - (void)drawAttributedString:(NSAttributedString *)string atPoint:(CGPoint)point { [string drawAtPoint:point];
} - (void)drawAttributedString:(NSAttributedString *)string inRect:(CGRect)rect { [string drawInRect:rect];
} - (void)beginPath { if (_context) {
CGContextBeginPath(_context);
}
} - (void)closePath { if (_context) {
CGContextClosePath(_context);
}
} - (void)strokePath { if (_context) {
CGContextStrokePath(_context);
}
} - (void)fillPath { if (_context) {
CGContextFillPath(_context);
}
} - (void)strokeAndFillPath { if (_context) {
CGContextDrawPath(_context, kCGPathFillStroke);
}
} - (void)drawStrokeBlock:(CGContextObjectDrawBlock_t)block { [self beginPath]; __weak CGContextObject *weakSelf = self; block(weakSelf); [self closePath]; [self strokePath];
} - (void)drawFillBlock:(CGContextObjectDrawBlock_t)block { [self beginPath]; __weak CGContextObject *weakSelf = self; block(weakSelf); [self closePath]; [self fillPath];
} - (void)drawStrokeAndFillBlock:(CGContextObjectDrawBlock_t)block { [self beginPath]; __weak CGContextObject *weakSelf = self; block(weakSelf); [self closePath]; [self strokeAndFillPath];
} - (void)drawStrokeBlock:(CGContextObjectDrawBlock_t)block closePath:(BOOL)closePath { [self beginPath]; __weak CGContextObject *weakSelf = self; block(weakSelf); if (closePath) {
[self closePath];
} [self strokePath];
} - (void)drawFillBlock:(CGContextObjectDrawBlock_t)block closePath:(BOOL)closePath { [self beginPath]; __weak CGContextObject *weakSelf = self; block(weakSelf); if (closePath) {
[self closePath];
} [self fillPath];
} - (void)drawStrokeAndFillBlock:(CGContextObjectDrawBlock_t)block closePath:(BOOL)closePath { [self beginPath]; __weak CGContextObject *weakSelf = self; block(weakSelf); if (closePath) {
[self closePath];
} [self strokeAndFillPath];
} - (void)drawImage:(UIImage *)image atPoint:(CGPoint)point { [image drawAtPoint:point];
} - (void)drawImage:(UIImage *)image atPoint:(CGPoint)point blendMode:(CGBlendMode)blendMode alpha:(CGFloat)alpha { [image drawAtPoint:point blendMode:blendMode alpha:alpha];
} - (void)drawImage:(UIImage *)image inRect:(CGRect)rect { [image drawInRect:rect];
} - (void)drawImage:(UIImage *)image inRect:(CGRect)rect blendMode:(CGBlendMode)blendMode alpha:(CGFloat)alpha { [image drawInRect:rect blendMode:blendMode alpha:alpha];
} - (void)drawImage:(UIImage *)image asPatternInRect:(CGRect)rect { [image drawAsPatternInRect:rect];
} - (void)saveStateToStack { if (_context) {
CGContextSaveGState(_context);
}
} - (void)restoreStateFromStack { if (_context) {
CGContextRestoreGState(_context);
}
} #pragma mark - 重写setter,getter方法
@synthesize strokeColor = _strokeColor;
- (void)setStrokeColor:(RGBColor *)strokeColor { if (_context) { _strokeColor = strokeColor;
CGContextSetRGBStrokeColor(_context, strokeColor.red, strokeColor.green, strokeColor.blue, strokeColor.alpha);
}
}
- (RGBColor *)strokeColor { return _strokeColor;
} @synthesize fillColor = _fillColor;
- (void)setFillColor:(RGBColor *)fillColor { if (_context) { _fillColor = fillColor;
CGContextSetRGBFillColor(_context, fillColor.red, fillColor.green, fillColor.blue, fillColor.alpha);
}
}
- (RGBColor *)fillColor { return _fillColor;
} @synthesize lineWidth = _lineWidth;
- (void)setLineWidth:(CGFloat)lineWidth { if (_context) { _lineWidth = lineWidth;
CGContextSetLineWidth(_context, lineWidth);
}
}
- (CGFloat)lineWidth { return _lineWidth;
} @synthesize lineCap = _lineCap;
- (void)setLineCap:(CGLineCap)lineCap { if (_context) { _lineCap = lineCap;
CGContextSetLineCap(_context, lineCap);
} }
- (CGLineCap)lineCap { return _lineCap;
} @end

细节

封装CoreGraphics的API简化绘图操作的更多相关文章

  1. javaCV入门指南:调用FFmpeg原生API和JavaCV是如何封装了FFmpeg的音视频操作?

    通过"javaCV入门指南:序章 "大家知道了处理音视频流媒体的前置基本知识,基本知识包含了像素格式.编解码格式.封装格式.网络协议以及一些音视频专业名词,专业名词不会赘述,自行搜 ...

  2. 八:SpringBoot-集成JPA持久层框架,简化数据库操作

    SpringBoot-集成JPA持久层框架,简化数据库操作 1.JPA框架简介 1.1 JPA与Hibernate的关系: 2.SpringBoot整合JPA Spring Data JPA概述: S ...

  3. 深入浅出话VC++(3)——VC++实现绘图操作

    VC++实现绘图操作,说白了也就是对API熟练操作了,下面介绍几种绘图 1. 绘制线条 具体实现代码如下: // 鼠标左键按下时的处理函数 void CDrawView::OnLButtonDown( ...

  4. 利用SolrJ操作solr API完成index操作

    使用SolrJ操作Solr会比利用httpClient来操作Solr要简单.SolrJ是封装了httpClient方法,来操作solr的API的.SolrJ底层还是通过使用httpClient中的方法 ...

  5. HBase篇--HBase操作Api和Java操作Hbase相关Api

    一.前述. Hbase shell启动命令窗口,然后再Hbase shell中对应的api命令如下. 二.说明 Hbase shell中删除键是空格+Ctrl键. 三.代码 1.封装所有的API pa ...

  6. C# 使用 Index 和 Range 简化集合操作

    C# 使用 Index 和 Range 简化集合操作 Intro 有的语言数组的索引值是支持负数的,表示从后向前索引,比如:arr[-1] 从 C# 8 开始,C# 支持了数组的反向 Index,和 ...

  7. Web API与文件操作

    前段时间,一直有练习ASP.NET MVC与Web API交互,接下来,Insus.NET再做一些相关的练习,Web API与文件操作,如POST文件至Web API,更新或是删除等. 不管怎样,先在 ...

  8. Java封装自己的Api

    转自:http://www.2cto.com/kf/201404/291555.html 随着学习的深入,我们都想封装自己的Api,但对于新手这并不是一件简单容易的事! 我要达到的效果:自己封装一些方 ...

  9. Asp.Net Web API 2(CRUD操作)第二课

    Asp.Net Web API 2(CRUD操作)第二课 Asp.Net Web API 导航   Asp.Net Web API第一课:入门http://www.cnblogs.com/aehyok ...

随机推荐

  1. 数据分析--降维--LDA和PCA

    一.因子分析 因子分析是将具有错综复杂关系的变量(或样本)综合为少数几个因子,以再现原始变量和因子之间的相互关系,探讨多个能够直接测量,并且具有一定相关性的实测指标是如何受少数几个内在的独立因子所支配 ...

  2. 使用Java设计验证码生成程序

    我们来设计一个简单的验证码生成程序:验证码一个由4位的数字.字母随机组合而成图像,为了避免被光学字元识别(OCR,Optical Character Recognition)之类的程序识别出图片中的数 ...

  3. ANTLR4权威指南 - 第7章 通过特定应用程序代码解耦语法

    第7章 通过特定应用程序代码解耦语法 到目前为止,我们已经知道了怎么用ANTLR的语法来定义语言了,接下来我们要给我们的语法注入一些新的元素了.就语法本身而言,其用处并不大,因为它只能告诉我们一个用户 ...

  4. 深入了解Java虚拟机(3)类文件结构

    虚拟机执行子系统 一.类文件结构 1.魔数和class版本 1.magic-魔数:0xCAFEBABE:4字节 2.minor_version:次版本,丶之后的数字:2字节 3.major_versi ...

  5. win7 iis7 asp.net 编译器错误消息: CS0016:

    编译器错误消息: CS0016: 未能写入输出文件“c:/Windows/Microsoft.NET/Framework/v2.0.50727/Temporary ASP.NET Files/root ...

  6. AngularJS内建服务以及自定义服务的用法

    在AngularJS中, 服务是一个比较重要的部分,它是一个对象或者是函数,可以在你的AngularJS的应用中使用.接下来介绍几种比较常用的内建服务以及自定义服务的方法. [内建服务] (1)loc ...

  7. mvc 提交Html内容的处理

    默认   方法1 [ValidateInput(false)] 这个方法会完全开放,对于有些字段允许,有些字段不允许的情况,是不会检测的   方法2 [AllowHtml] 此方法只有再使用Defau ...

  8. win10 uwp 让焦点在点击在页面空白处时回到textbox中

    在网上 有一个大神问我这样的问题:在做UWP的项目,怎么能让焦点在点击在页面空白处时回到textbox中? 虽然我的小伙伴认为他这是一个 xy 问题,但是我还是回答他这个问题. 首先需要知道什么是空白 ...

  9. Jquery链式编程及Index()详解

    Jquery中的方法基本 上都可以返回一个Jquery对象, 如: <body> <div class="divcontent"> <p>中国& ...

  10. js中的深浅拷贝

    js中的深浅拷贝 js中有深拷贝.浅拷贝一说,所谓的深浅拷贝是针对value类型为引用类型(函数.对象.数组)而言的,大概理解的就是: 浅拷贝: 拷贝出的对象c和原始对象o,c和o在key对应的val ...