嗷呜嗷呜嗷呜

 // 将视图作为属性方便后面执行多个不同动画
_myView = [[UIView alloc] init];
_myView.layer.position = CGPointMake(, );
_myView.layer.bounds = CGRectMake(, , , );
_myView.backgroundColor = [UIColor blueColor];
[self.view addSubview:_myView];
[_myView release];

平移动画(1)

 // 创建一个CABasicAnimation类型的动画对象并对CALayer的position属性执行动画
CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:@"position"]; // 动画持续1.5s
anim.duration = 1.5; // position属性值从(50, 80)渐变到(300, 350)
anim.fromValue = [NSValue valueWithCGPoint:CGPointMake(, )];
anim.toValue = [NSValue valueWithCGPoint:CGPointMake(, )]; // 设置动画的代理
anim.delegate = self; // 保持动画执行后的状态
anim.removedOnCompletion = NO;
anim.fillMode = kCAFillModeForwards; // 添加动画对象到myView的图层上
[_myView.layer addAnimation:anim forKey:@"translate"];
  • 上面实现了平移动画
  • 想要实现不同的效果,最关键的地方就是第2行CABasicAnimation对象的初始化方法中keyPath的设定。必须是CALayer的某项属性。
  • 第8、9行这里的属性接收的是id类型的参数所以不能直接使用CGPoint这种结构体类型,而是要先包装成NSValue对象后再使用。
  • 注意:可以尝试将第9行的toValue换成byValue  区别:前者是到指定的位置,后者是在当前的位置上增加多少

  • 默认情况下,动画执行完毕后,动画会自动从CALayer上移除,CALayer又会回到原来的状态。为了保持动画执行后的状态,可以加入第15、16行代码

    fillMode的作用就是决定当前对象过了非active时间段的行为。比如动画开始之前,动画结束之后。如果是一个动画CAAnimation,则需要将其removedOnCompletion设置为NO,要不然fillMode不起作用.

    kCAFillModeRemoved 默认值 也就是说当动画开始前和动画结束后,动画对layer都没有影响,动画结束后,layer会恢复到之前的状态 
    kCAFillModeForwards 当动画结束后,layer会一直保持着动画最后的状态 
    kCAFillModeBackwards 这个和kCAFillModeForwards是相对的,就是在动画开始前,你只要将动画加入了一个layer,layer便立即进入动画的初始状态并等待动画开始.你可以这样设定测试代码,将一个动画加入一个layer的时候延迟5秒执行.然后就会发现在动画没有开始的时候,只要动画被加入了layer,layer便处于动画初始状态 
    kCAFillModeBoth 理解了上面两个,这个就很好理解了,这个其实就是上面两个的合成.动画加入后开始之前,layer便处于动画初始状态,动画结束后layer保持动画最后的状态.

  • 第19行后面的@"translate"只是给动画对象起了个名称,也可以直接给个nil,但是为方便以后可以调用CALayer的removeAnimationForKey:方法根据动画名称来移除相应的动画
  • 第12行后面的self是视图控制器。代理需要实现的方法:
 #pragma mark -----动画开始-----
- (void)animationDidStart:(CAAnimation *)anim {
NSLog(@"动画开始了");
} #pragma mark -----动画结束-----
- (void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag {
// 查看一下动画执行完毕后的position值
NSString *string = NSStringFromCGPoint(_myView.layer.position);
NSLog(@"动画结束了,position:%@", string);
}

运行后发现, 在实质上,图层的属性值还是动画执行前的初始值,并没有真正被改变。

 // 移除动画
[_myView.layer removeAnimationForKey:@"translate"]

平移动画(2)

 CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:@"transform"];
anim.duration = ; CATransform3D form = CATransform3DMakeTranslation(, , );
anim.toValue = [NSValue valueWithCATransform3D:form]; [_myView.layer addAnimation:anim forKey:nil];
  • 通过CALayer的transform属性实现平移动画,layer会从自己的初始位置平移到(350, 350)位置
  • 通过transform(KVC)的方式来进行设置,可以简单实现3D效果的平移、缩放、旋转效果。
  • 可查看API文档搜索CABasicAnimation animationWithKeyPath Types

缩放动画(1)

 CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:@"bounds"];
anim.duration = ; anim.toValue = [NSValue valueWithCGRect:CGRectMake(, , , )]; [_myView.layer addAnimation:anim forKey:nil];

通过CALayer的bounds属性实现缩放动画,layer会从原来的尺寸(100x100)变为30x30

缩放动画(2)

 CABasicAnimation *anim = [CABasicAnimation
animationWithKeyPath:@"transform"];
anim.duration = 1.5; // 动画持续1.5s // CALayer的宽度从0.5倍变为2倍
// CALayer的高度从0.5倍变为1.5倍
anim.fromValue = [NSValue valueWithCATransform3D:CATransform3DMakeScale(0.5, 0.5, )];
anim.toValue = [NSValue valueWithCATransform3D:CATransform3DMakeScale(, 1.5, )]; [_myView.layer addAnimation:anim forKey:nil];

旋转动画

 CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:@"transform"];
