OC语言知识8

本文目录

CABasicAnimation是CAPropertyAnimation的子类,使用它可以实现一些基本的动画效果,它可以让CALayer的某个属性从某个值渐变到另一个值。下面就用CABasicAnimation实现几个简单的动画。

* 先初始化一个UIView添加到控制器的view中,然后在这个UIView的layer上执行动画,下面的self是指控制器

1 _myView = [[UIView alloc] init];
2 _myView.layer.position = CGPointMake(100, 100);
3 _myView.layer.bounds = CGRectMake(0, 0, 100, 100);
4 _myView.backgroundColor = [UIColor blueColor];
5 [self.view addSubview:_myView];
6 [_myView release];

回到顶部

一、平移动画

实现平移动画有好几种方法,这里列举2种。

1.方法1

 1 // 说明这个动画对象要对CALayer的position属性执行动画
 2 CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:@"position"];
 3 // 动画持续1.5s
 4 anim.duration = 1.5;
 5
 6 // position属性值从(50, 80)渐变到(300, 350)
 7 anim.fromValue = [NSValue valueWithCGPoint:CGPointMake(50, 80)];
 8 anim.toValue = [NSValue valueWithCGPoint:CGPointMake(300, 350)];
 9
10 // 设置动画的代理
11 anim.delegate = self;
12
13 // 保持动画执行后的状态
14 anim.removedOnCompletion = NO;
15 anim.fillMode = kCAFillModeForwards;
16
17 // 添加动画对象到图层上
18 [_myView.layer addAnimation:anim forKey:@"translate"];

* 第2行设置的keyPath是@"position",说明要修改的是CALayer的position属性,也就是会执行平移动画

* 注意第7、8行,这里并不是直接使用CGPoint这种结构体类型,而是要先包装成NSValue对象后再使用。这2行代码表示CALayer从位置(50, 80)移动到位置(300, 350)

* 如果将第8行的toValue换成byValue,代表CALayer从位置(50, 80)开始向右移动300、向下移动350,也就是移动到位置(350, 430)

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

* 第18行后面的@"translate"是给动画对象起个名称,以后可以调用CALayer的removeAnimationForKey:方法根据动画名称停止相应的动画

* 第11行是设置动画的代理,可以监听动画的执行过程,这里设置控制器为代理。代理需要实现的方法有:

 1 #pragma mark 动画开始
 2 - (void)animationDidStart:(CAAnimation *)anim {
 3     NSLog(@"动画开始了");
 4 }
 5
 6 #pragma mark 动画结束
 7 - (void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag {
 8     // 查看一下动画执行完毕后的position值
 9     NSString *string = NSStringFromCGPoint(_myView.layer.position);
10     NSLog(@"动画结束了,position:%@", string);
11 }

打印结果为:

1 2013-04-14 23:44:26.197 CAAnimation[5995:c07] 动画开始了
2 2013-04-14 23:44:27.697 CAAnimation[5995:c07] 动画结束了,position:{100, 100}

从第2行的打印信息可以看出,实际上,动画执行完毕后,并没有真正改变CALayer的position属性的值!

2.方法2

1 CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:@"transform"];
2 anim.duration = 1;
3
4 CATransform3D form = CATransform3DMakeTranslation(350, 350, 0);
5 anim.toValue = [NSValue valueWithCATransform3D:form];
6
7 [_myView.layer addAnimation:anim forKey:nil];

通过CALayer的transform属性实现平移动画,layer会从自己的初始位置平移到(350, 350)位置

回到顶部

二、缩放动画

实现缩放动画有好几种方法,这里列举2种。

1.方法1

1 CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:@"bounds"];
2 anim.duration = 2;
3
4 anim.toValue = [NSValue valueWithCGRect:CGRectMake(0, 0, 30, 30)];
5
6 [_myView.layer addAnimation:anim forKey:nil];

layer会从原来的尺寸(100x100)变为30x30

2.方法2

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

回到顶部

三、旋转动画

1 CABasicAnimation *anim = [CABasicAnimation animationWithKeyPath:@"transform"];
2 anim.duration = 1.5;
3
4 // 绕着(0, 0, 1)这个向量轴顺时针旋转45°
5 anim.toValue = [NSValue valueWithCATransform3D:CATransform3DMakeRotation(M_PI_4, 0, 0, 1)];
6
7 [_myView.layer addAnimation:anim forKey:nil]; 

其实可以不用设置fromValue,这里只设置了toValue

回到顶部

四、其他

* 除开前面使用的position、transform属性,其实CALayer还有好多属性都可以形成动画,这些属性统称为"Animatable Properties"。在《CALayer3-层的属性》开头有介绍如何搜索这些属性

* CABasicAnimation虽然能够做很多基本的动画效果,但是有个局限性,只能让CALayer的属性从某个值渐变到另一个值,仅仅是在2个值之间渐变

时间: 2024-08-15 00:46:51

OC语言知识8的相关文章

OC语言知识3

本文目录 知识回顾 一.自定义构造方法 二.description方法 说明:这个Objective-C专题,是学习iOS开发的前奏,也为了让有面向对象语言开发经验的程序员,能够快速上手Objective-C.如果你还没有编程经验,或者对Objective-C.iOS开发不感兴趣,请忽略.学习本专题之前,建议先学习C语言专题. 回到顶部 知识回顾 在第5讲中已经介绍了如何定义类和创建并初始化对象,比如有Student这个类 1.Student.h 1 #import <Foundation/Fo

