使用CAShapeLayer 的 转圈圈动画

在View中添加一个加载动画
UIView *view = [[UIView alloc]initWithFrame:CGRectMake(100, 100, 100, 100)];
view.backgroundColor = [UIColor whiteColor];
[self.view addSubview:view];

CAShapeLayer *shapeLayer = [CAShapeLayer layer];
shapeLayer.frame = view.bounds;
UIBezierPath *path = [UIBezierPath bezierPathWithOvalInRect:view.bounds];
shapeLayer.path = path.CGPath;
shapeLayer.fillColor = [UIColor clearColor].CGColor;
shapeLayer.lineWidth = 2;
shapeLayer.strokeColor = [UIColor lightGrayColor].CGColor;
[view.layer addSublayer:shapeLayer];
//任何CABasicAnimation 的@keyPath 为确定的,  此处为strokeEnd
//其他keyPath 参考[Ansel_m 的博客](http://blog.csdn.net/majiakun1/article/details/46426727)
CABasicAnimation *pathAnima = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
pathAnima.duration = 1.0f;
pathAnima.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
pathAnima.fromValue = @0.05f;
pathAnima.toValue = @1.0f;
pathAnima.repeatCount = 100;
pathAnima.fillMode = kCAFillModeForwards;
pathAnima.removedOnCompletion = NO;
[shapeLayer addAnimation:pathAnima forKey:@"strokeEndAnimation"];
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值