2014-05-22 143 views
2

请不要参考CABasicAnimation returns to the original position before the next animationObjective-C - CABasicAnimation applying changes after animation?CABasicAnimation rotate returns to original position 我已经尝试过了。CABasicAnimation在完成1个周期后回到其原始位置

below code does,bottom->top->goes left->back to it’s original position. 
bottom->top->goes left->back to its original position. 
I need bottom->top->goes left.bottom->top->goes left so on… 

-(void)addUpDownAnimationForButton:(UILabel*)label 
{ 
    CABasicAnimation * bottomAnimation ; 
    bottomAnimation =[CABasicAnimation animationWithKeyPath:@"transform.translation.y"]; 
    [bottomAnimation setValue:@"animation1" forKey:@"id"]; 
    bottomAnimation.delegate = self; 
    [UIView setAnimationDidStopSelector:@selector(animationDidStop:finished:)]; 
    bottomAnimation.duration = 2.0; 
    bottomAnimation.fromValue = [NSNumber numberWithFloat:13]; 
    bottomAnimation.toValue = [NSNumber numberWithFloat:-7]; 
    bottomAnimation.repeatCount = 0; 
    bottomAnimation.fillMode = kCAFillModeForwards; 
    bottomAnimation.removedOnCompletion = NO; 
    [btnSpecialForListing.titleLabel.layer addAnimation:bottomAnimation forKey:@"transform.translation.y"]; 
} 
- (void)animationDidStop:(CAAnimation *)theAnimation2 finished:(BOOL)flag 
{ 
    if([[theAnimation2 valueForKey:@"id"] isEqual:@"animation1"]) { 
     CABasicAnimation *moveAnimation; 
     moveAnimation=[CABasicAnimation animationWithKeyPath:@"transform.translation.x"]; 
     moveAnimation.duration=3.5; 
     moveAnimation.repeatCount=0; 
     moveAnimation.autoreverses=NO; 
     moveAnimation.fromValue=[NSNumber numberWithFloat:0]; 
     moveAnimation.toValue=[NSNumber numberWithFloat:-400]; 
     moveAnimation.removedOnCompletion = NO; 
     moveAnimation.fillMode = kCAFillModeRemoved; 
     [btnSpecialForListing.titleLabel.layer addAnimation:moveAnimation forKey:@"transform.translation.x"]; 
    } 
} 

任何帮助将不胜感激。 谢谢!

回答

3

你试过吗?

moveAnimation.fillMode = kCAFillModeForwards; 
moveAnimation.removedOnCompletion = NO; 

编辑 至于我可以看到你也可以使用animateWithDuration具有完成块。 示例如下:

CGRect rect = btnSpecialForListing.titleLabel.frame; 
[UIView animateWithDuration:2.0 animations:^{ 

rect.origin.y = -7; 
btnSpecialForListing.titleLabel.frame = rect; 

} completion:^(BOOL finished){ 

[UIView animateWithDuration:3.5 animation:^{ 
rect.origin.x = -400; 
btnSpecialForListing.titleLabel.frame = rect; 
}]; 

}]; 
+0

是的,我做了。 但是在第一个循环完成之后,只有移动动画才起作用,即文本只剩下。 但bottomAnimation的代码执行但不显示。 –

+0

那么你已经添加了moveAnimation到btnSpecialForListing.titleLabel.layer那么你到底想要做什么?我真的不知道它 – Pancho

+0

看到,我有标签上我要添加从底部开始动画(底部动画从-7到-13位置),动画1完成,然后完成底部动画,或者你可以说当底部动画停止我们的第二个动画(moveAnimation)开始并且向左移动,但在完成moveAnimation后,我的文本返回到它的原始位置,并再次开始相同的循环。 –

相关问题