iOS 环绕动画 CAReplicatorLayer

@implementation ViewController
{
    CAReplicatorLayer *_replicatorLayer;
    UIView *_earthView;;
    
}
- (void)viewWillAppear:(BOOL)animated{
    [super viewWillAppear:animated];
    UIBezierPath *bezierPath = [UIBezierPath bezierPath];
    [bezierPath addArcWithCenter:CGPointMake(self.view.center.x, self.view.center.y) radius:150 startAngle:0 endAngle:M_PI * 2 clockwise:YES];
    [bezierPath closePath];
    CAKeyframeAnimation *animation = [CAKeyframeAnimation animation];
    animation.keyPath = @"position";
    animation.path = bezierPath.CGPath;
    animation.duration = 10;
    animation.repeatCount = MAXFLOAT;
    _replicatorLayer.instanceCount = 1; // 创建实例个数
    _replicatorLayer.instanceDelay = 0;
    [self.view.layer addSublayer:_replicatorLayer];
    [_earthView.layer addAnimation:animation forKey:nil];
}
- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor = [UIColor grayColor];
    
    _replicatorLayer = [[CAReplicatorLayer alloc] init];
    
    _earthView  = [[UIView alloc] initWithFrame:CGRectMake(50, 100, 50, 50)];
    _earthView.backgroundColor = [UIColor greenColor];
    _earthView.layer.masksToBounds = YES;
    _earthView.layer.cornerRadius = 25;
    [self.view addSubview:_earthView];
    
    UIView *sunView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 100, 100)];
    sunView.layer.masksToBounds = YES;
    sunView.layer.cornerRadius = 50;
    sunView.backgroundColor = [UIColor redColor];
    sunView.center = self.view.center;
    [self.view addSubview:sunView];
    [_replicatorLayer addSublayer:_earthView.layer];
    [_replicatorLayer addSublayer:sunView.layer];
    }

话不多说直接代码


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值