iOS - CATransition 问题 : showing end image at start

标签 ios core-animation catransition

在我的 UIViewController 中,我使用 image1 创建了 CALayer

CALayer *imageLayer = [CALayer layer];
[imageLayer setBounds:CGRectMake(0.0, 0.0, 241.0, 430.0)];
[imageLayer setPosition:CGPointMake(160.0, 60.0)];
[imageLayer setAnchorPoint:CGPointMake(0.5, 0.0)];
[imageLayer setContents:(id)[UIImage imageNamed:@"image1.png".CGImage];
[imageLayer setContentsGravity:kCAGravityResizeAspect];
[self.view.layer addSublayer:imageLayer];

稍后在 UIViewController 中,我想通过使用 CATransition 推送它来更改图像。

CATransition *t = [CATransition animation];
t.beginTime = [self.view.layer convertTime:CACurrentMediaTime() + 6.5 fromLayer:nil];
t.type = kCATransitionPush;
t.subtype = kCATransitionFromRight;
[imageLayer setContents:(id)[UIImage imageNamed:@"image2.png"].CGImage];    
[imageLayer addAnimation:t forKey:nil];

当运行代码时,我从一开始就得到了 image2,过渡通过在 6.5 秒后推送自身来工作。 图1在哪里?怎么了?

正确答案: 感谢 Jacky Boy 和 Tiago Almeida。 我更正了删除行的代码

t.beginTime = [self.view.layer convertTime:CACurrentMediaTime() + 6.5 fromLayer:nil];

并添加“dispatch_after”。

现在可以了:

CATransition *t = [CATransition animation];
t.type = kCATransitionPush;
t.subtype = kCATransitionFromRight;
[imageLayer setContents:(id)[UIImage imageNamed:@"image2.png"].CGImage];    
[imageLayer addAnimation:t forKey:nil];
[CATransaction begin];
NSTimeInterval delayInSeconds = 6.5;
dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, delayInSeconds * NSEC_PER_SEC);
dispatch_after(popTime, dispatch_get_main_queue(), ^(void){
    [imageLayer setContents:(id)[UIImage imageNamed:@"image2.png"].CGImage];
    [imageLayer addAnimation:t forKey:nil];
});
[CATransaction commit];

再次感谢大家!

最佳答案

删除以下行:

t.beginTime = [self.view.layer convertTime:CACurrentMediaTime() + 1.5 fromLayer:nil];

这就是延迟动画,所以层正在设置新的内容,并且只有在层被动画化之后。如果要指定动画的持续时间:

[CATransaction begin];
[CATransaction setAnimationDuration:1.0];

CATransition *t = [CATransition animation];
t.type = kCATransitionPush;
t.subtype = kCATransitionFromRight;
[_layer setContents:(id)[UIImage imageNamed:@"image2.jpg"].CGImage];
[_layer addAnimation:t forKey:nil];


[CATransaction commit];

或更小的版本:

CATransition *t = [CATransition animation];
t.type = kCATransitionPush;
[t setDuration:2.5];
t.subtype = kCATransitionFromRight;
[_layer setContents:(id)[UIImage imageNamed:@"image2.jpg"].CGImage];
[_layer addAnimation:t forKey:nil];

我更喜欢这个:

CATransition *transition = [CATransition animation];
transition.type = kCATransitionPush;
transition.duration = .25f;
transition.subtype = kCATransitionFromRight;

_layer.actions = @{@"contents": transition};

当你想改变内容时:

[_layer setContents:(id)[UIImage imageNamed:@"image2.jpg"].CGImage];

关于iOS - CATransition 问题 : showing end image at start,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21164305/

相关文章:

ios - 如何添加构建脚本 Xcode 5?

swift - 自定义 segue 过渡动画

ios - CATransition 动画在 iOS 中花费很长时间

ios - CATransition 在过渡期间淡化黑色

objective-c - 如何加载驻留在我的应用程序文件夹中的文件的内容?

ios - 从 plist 中读取数组,只有在找到匹配项时才返回项目

ios - UICollectionView 单元格布局超出了 Collection View 的边界

ios - 如何在 objective-c 中绘制半圆形图层的切片

iOS "slide in from left/right"查看动画

ios - 谁能弄清楚如何手动触发这个饼图(XYPieChart)的动画?