9

我一直在尝试使用 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"];

我有两个问题:

  1. 复制的图层从终点开始。
  2. 当主图层到达他的最后一个动画点时,动画停止并且复制的图层无法完成它们的动画。
4

1 回答 1

5

为动画对象的 fillMode 和 removedOnCompletion 属性设置正确的值将有望解决您的问题:

“复制的图层从终点开始。”

这是由分配给instanceDelay属性的值引起的,它在您的示例中将动画延迟了 0.15 秒。要从 fromValue 呈现动画,您需要通过将动画的 fillMode 设置为 kCAFillModeBackwards 来解决此延迟问题。

animation.fillMode = kCAFillModeBackwards;

“当主图层到达他的最后一个动画点时,动画停止并且复制的图层无法完成动画。”

发生这种情况是因为默认情况下“动画在完成后从目标层的动画中删除”。1 . 您可以通过将动画属性 removedOnCompletion 设置为 NO 来覆盖此默认行为。

animation.removedOnCompletion = NO;

希望这可以帮助。:)

于 2012-10-05T23:30:25.930 回答