話不多說,直接上代碼
.h文件
#import <UIKit/UIKit.h>
@interface XASignatureView : UIView
/**
* 畫布
*/
{
CGPoint _start;
CGPoint _move;
CGMutablePathRef _path;
NSMutableArray *_pathArray;
CGFloat _lineWidth;
UIColor *_color;
}
@property (nonatomic,assign)CGFloat lineWidth;/**< 線寬 */
@property (nonatomic,strong)UIColor *color;/**< 線的顏色 */
@property (nonatomic,strong)NSMutableArray *pathArray;
/**
獲取繪制的圖片
@return 繪制的圖片
*/
-(UIImage*)getDrawingImg;
/**
撤銷
*/
-(void)undo;
/**
清空
*/
-(void)clear;
@end
.m文件
#import "XASignatureView.h"
@implementation XASignatureView
/*
// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
- (void)drawRect:(CGRect)rect {
// Drawing code
}
*/
- (instancetype)initWithFrame:(CGRect)frame {
if (self = [super initWithFrame:frame]) {
_move = CGPointMake(0, 0);
_start = CGPointMake(0, 0);
_lineWidth = 2;
_color = [UIColor redColor];
_pathArray = [NSMutableArray array];
}
return self;
}
- (void)drawRect:(CGRect)rect {
// 獲取圖形上下文
CGContextRef context = UIGraphicsGetCurrentContext();
[self drawPicture:context]; //畫圖
}
- (void)drawPicture:(CGContextRef)context {
for (NSArray * attribute in _pathArray) {
//將路徑添加到上下文中
CGPathRef pathRef = (__bridge CGPathRef)(attribute[0]);
CGContextAddPath(context, pathRef);
//設置上下文屬性
[attribute[1] setStroke];
CGContextSetLineWidth(context, [attribute[2] floatValue]);
//繪制線條
CGContextDrawPath(context, kCGPathStroke);
}
}
- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event {
UITouch *touch = [touches anyObject];
//創(chuàng)建路徑
_path = CGPathCreateMutable();
NSArray *attributeArry = @[(__bridge id)(_path),_color,[NSNumber numberWithFloat:_lineWidth]];
//路徑及屬性數(shù)組數(shù)組
[_pathArray addObject:attributeArry];
//起始點
_start = [touch locationInView:self];
CGPathMoveToPoint(_path, NULL,_start.x, _start.y);
}
- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {
//釋放路徑
CGPathRelease(_path);
}
- (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event {
UITouch *touch = [touches anyObject];
_move = [touch locationInView:self];
//將點添加到路徑上
CGPathAddLineToPoint(_path, NULL, _move.x, _move.y);
[self setNeedsDisplay];
}
/**
獲取簽名圖片
@return image
*/
-(UIImage *)getDrawingImg{
if (_pathArray.count) {
UIGraphicsBeginImageContext(self.frame.size);
CGContextRef context = UIGraphicsGetCurrentContext();
UIRectClip(CGRectMake(0, 0, self.frame.size.width, self.frame.size.height));
[self.layer renderInContext:context];
UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
return image;
}
return nil;
}
/**
撤銷
*/
-(void)undo
{
[_pathArray removeLastObject];
[self setNeedsDisplay];
}
/**
清空
*/
-(void)clear
{
[_pathArray removeAllObjects];
[self setNeedsDisplay];
}
@end
直接引用調(diào)用即可
XASignatureView *signatureView = [[XASignatureView alloc] init];
[self.view addSubview:signatureView];
signatureView.frame = CGRectMake(0, 100, 200, 200);

image.png