开发者社区> ghost丶桃子> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

暂停、恢复CALayer 动画

简介:
+关注继续查看

CALayer都是实现了CAMediaTiming协议(或者叫做接口)。所以layer的动画有一个很有意思的属性speed。如果一个layer的动画速度变成0.0的时候,很显然这个动画就不再动了。设置layer的speed为0时,layer的动画暂停。speed属性设置为任意大于0的值时,动画回复。

要暂停一个动画时:

-(void)pauseLayer:(CALayer*)layer {
   CFTimeInterval pausedTime = [layer convertTime:CACurrentMediaTime() fromLayer:nil];
   layer.speed = 0.0;
   layer.timeOffset = pausedTime;
}

恢复一个动画:

复制代码
-(void)resumeLayer:(CALayer*)layer {
   CFTimeInterval pausedTime = [layer timeOffset];
   layer.speed = 1.0;
   layer.timeOffset = 0.0;
   layer.beginTime = 0.0;
   CFTimeInterval timeSincePause = [layer convertTime:CACurrentMediaTime() fromLayer:nil] - pausedTime;
   layer.beginTime = timeSincePause;
}
复制代码

比如你有这么一个在ImageView上执行的动画,你想让这个动画开始执行后点击按钮暂停,在点击按钮恢复就可以这样:

复制代码
CABasicAnimation *sizeAnim = [CABasicAnimation animationWithKeyPath:@"transform"];
        sizeAnim.fromValue = [NSValue valueWithCATransform3D:CATransform3DIdentity];
        sizeAnim.toValue = [NSValue valueWithCATransform3D:CATransform3DMakeScale(1.5f, 1.5f, 1.f)];
        sizeAnim.duration = .2f;
        sizeAnim.fillMode = kCAFillModeForwards;
        sizeAnim.removedOnCompletion = YES;
        sizeAnim.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
        [self.collectionImageView.layer addAnimation:sizeAnim forKey:@"size"];
        
        CAKeyframeAnimation *shakeAnim = [CAKeyframeAnimation animationWithKeyPath:@"transform.rotation.z"];
        shakeAnim.values = @[@(M_PI/6), @(-M_PI/6),@(M_PI/6)/*, @(-M_PI/6)*/];
        shakeAnim.timingFunctions = @[[self getTiming:kCAMediaTimingFunctionLinear]
                                      , [self getTiming:kCAMediaTimingFunctionLinear]
                                      ,[self getTiming:kCAMediaTimingFunctionLinear]];
        shakeAnim.duration = .2f;
//        shakeAnim.beginTime = CACurrentMediaTime() + sizeAnim.duration;
        [self.collectionImageView.layer addAnimation:shakeAnim forKey:@"shake"];
复制代码

上面说的ImageView可以通过self.collectionImageView来访问。这里设置的执行时间都不是很长,在实验的时候最好把动画的执行时间设置的长点。

暂停&恢复的代码:

复制代码
static BOOL animationStoped = NO;
- (IBAction)animationAction:(id)sender {
    if (!animationStoped) {
        [self pauseLayer:self.collectionImageView.layer];
//        animationStoped = YES;
    }
    else{
        [self resumeLayer:self.collectionImageView.layer];
    }
    animationStoped = !animationStoped;
}
复制代码

 

欢迎加群互相学习,共同进步。QQ群:iOS: 58099570 | Android: 330987132 | Go:217696290 | Python:336880185 | 做人要厚道,转载请注明出处!

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
用tar备份和恢复Linux系统
其实备份系统平时看来可能用处不大,因为一般平时无论是数据库,还是应用,都会做自己的备份。实在系统坏了,也可以重装,重新配置就行。 有些系统可能用了很久,转了好几个人,里面的配置可能后来的人都搞不清楚了,重新配置需要花费很大精力。
4927 0
【Web动画】SVG 实现复杂线条动画
在上一篇文章中,我们初步实现了一些利用基本图形就能完成的线条动画: 【Web动画】SVG 线条动画入门 当然,事物都是朝着熵增焓减的方向发展的,复杂线条也肯定比有序线条要多。 很多时候,我们无法人工去画出一些十分复杂动画的线条,这个时候,就要借助前端好帮手 PS 和 AI,而本文就是介绍如何导出复杂的 SVG 路径。
1115 0
恢复低版本的FlashPlayer
做页游开发,经常会遇到一些很奇怪的问题。我最近就遇到一个问题:用户进入游戏,只显示游戏部分界面,chrome浏览器是正常的,就IE死活不行,而我自己的IE却又是可以的(都是IE8)。右击看了一下flash player的版本号,她的ie8使用的flash player版本号比她本机的chrome要高,比我的也要高,而且是非debug版本。
666 0
1955
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载