Я пытался создать крутой текстовый эффект с помощью CAReplicatorlayer, CATextLayer и очень простых анимаций. Я пытаюсь сделать так, чтобы буквы выглядели так, как будто они сбрасываются с верхней части экрана, а затем появляются крутые репликаторы, которые становятся все менее и менее заметными. Мне удалось сделать этот эффект, но не полностью.
Пока это то, что у меня есть:
CATextLayer *messageLayer = [CATextLayer layer];
[messageLayer setForegroundColor:[[UIColor blackColor] CGColor]];
[messageLayer setContentsScale:[[UIScreen mainScreen] scale]];
[messageLayer setFrame:CGRectMake(0, 0, 40, 40)];
[messageLayer setString:@"A"];
CAReplicatorLayer *replicatorX = [CAReplicatorLayer layer];
//Set the replicator's attributes
replicatorX.frame = CGRectMake(0, 0, 40, 40);
replicatorX.anchorPoint = CGPointMake(0,0);
replicatorX.position = CGPointMake(0, 0);
replicatorX.instanceCount = 9;
replicatorX.instanceDelay = 0.15;
replicatorX.instanceAlphaOffset = -0.1;
replicatorX.zPosition = 200;
replicatorX.anchorPointZ = -160;
[replicatorX addSublayer:messageLayer];
[self.view.layer addSublayer:replicatorX];
messageLayer.position = CGPointMake(40, 400);
CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"position.y"];
animation.fromValue = [NSNumber numberWithInt:0];;
animation.toValue = [NSNumber numberWithInt:400];
animation.duration = 3;
[messageLayer addAnimation:animation forKey:@"s"];
У меня две проблемы:
- Реплицированные слои начинаются в конечной точке.
- Когда основной слой достигает своей последней анимированной точки, анимация останавливается, и реплицированные слои не могут закончить свою анимацию.