anim.duration = 1.5; // 绕着(1, 1, 0)这个向量轴顺时针旋转45°
anim.toValue = [NSValue valueWithCATransform3D:CATransform3DMakeRotation(M_PI_4, , , )]; [_myView.layer addAnimation:anim forKey:nil];
  • 提示:如果要仅需要图形以2D的方式旋转,只要把CATransform3DMakeRotation在z方向上的值改为1即可。

    anima.toValue=[NSValue valueWithCATransform3D:CATransform3DMakeRotation(M_PI_4, 1, 1, 0)];

  • 通过以上可以发现其实可以不用设置fromValue,只设置了toValue
  • CABasicAnimation虽然能够做很多基本的动画效果,但是有个局限性,只能让CALayer的属性从某个值渐变到另一个值,仅仅是在2个值之间渐变

之一:CABasicAnimation - 基本动画的更多相关文章

  1. 核心动画基础动画(CABasicAnimation)关键帧动画

    1.在iOS中核心动画分为几类: 基础动画(CABasicAnimation) 关键帧动画(CAKeyframeAnimation) 动画组(CAAnimationGroup) 转场动画(CATran ...

  2. IOS第18天(5,CABasicAnimation基本动画)

    ******* #import "HMViewController.h" @interface HMViewController () @property (nonatomic, ...

  3. Swift - 使用CABasicAnimation实现动画效果

    1,CABasicAnimation类只有三个属性: fromValue:开始值 toValue:结束值 Duration:动画的时间 2,通过animationWithKeyPath键值对的方式设置 ...

  4. CABasicAnimation 基本动画

    几个可以用来实现热门APP应用PATH中menu效果的几个方法 +(CABasicAnimation *)opacityForever_Animation:(float)time //永久闪烁的动画 ...

  5. CABasicAnimation 基本动画 分类: ios技术 2015-07-16 17:10 132人阅读 评论(0) 收藏

    几个可以用来实现热门APP应用PATH中menu效果的几个方法 +(CABasicAnimation *)opacityForever_Animation:(float)time //永久闪烁的动画 ...

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

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

  7. CABasicAnimation 划线动画

    CGFloat animateDuration = ; UIBezierPath *bezierPath = [[UIBezierPath alloc] init]; CGPoint centerFr ...

  8. CABasicAnimation添加动画离开屏幕就动画停止的问题

    解决方法: animation.removedOnCompletion = NO;

  9. iOS开发CABasicAnimation动画理解

    1.CALayer简介 CALayer是个与UIView很类似的概念,同样有backgroundColor.frame等相似的属性,我们可以将UIView看做一种特殊的CALayer.但实际上UIVi ...

随机推荐

  1. JDK和tomcat环境变量配置

    JDK环境变量配置:   如果你的JDK安装在C盘里,如:C:\Program Files\Java\jdk1.6.0_05, 那么就在系统变量里(当然也可以在用户变量里)点新建: 变量名:JAVA_ ...

  2. Android聚合广告AFP的对接系统设计

    工作需要,要对接阿里妈妈的广告聚合平台,简称AFP.对于一般的应用而言,想要流量变现,广告是显而易见的手段,尤其是在中国,打开一个千万级别的用户,肯定有某个地方是有对接广告的,只不过明不明显而已. 阿 ...

  3. Asp.net 高性能 Sqlite ORM 框架之 sqliteSugar

    一.介简 easyliter框架的升级版本,并且正式命名为SqliteSugar框架,另外Sugar系列还有 MySql和MsSql版本,Oracle版本待开发中(因为客户端太大一直在忧郁当中) 用S ...

  4. 两种读写配置文件的方案(app.config与web.config通用)

    第一种方法:采用MS现有的ConfigurationManager来进行读写 using System.Configuration; namespace Zwj.TEMS.Common { publi ...

  5. 使用Microsoft Fakes进行单元测试(2)

    接上一篇使用Microsoft Fakes进行单元测试(1) 下面进行Shim的演示. 2.使用Shim替换静态方法 假设我们需要一个工具方法用来格式化当前时间为字符串,因为DateTime.Now一 ...

  6. 解决 DotNetCore.1.0.1-VS2015Tools.Preview2.0.3.exe 在VS2015 Update3 安装失败的问题

    今天抽空升级VS2015 Update3. 在安装DotNetCore.1.0.1-VS2015Tools.Preview2.0.3.exe 时报错了,看了错误日志 显示: 看到我标红的两个地方,那么 ...

  7. 【转】jQuery中.bind() .live() .delegate() .on()的区别

    bind(type,[data],fn) 为每个匹配元素的特定事件绑定事件处理函数 $("a").bind("click",function(){alert(& ...

  8. [DBW]js获取当前时间(昨天、今天、明天)

    开发过程中某些前台页面的时间控件我们需要给默认当前时间,jquery可以轻松的帮我们实现,代码如下 1 //昨天的时间 2 var day1 = new Date(); 3 day1.setTime( ...

  9. 基于TCP和多线程实现无线鼠标键盘-InputMethodManager

    为了实现无线键盘的功能,使用了InputMethodManager弹出软键盘. // 弹出软键盘 public void pop_keyboard(){ imm = (InputMethodManag ...

  10. [转]JavaScript程序编码规范

    原文:http://javascript.crockford.com/code.html 作者:Douglas Crockford 译文:http://www.yeeyan.com/articles/ ...