iOS开发之动画编程的几种方法
iOS开发之动画编程的几种方法
IOS中的动画总结来说有五种:UIView<block>,CAAnimation<CABasicAnimation,CATransition,CAKeyframeAnimation>,NSTimer
这里我就总结了一下这五种方法,其实iOS开发中动画的编程都会在这里面变化,所以只要弄懂了这些动画编程就不难了。
一:UIView动画
一般方式
- [UIView beginAnimations:@"ddd" context:nil];//设置动画
- [UIView commitAnimations]; //提交动画
- 这两个是必须有的,然后在两句的中间添加动画的代码
- [UIView beginAnimations:@"ddd" context:nil];//设置动画 ddd为动画名称
- [UIView setAnimationDuration:3];//定义动画持续时间
- [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut]; //setAnimationCurve来定义动画加速或减速方式
- [UIView setAnimationTransition:UIViewAnimationTransitionCurlDown forView:self.window cache:YES];
- //设置动画的样式 forView为哪个view实现这个动画效果
- [UIView setAnimationDelay:3]; //设置动画延迟多久执行
- [UIView setAnimationDelegate:self]; //设置动画的代理 实现动画执行前后的方法 在commitAnimation之前设置
- [UIView setAnimationDidStopSelector:@selector(stop)];//设置动画结束后执行的方法
- [UIView setAnimationWillStartSelector:@selector(star)];//设置动画将要开始执行的方法
- [UIView commitAnimations]; //提交动画
- typedef enum {
- UIViewAnimationTransitionNone, //普通状态
- UIViewAnimationTransitionFlipFromLeft, //从左往右翻转
- UIViewAnimationTransitionFlipFromRight, //从右往左翻转
- UIViewAnimationTransitionCurlUp, //向上翻页
- UIViewAnimationTransitionCurlDown, //向下翻页
- } UIViewAnimationTransition;
- typedef enum {
- UIViewAnimationCurveEaseInOut,
- UIViewAnimationCurveEaseIn,
- UIViewAnimationCurveEaseOut,
- UIViewAnimationCurveLinear
- } UIViewAnimationCurve;
- [UIView beginAnimations:@"ddd" context:nil]; //设置动画
- view.frame = CGRectMake(200, 200, 100, 100);
- [UIView commitAnimations]; //提交动画
- 当view从本来的frame移动到新的frame时会慢慢渐变 而不是一下就完成了 中间也可以添加到上面那段中间 只是多种效果重叠
- 以下这些也可以加到 [UIView beginAnimations:@"ddd" context:nil]; [UIView commitAnimations];之间
- view.transform = CGAffineTransformMakeTranslation(10, 10);//设置偏移量 相对于最初的 只能偏移一次
- view.transform = CGAffineTransformTranslate(view.transform, 10, 10); //设置偏移量 偏移多次
- self.view.transform = CGAffineTransformMakeRotation(M_PI);//设置旋转度 只能旋转一次
- self.view.transform = CGAffineTransformRotate(self.view.transform, M_PI); //旋转多次
- self.view.transform = CGAffineTransformMakeScale(1.1, 1.1); //设置大小 只能改变一次 数值时相对于本来的几倍
- self.view.transform = CGAffineTransformScale(self.view.transform, 1.1, 1.1);//改变多次
- self.view.transform = CGAffineTransformIdentity;//回到当初的样子 执行一次
- self.view.transform = CGAffineTransformInvert(self.view.transform);//得到相反的样子 大小 方向 位置执行多次
这里我实现了一个自定义的动画方法,方便使用,只需要调用就可以实现很好的功能。
方法的实现
-(void)UIViewAnimation:(UIView* )view frame:(CGRect)frame type:(int)type alpha:(float)alpha duration:(float)duration
{
//将对应的参数实现在方法中,调用的时候只需要输入方法中所需要的参数就能很好的调用这个方法,并且实现想要的功能!
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:duration];
[UIView setAnimationCurve:type];
[UIView setAnimationDelegate:self];
view.alpha=alpha;
view.frame=frame;
[UIView commitAnimations];
}
调用方法
[self UIViewAnimation:downView frame:CGRectMake(0, height, 320, 58) type:UIViewAnimationCurveEaseOut alpha:1 duration:0.3];
Block方式
- [UIView animateWithDuration:3 animations:^(void){
- //这里相当于在begin和commint之间
- }completion:^(BOOL finished){
- //这里相当于动画执行完成后要执行的方法,可以继续嵌套block
- }];
高级一点的block动画(Next)内嵌
二:.CAAnimation
需要添加库,和包含头文件
caanimation有多个子类
CABasicAnimation
- CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"opacity"];
- //@""里的字符串有多种,可以自己找相关资料,一定要填对,动画才会执行 opacity设置透明度 bounds.size设置大小
- [animation setFromValue:[NSNumber numberWithFloat:1.0]]; //设置透明度从几开始
- [animation setToValue:[NSNumber numberWithFloat:0.3]];//设置透明度到几结束
- [animation setDuration:0.1]; //设置动画时间
- [animation setRepeatCount:100000];//设置重复时间
- [animation setRepeatDuration:4]; //会限制重复次数
- [animation setAutoreverses:NO];//设置是否从1.0到0.3 再从0.3到1.0 为一次 如果设置为NO则 1.0到0.3为一次
- [animation setRemovedOnCompletion:YES]; //完成时移出动画 默认也是
- [view.layer addAnimation:animation forKey:@"abc"];//执行动画
CAKeyframeAnimation
- CAKeyframeAnimation *animation = [CAKeyframeAnimation animationWithKeyPath:@"position"];//设置view从初始位置经过一系列点
- NSArray *postionAraay = [NSArray arrayWithObjects:[NSValue valueWithCGPoint:CGPointMake(100, 20)], [NSValue valueWithCGPoint:CGPointMake(40, 80)],[NSValue
- valueWithCGPoint:CGPointMake(30, 60)],[NSValue valueWithCGPoint:CGPointMake(20, 40)],[NSValue valueWithCGPoint:CGPointMake(0, 100)],nil];//设置点
- NSArray *times = [NSArray arrayWithObjects:[NSNumber numberWithFloat:0.3],[NSNumber numberWithFloat:0.5],[NSNumber numberWithFloat:0.6],[NSNumber numberWithFloat:0.1],[NSNumber
- numberWithFloat:1.0], nil]; //设置移动过程的时间
- [animation setKeyTimes:times];
- [animation setValues:postionAraay];
- [animation setDuration:5]; //设置动画时间
- [bigImage.layer addAnimation:animation forKey:@"dd"]; //执行动画
CATransition
- CATransition *animation = [CATransition animation];
- animation.duration = 0.5f;
- animation.timingFunction = UIViewAnimationCurveEaseInOut;
- animation.fillMode = kCAFillModeForwards;
- /*
- kCATransitionFade;
- kCATransitionMoveIn;
- kCATransitionPush;
- kCATransitionReveal;
- */
- /*
- kCATransitionFromRight;
- kCATransitionFromLeft;
- kCATransitionFromTop;
- kCATransitionFromBottom;
- */
- animation.type = kCATransitionPush;
- animation.subtype = kCATransitionFromBottom;
- [view.layer addAnimation:animation forKey:animation];
- type也可以直接用字符串
- /*
- cube
- suckEffect 卷走
- oglFlip 翻转
- rippleEffect 水波
- pageCurl 翻页
- pageUnCurl
- cameraIrisHollowOpen
- cameraIrisHollowClose
- */
三:NSTimer
这是一种定时器来操作动画的方法,他可以结合上面的方法来实现动画的多样化!
- -(void) onTimer {
- imageView.center = CGPointMake(imageView.center.x + delta.x,
- imageView.center.y + delta.y);
- if (imageView.center.x > self.view.bounds.size.width - ballRadius ||
- imageView.center.x < ballRadius)
- delta.x = -delta.x;
- if (imageView.center.y > self.view.bounds.size.height - ballRadius ||
- imageView.center.y < ballRadius)
- delta.y = -delta.y;
- }
- - (void) viewDidLoad {
- ballRadius = imageView.bounds.size.width / 2;
- [slider setShowValue:YES];
- delta = CGPointMake(12.0,4.0);
- timer = [NSTimer scheduledTimerWithTimeInterval:slider.value
- target:self
- selector:@selector(onTimer)
- userInfo:nil
- repeats:YES];
- [super viewDidLoad];
- }
- -(IBAction) sliderMoved:(id) sender {
- [timer invalidate];
- timer = [NSTimer scheduledTimerWithTimeInterval:slider.value
- target:self
- selector:@selector(onTimer)
- userInfo:nil
- repeats:YES];
- //
- timer = [NSTimer scheduledTimerWithTimeInterval:?
- invocation:?
- repeats:YES];
- }
iOS开发之动画编程的几种方法的更多相关文章
- IOS开发中数据持久化的几种方法--NSUserDefaults
IOS开发中数据持久化的几种方法--NSUserDefaults IOS 开发中,经常会遇到需要把一些数据保存在本地的情况,那么这个时候我们有以下几种可以选择的方案: 一.使用NSUserDefaul ...
- iOS开发进阶-实现多线程的3种方法
相关文章链接: 1.多线程简介 2.实现多线程的3种方法 ......待续 前言 在多线程简介中,我已经说明过了,为了提高界面的流畅度以及用户体验.我们务必要把耗时的操作放到别的线程中去执行,千万不要 ...
- 【转】 ios开发之倒计时实现的两种方法
原文:http://blog.csdn.net/kylinbl/article/details/8972261 方法1:使用NSTimer来实现 主要使用的是NSTimer的scheduledTime ...
- iOS开发之网络编程--4、NSURLSessionDataTask实现文件下载(离线断点续传下载) <进度值显示优化>
前言:根据前篇<iOS开发之网络编程--2.NSURLSessionDownloadTask文件下载>或者<iOS开发之网络编程--3.NSURLSessionDataTask实现文 ...
- iOS开发之网络编程--3、NSURLSessionDataTask实现文件下载(离线断点续传下载)
前言:使用NSURLSessionDownloadTask满足不这个需要离线断点续传的下载需求,所以这里就需要使用NSURLSessionDataTask的代理方法来处理下载大文件,并且实现离线断点续 ...
- iOS开发之网络编程--小文件下载
文件下载方式: 如果下载的文件比较小,下载方式: 直接用NSData的 +(id)dataWithContentsOfURL:(NSURL*)url; 利用NSURLConnection发送一个HTT ...
- iOS开发之网络编程--5、NSURLSessionUploadTask+NSURLSessionDataDelegate代理上传
前言:关于NSURLSession的主要内容快到尾声了,这里就讲讲文件上传.关于文件上传当然就要使用NSURLSessionUploadTask,这里直接讲解常用的会和代理NSURLSessionDa ...
- iOS开发之网络编程--2、NSURLSessionDownloadTask文件下载
本文内容大纲: 1.回顾NSURLSessionTask 2.NSURLSessionDownloadTask大文件之block下载 3.NSURLSessionDownloadTask大文件之代理方 ...
- iOS开发之网络编程--使用NSURLConnection实现文件上传
前言:使用NSURLConnection实现文件上传有点繁琐. 本文并没有介绍使用第三方框架上传文件. 正文: 这里先提供用于编码测试的接口:http://120.25.226.186:3281 ...
随机推荐
- AdHoc发布时出现重复Provisioning Profile的解决方案
当在developer.apple.com更新Provisioning Profile(添加新机器)后,下载到本地,双击载入xcode,运行时没问题.但如果用adhoc发布,可能会发现重复的provi ...
- Android attrs.xml文件中属性类型format值的格式
"reference" //引用 "color" //颜色 "boolean" //布尔值 "dimension" // ...
- 【转】VirtualBox direct access to SD Card in Windows--不错
原文网址:http://www.sandyscott.net/2013/08/14/virtualbox-direct-drive-access/ I’ve trying to get my Rasp ...
- Android录音服务
MediaRecorder Mediarecorder=new MediaRecorder();//创建一个MediaRecorder对象 Mediarecorder.setAudioSource(M ...
- 百度全站变https
今天打开百度首页,突然发现,百度的网址变为 https://www.baidu.com/,如下图: 好嘛,以后再也不怕别人使用抓包工具查看我在百度的搜索数据了.当年的Duck Duck Go就是因为是 ...
- javascript 倒计时天、小时、分钟、描述的倒计时代码
调用方法 var _TimeCountDown = new TimeCountDown("sttime1",{ startTime:'2016-07-30 10:07:55', / ...
- less.css基础学习,陆续更新中
//基础//概念:动态样式语言,有很多语言的特性:变量,函数,运算等 //变量:通过一个简单的@+字母,数字下划线等,但不能以数字开头,不能关键字,保留字等//注意less.css是全局变量,除在函数 ...
- PHPSTORM实用快捷键
alt + F7 find usages 功能,可以很方便的找到函数在哪里调用了 Ctrl + E 可查看最近打开文件或项目 项目名右键选择"Local History | Show His ...
- 关闭钩子(shutdown hook)的作用
DK1.3介绍了java.lang.Runtime class的addShutdownHook()方法.如果你需要在你的程序关闭前采取什么措施,那么关闭钩子(shutdown hook)是很有用的. ...
- Ftp实现文件同步
通常在做服务器与服务器文件.服务器与本地文件同步时通过Ftp服务实现,下面就以服务器文件和本地同步为例,介绍一下Ftp同步文件:首先建立一个Ftp站点服务,基本身份验证登陆,端口号为默认的21:Ftp ...