OC语言知识2

本文目录 一.Java中的this只能用在动态方法中,不能用在静态方法中 二.OC中的self既可以用在动态方法中,也可以用在静态方法中 说明:这个Objective-C专题,是学习iOS开发的前奏,也为了让有面向对象语言开发经验的程序员,能够快速上手Objective-C.如果你还没有编程经验,或者对Objective-C.iOS开发不感兴趣,请忽略.学习本专题之前,建议先学习C语言专题. OC中有一个self关键字,用法跟Java中的this类似,都是代表着当前方法的调用者.但self和th

OC语言知识1

本文目录 一.什么是空指针和野指针 二.野指针和空指针例子 说明:这个Objective-C专题,是学习iOS开发的前奏,也为了让有面向对象语言开发经验的程序员,能够快速上手Objective-C.如果你还没有编程经验,或者对Objective-C.iOS开发不感兴趣,请忽略.学习本专题之前,建议先学习C语言专题. 回到顶部 一.什么是空指针和野指针 1.空指针 1> 没有存储任何内存地址的指针就称为空指针(NULL指针) 2> 空指针就是被赋值为0的指针,在没有被具体初始化之前,其值为0.

OC语言知识5

本文目录 前言 一.获取当前线程 二.获取主线程 三.NSThread的创建 四.暂停当前线程 五.线程的其他操作 六.优缺点 回到顶部 前言 每个iOS应用程序都有个专门用来更新显示UI界面.处理用户触摸事件的主线程,因此不能将其他太耗时的操作放在主线程中执行,不然会造成主线程堵塞(出现卡机现象),带来极坏的用户体验.一般的解决方案就是将那些耗时的操作放到另外一个线程中去执行,多线程编程是防止主线程堵塞,增加运行效率的最佳方法. iOS中有3种常见的多线程编程方法: 1.NSThread 这种

OC语言知识7

本文目录 前言 一.API简介 二.发送异步的GET请求 回到顶部 前言 云计算 近几年来,云计算是一个非常热门的技术名词,很多专家认为,云计算会改变互联网的技术基础,甚至会影响整个产业的格局.可能还很多人不了解什么是云计算,简单来说,就是把用户的数据(比如文档.照片等).用户需要使用的软件.用户需要搜索的资源都保存在"云端",并不用保存在用户本地.你可以将"云端"看做了一台超级计算机,其实是由无数台大型服务器组成的. 移动应用 现在很多的移动应用也类似于"

OC语言知识6

本文目录 一.异步POST请求 二.NSURLConnection的其他请求方法 上一讲介绍了iOS中的异步GET请求,这讲来看看异步POST请求. 回到顶部 一.异步POST请求 假如请求路径是http://192.168.1.102:8080/MJServer/login,请求参数有2个: username :母鸡 pwd :123 1.POST请求细节分析 要想在iOS中发送一个POST请求,首先要了解POST请求的一些细节: 1> 跟GET请求不一样的是,POST请求的请求参数不是拼接在

OC语言知识9

本文目录 一.Core Animation简介 二.Core Animation的使用步骤 三.CAAnimation 四.CAPropertyAnimation 回到顶部 一.Core Animation简介 * Core Animation,中文翻译为核心动画,它是一组非常强大的动画处理API,使用它能做出非常炫丽的动画效果,而且往往是事半功倍.也就是说,使用少量的代码就可以实现非常强大的功能. * Core Animation可以用在Mac OS X和iOS平台. * 乔帮主在2007年的

OC语言知识4

本文目录 前言 一.NSInvocationOperation 二.NSBlockOperation 三.NSOperation的其他用法 四.自定义NSOperation 回到顶部 前言 1.上一讲简单介绍了NSThread的使用,虽然也可以实现多线程编程,但是需要我们去管理线程的生命周期,还要考虑线程同步.加锁问题,造成一些性能上的开销.我们也可以配合使用NSOperation和NSOperationQueue实现多线程编程,实现步骤大致是这样的: 1> 先将需要执行的操作封装到一个NSOp

OC语言知识10

本文目录 一.自定义层的方法1 二.自定义层的方法2 三.其他 自定义层,其实就是在层上绘图,一共有2种方法,下面详细介绍一下. 回到顶部 一.自定义层的方法1 方法描述:创建一个CALayer的子类,然后覆盖drawInContext:方法,使用Quartz2D API进行绘图 1.创建一个CALayer的子类 2.在.m文件中覆盖drawInContext:方法,在里面绘图 1 @implementation MJLayer 2 3 #pragma mark 绘制一个实心三角形 4 - (v

OC语言知识12

本文目录 一.添加一个简单的图层 二.添加一个显示图片的图层 三.为什么CALayer中使用CGColorRef和CGImageRef这2种数据类型,而不用UIColor和UIImage? 四.UIView和CALayer的选择 五.UIView和CALayer的其他关系 * 上一讲已经说过,UIView内部默认有个CALayer对象(层),通过layer属性可以访问这个层.要注意的是,这个默认的层不允许重新创建,但可以往层里面添加子层 * UIView可以通过addSubview:方法添加子视