UIBezierPath和CABasicAnimation画一条从左至右有动画的线,画曲线

  根据转载文章改写

动态 画从左到右的直线

   UIBezierPath *path = [UIBezierPath bezierPath];
    [path moveToPoint:(CGPointMake(30, 100))];
    [path addLineToPoint:(CGPointMake(300, 100))];
    
    CAShapeLayer *shaperLayer = [CAShapeLayer layer];
//    shaperLayer.frame = CGRectMake(30, 100, 300, 20);
//    shaperLayer.backgroundColor = [UIColor yellowColor].CGColor;
//    shaperLayer.fillColor = [UIColor blueColor].CGColor;
    shaperLayer.path = path.CGPath;
    shaperLayer.strokeColor = [UIColor redColor].CGColor;
    
    
    CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:NSStringFromSelector(@selector(strokeEnd))];
    anim.fromValue = @0;
    anim.toValue = @1;
    anim.duration = 5;
    
    [shaperLayer addAnimation:anim forKey:NSStringFromSelector(@selector(strokeEnd))];
    [self.view.layer addSublayer:shaperLayer];
   


画曲线


    UIBezierPath *path = [UIBezierPath bezierPath];

    [path moveToPoint:CGPointMake(20, 300)];
    [path addQuadCurveToPoint:CGPointMake(300, 300)
                 controlPoint:CGPointMake(100, 100)];

    path.lineCapStyle = kCGLineCapRound;
    path.lineJoinStyle = kCGLineJoinRound;
    path.lineWidth = 5.0;

    
    CAShapeLayer *shaperLayer = [CAShapeLayer layer];
    shaperLayer.path = path.CGPath;
    shaperLayer.strokeColor = [UIColor redColor].CGColor;
    shaperLayer.fillColor = [UIColor yellowColor].CGColor;
    
    
    CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:NSStringFromSelector(@selector(strokeEnd))];
    anim.fromValue = @0;
    anim.toValue = @1;
    anim.duration = 1;
    
    [shaperLayer addAnimation:anim forKey:NSStringFromSelector(@selector(strokeEnd))];
    
    [self.view.layer addSublayer:shaperLayer];



转载文章

//view 是曲线的背景 view

UIView *view = [[ UIView alloc ] initWithFrame : CGRectMake ( 10 , 0 ,300 ,300 )];

    view. backgroundColor = [ UIColor whiteColor];

[ self . view addSubview :view];

// 第一、 UIBezierPath 绘制线段

    UIBezierPath *firstPath = [ UIBezierPath bezierPathWithOvalInRect : CGRectMake (0,0, 5 , 5 )];

CGPoint p1 = CGPointMake ( 0 , 0 );

CGPoint p2 = CGPointMake ( 300 , 0 );

[firstPath addLineToPoint :p1];

[firstPath addLineToPoint :p2];

    UIBezierPath *lastPath = [ UIBezierPath bezierPathWithOvalInRect : CGRectMake (300,0, 0 , 0 )];

[firstPath appendPath :lastPath];

// 第二、 UIBezierPath 和 CAShapeLayer 关联

    CAShapeLayer *lineLayer2 = [ CAShapeLayer layer ];

lineLayer2. frame = CGRectMake ( 0 ,50 ,320 ,40 );

lineLayer2. fillColor = [ UIColor yellowColor ].CGColor ;

lineLayer2. path = firstPath. CGPath ;

    lineLayer2. strokeColor = [ UIColor redColor ]. CGColor ;

//第三,动画

    CABasicAnimation *ani = [ CABasicAnimation animationWithKeyPath : NSStringFromSelector ( @selector (strokeEnd))];

ani. fromValue = @0 ;

ani. toValue = @1 ;

ani. duration = 5 ;

    [lineLayer2 addAnimation :ani forKey : NSStringFromSelector ( @selector (strokeEnd))];

[view. layer addSublayer :lineLayer2];

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值