本文转载至 http://blog.csdn.net/wildfireli/article/details/23191861

暂停和继续动画的核心代码如下:

  1. <pre name="code" class="cpp">//暂停layer上面的动画
  2. - (void)pauseLayer:(CALayer*)layer
  3. {
  4. CFTimeInterval pausedTime = [layer convertTime:CACurrentMediaTime() fromLayer:nil];
  5. layer.speed = 0.0;
  6. layer.timeOffset = pausedTime;
  7. }
  8. //继续layer上面的动画
  9. - (void)resumeLayer:(CALayer*)layer
  10. {
  11. CFTimeInterval pausedTime = [layer timeOffset];
  12. layer.speed = 1.0;
  13. layer.timeOffset = 0.0;
  14. layer.beginTime = 0.0;
  15. CFTimeInterval timeSincePause = [layer convertTime:CACurrentMediaTime() fromLayer:nil] - pausedTime;
  16. layer.beginTime = timeSincePause;
  17. }</pre><br>
  18. <pre></pre>
  19. <p>附上完整代码</p>
  20. <p></p>
  21. <p class="p1">AnimationPauseViewController.h</p>
  22. <pre name="code" class="cpp">#import <UIKit/UIKit.h>
  23. @interface AnimationPauseViewController : UIViewController {
  24. UIImageView *soccer;
  25. BOOL isPause;
  26. UIButton *controlButton;
  27. }
  28. @property (nonatomic, retain) IBOutlet UIImageView *soccer;
  29. - (IBAction)clickControlButton:(id)sender;
  30. @property (nonatomic, retain) IBOutlet UIButton *controlButton;
  31. @end</pre><br>
  32. <p></p>
  33. <p class="p1">AnimationPauseViewController.m</p>
  34. <p></p><pre name="code" class="cpp">#import "AnimationPauseViewController.h"
  35. #import <QuartzCore/QuartzCore.h>
  36. @implementation AnimationPauseViewController
  37. @synthesize controlButton;
  38. @synthesize soccer;
  39. - (void)dealloc
  40. {
  41. [soccer release];
  42. [controlButton release];
  43. [super dealloc];
  44. }
  45. - (void)didReceiveMemoryWarning
  46. {
  47. // Releases the view if it doesn't have a superview.
  48. [super didReceiveMemoryWarning];
  49. // Release any cached data, images, etc that aren't in use.
  50. }
  51. - (void)addAnimations
  52. {
  53. //让足球来回移动
  54. CABasicAnimation *translation = [CABasicAnimation animationWithKeyPath:@"position"];
  55. translation.fromValue = [NSValue valueWithCGPoint:CGPointMake(24, 240)];
  56. translation.toValue = [NSValue valueWithCGPoint:CGPointMake(320- 24, 240)];
  57. translation.duration = 2;
  58. translation.repeatCount = HUGE_VALF;
  59. translation.autoreverses = YES;
  60. //让足球来回转动
  61. CABasicAnimation *rotation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"];
  62. //kCAMediaTimingFunctionLinear 表示时间方法为线性,使得足球匀速转动
  63. rotation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionLinear];
  64. rotation.toValue = [NSNumber numberWithFloat:4 * M_PI];
  65. rotation.duration = 2;
  66. rotation.repeatCount = HUGE_VALF;
  67. rotation.autoreverses = YES;
  68. [soccer.layer addAnimation:rotation forKey:@"rotation"];
  69. [soccer.layer addAnimation:translation forKey:@"translation"];
  70. }
  71. #pragma mark - View lifecycle
  72. - (void)viewDidLoad
  73. {
  74. [super viewDidLoad];
  75. [self addAnimations];
  76. }
  77. - (void)viewDidUnload
  78. {
  79. [self setSoccer:nil];
  80. [self setControlButton:nil];
  81. [super viewDidUnload];
  82. }
  83. - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
  84. {
  85. // Return YES for supported orientations
  86. return (interfaceOrientation == UIInterfaceOrientationPortrait);
  87. }
  88. //暂停layer上面的动画
  89. - (void)pauseLayer:(CALayer*)layer
  90. {
  91. CFTimeInterval pausedTime = [layer convertTime:CACurrentMediaTime() fromLayer:nil];
  92. layer.speed = 0.0;
  93. layer.timeOffset = pausedTime;
  94. }
  95. //继续layer上面的动画
  96. - (void)resumeLayer:(CALayer*)layer
  97. {
  98. CFTimeInterval pausedTime = [layer timeOffset];
  99. layer.speed = 1.0;
  100. layer.timeOffset = 0.0;
  101. layer.beginTime = 0.0;
  102. CFTimeInterval timeSincePause = [layer convertTime:CACurrentMediaTime() fromLayer:nil] - pausedTime;
  103. layer.beginTime = timeSincePause;
  104. }
  105. - (void)pauseSoccer
  106. {
  107. isPause = YES;
  108. [controlButton setTitle:@"继续" forState:UIControlStateNormal];
  109. [self pauseLayer:soccer.layer];
  110. }
  111. - (void)resumeSoccer
  112. {
  113. isPause = NO;
  114. [controlButton setTitle:@"暂停" forState:UIControlStateNormal];
  115. [self resumeLayer:soccer.layer];
  116. }
  117. - (IBAction)clickControlButton:(id)sender {
  118. if (isPause) {
  119. [self resumeSoccer];
  120. }else{
  121. [self pauseSoccer];
  122. }
  123. }
  124. @end</pre><br>
  125. <br>
  126. <p></p>

