CAKeyframeAnimation 动画使用 开始、暂停动画
来源:互联网 发布:大数据cdh平台是什么 编辑:程序博客网 时间:2024/05/21 21:49
开始一个帧动画
- - (void)showAlertAnimation
- {
- CAKeyframeAnimation *animation = [CAKeyframeAnimation animationWithKeyPath:@"transform"];
- //方式1:放大再缩小(类似系统alert)
- //如果需要更好的效果
- //可以添加 .keyTimes 属性。
- NSMutableArray *values = [NSMutableArray array]; [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(0.1, 0.1, 1.0)]]; [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(1.2, 1.2, 1.0)]]; [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(0.9, 0.9, 0.9)]]; [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(1.0, 1.0, 1.0)]]; animation.values = values;
- //end
- //方式2:直接缩小
- // animation.values = @[[NSValue valueWithCATransform3D:CATransform3DMakeScale(1.2, 1.2, 1)],
- // [NSValue valueWithCATransform3D:CATransform3DMakeScale(1.05, 1.05, 1)],
- // [NSValue valueWithCATransform3D:CATransform3DMakeScale(1.0, 1.0, 1)]];
- // animation.keyTimes = @[ @0, @0.5, @1 ];
- //end
- animation.fillMode = kCAFillModeForwards;
- animation.removedOnCompletion = NO;
- animation.duration = .3;
- [self.alertView.layer addAnimation:animation forKey:@"showAlert"];
- }
其中:fillMode主要是决定显示layer在动画完成后的状态..一般和removedOnCompletion一起使用..
如果fillmode是..kCAFillModeRemoved 或..kCAFillModeBackwards...
不管removedOnCompletion是yes还是no,都会回到原始状态..
一般用在重复的动画里..比如图片旋转5圈..你做一圈的功能.然后重复5次..就行了..
kCAFillModeForwards 或 kCAFillModeBoth模式下...
如果..removedOnCompletion 是yes,动画完成后会回到原始状态..
removedOnCompletion是NO的话..动画完成后会保持状态..
保持状态只是保持可见层(presentation)的状态...layer本身的状态不会改变.
比如...layer的frame,在动画完成后不管是否保持状态,frame都不变..完成后得手动设定frame的位置
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>开始、暂停动画
- -(void)pauseLayer:(CALayer*)layer
- {
- CFTimeInterval pausedTime = [layer convertTime:CACurrentMediaTime() fromLayer:nil];
- layer.speed = 0.0;
- layer.timeOffset = pausedTime;
- }
- //恢复layer上的动画
- -(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;
- }
0 0
- CAKeyframeAnimation 动画使用 开始、暂停动画
- CAKeyframeAnimation动画的使用
- CAKeyframeAnimation动画
- CAKeyframeAnimation(关键帧动画)的简单使用
- CAKeyframeAnimation-核心动画-帧动画
- 关键帧动画CAKeyframeAnimation
- 关键帧动画CAKeyframeAnimation
- 关键帧动画CAKeyframeAnimation
- 关键帧动画CAKeyframeAnimation
- 关键帧动画CAKeyframeAnimation
- 关键帧动画CAKeyframeAnimation
- 关键帧动画CAKeyframeAnimation
- CAKeyframeAnimation 帧动画实现
- 关键帧动画CAKeyframeAnimation
- CAKeyframeAnimation ---关键帧动画
- 关键帧动画CAKeyframeAnimation
- CAKeyFrameAnimation关键帧动画
- 关键帧动画CAKeyframeAnimation
- 【UICollectionview】UICollectionViewCell添加阴影书框效果
- java中构造函数的调用
- 习题4-1 象棋 UVa1589
- 程序在内存中的分配方式
- Longest Valid Parentheses Java
- CAKeyframeAnimation 动画使用 开始、暂停动画
- sdsd
- jquery弹性云拖动计算功能
- Ehcache缓存配置
- Launcher启动的流程图【AndroidICS4.0——>Launcher系列四】
- 团子WebApi相较于Asp.Net MVC/WebForm开发的特点
- 日本会社的职务
- tabitem标记
- XCode报错 has been modified since the precompiled header was built