码迷,mamicode.com
首页 > 其他好文 > 详细

画画板

时间:2017-03-07 13:11:59      阅读:133      评论:0      收藏:0      [点我收藏+]

标签:layer   屏幕   宽度   view   send   ack   back   poi   black   

使用CAShapeLayer 和 UIBezierPath 实现的画画功能。

1、首先根据触摸屏幕获取点信息:

- (CGPoint)pointWithTouches:(NSSet *)touches
{
    UITouch *touch = [touches anyObject];
    
    return [touch locationInView:self];
}

 

2、 重写响应方法:

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
- (void)touchesMoved:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
- (void)touchesEnded:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event

3、绘制:

在- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event 中使用CAShapeLayer 和 UIBezierPath 绘制。

CAShapeLayer:

   CAShapeLayer * slayer = [CAShapeLayer layer];
        slayer.path = path.CGPath;
        slayer.backgroundColor = [UIColor clearColor].CGColor;
        slayer.fillColor = [UIColor clearColor].CGColor; //颜色
        slayer.lineCap = kCALineCapRound;
        slayer.lineJoin = kCALineJoinRound;
        slayer.strokeColor = [UIColor blackColor].CGColor;
        slayer.lineWidth = path.lineWidth; // 宽度
        [self.layer addSublayer:slayer];

UIBezierPath:

    UIBezierPath * path = [[UIBezierPath alloc] init];
    path.lineWidth = width;
    path.lineCapStyle = kCGLineCapRound; //线条拐角
    path.lineJoinStyle = kCGLineCapRound; //终点处理
    [path moveToPoint:startPoint];

 

画画板

标签:layer   屏幕   宽度   view   send   ack   back   poi   black   

原文地址:http://www.cnblogs.com/liuziyu/p/6513896.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!