在ios中运用core animation暂停和继续动画的更多相关文章

  1. 使用Core Animation对象来实现动画

    转载保留原文地址:http://blog.csdn.net/kqjob/article/details/10417461,转载的 在iOS中如果使用普通的动画则可以使用UIKit提供的动画方式来实现, ...

  2. iOS开发之Core Animation

    在IOS中如果使用普通的动画则可以使用UIKit提供的动画方式来实现,如果想实现更复杂的效果,则需要使用Core Animation了. 在Core Animation中我们经常使用的是 CABasi ...

  3. iOS Instruments之Core Animation动画性能调优(工具复选框选项介绍)

    Core Animation工具用来监测Core Animation性能.它给我们提供了周期性的FPS,并且考虑到了发生在程序之外的动画(见图12.4) Core Animation工具提供了一系列复 ...

  4. iOS Core Animation学习总结(3)--动画的基本类型

    一. CABasicAnimation (基础动画) 移位: CABasicAnimation *animation = [CABasicAnimation animation]; //keyPath ...

  5. Core Animation之CABasicAnimation(基础动画)

    #import "ViewController.h" @interface ViewController () @property(nonatomic,strong)UIButto ...

  6. core Animation之CAKeyframeAnimation(关键帧动画)

    CABasicAnimation的区别是:CABasicAnimation只能从一个数值(fromValue)变到另一个数值(toValue),而CAKeyframeAnimation会使用一个NSA ...

  7. iOS开发基础知识:Core Animation(核心动画)

    Core Animation,中文翻译为核心动画,它是一组非常强大的动画处理API,使用它能做出非常炫丽的动画效果,而且往往是事半功倍.也就是说,使用少量的代码就可以实现非常强大的功能. Core A ...

  8. iOS之核心动画(Core Animation)

      Core Animation,中文翻译为核心动画,它是一组非常强大的动画处理API,使用它能做出非常炫丽的动画效果,而且往往是事半功倍.也就是说,使用少量的代码就可以实现非常强大的功能. Core ...

  9. iOS开发 - Core Animation 核心动画

    Core Animation Core Animation.中文翻译为核心动画,它是一组很强大的动画处理API,使用它能做出很炫丽的动画效果.并且往往是事半功倍. 也就是说,使用少量的代码就能够实现很 ...

随机推荐

  1. HTTP——代理协议 HTTP/1.1的CONNECT方法

    我们平时使用HTTP协议无非就是GET.POST这些方法,但是HTTP的内容远不止那些.今天就来说说HTTP代理使用的CONNECT.这个不是在网页开发上用的,如果没兴趣就跳过吧. APACHE只是作 ...

  2. ES标准中的相等比较算法 SameValue SameValueZero

    1.相等比较算法 The Abstract Equality Comparison Algorithm (==) The Strict Equality Comparison Algorithm (= ...

  3. PHP怎么实现站点保存快捷方式

    PHP怎么实现站点保存快捷方式 <?php $Shortcut = "[InternetShortcut] URL=http://blog.csdn.net/phpfenghuo/ I ...

  4. js canvas画柱状图 没什么高端的 就是一篇偶尔思路的

    公司项目要用js画柱状图,本来想用个插件吧 chart.js 忽然一想 我们也用不了那么大的插件.自己写个吧,也能看看自己那点数学水平能够不! 有几个小亮点吧 1.函数x 和 函数y 对坐标进行了转化 ...

  5. 移动负载均衡技术(MBL)

    移动负载均衡技术(MBL)   转至元数据结尾 附件:5 被admin添加,被admin最后更新于四月 27, 2015 转至元数据起始 互联网技术发展到今天,已经进入移动时代,很多在传统CS和BS的 ...

  6. CKEditor的安装与基本使用(JSP)

    文章分类:Web前端 一.下载CKEditor 1. 直接下载地址.当前最新版本号为3.5: http://download.cksource.com/CKEditor/CKEditor/CKEdit ...

  7. emcas自己所熟悉的快捷键

    刚开始用emacs,看完Tutorial了后又用emcas做了一些笔记. 现将自己脑海中觉得比较重要的快捷键一一列出,该列表将持续更新: C = Ctrl  M = Alt 查找或打开(新)文件 C- ...

  8. 关于top按钮的网页设置

    方法一: 直接用html实现,没有缓冲的效果,直接彪到顶部. HTMl: <a id="return-top" href="#top"> <s ...

  9. intent 启动activity、service的方法

    1.通过intent启动service. 通过传递一个Intent对象至Context.startService()将启动一个服务(或给予正在运行的服务以一个新的指令).Android调用服务的onS ...

  10. PHP图片识别成文字

    http://apistore.baidu.com/apiworks/servicedetail/146.html 分类: php2011-- : 3576人阅读 评论() 收藏 举报 phpfunc ...