ios基础篇(十.一)—— 动画

el/2024/7/17 21:01:58

CADisplayLink

CADisplayLink是一种以屏幕刷新频率触发的时钟机制,每秒钟执行大约60次左右

CADisplayLink是一个计时器,可以使绘图代码与视图的刷新频率保持同步,而NSTimer无法确保计时器实际被触发的准确时间

使用方法:

定义CADisplayLink并制定触发调用方法

将显示链接添加到主运行循环队列

核心动画

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

Core Animation是直接作用在CALayer上的,并非UIView。

动画使用步骤

  • 1. 创建动画对象
  • 2. 设置动画属性
  • 3. 把动画对象添加到某个 CALayer 对象上
  • 4. 需要停止动画:可以调用 remove 方法移除动画

Core Animation的使用步骤

  • 1.使用它需要先添加QuartzCore.framework框架和引入主头文件<QuartzCore/QuartzCore.h>(iOS7不需要)
  • 2.初始化一个CAAnimation对象,并设置一些动画相关属性
  • 3.通过调用CALayer的addAnimation:forKey:方法增加CAAnimation对象到CALayer中,这样就能开始执行动画了
  • 4.通过调用CALayer的removeAnimationForKey:方法可以停止CALayer中的动画

CAAnimation继承结构

注意:

  • 默认动画时长是0.25秒。通过 duration 属性自定义时长(单位:秒  )
  • 当把动画对象添加到 CALayer 中后, 立刻启动动画
  • 动画执行完毕以后, 又回到的原来的位置。

解决1:当动画执行完毕以后再设置位置为最终的位置。

解决2: 动画执行完毕后不要删除 设置

  • fillMode 核心动画的本质:在后台移动图层中的内容,  执行完毕后图层本身的位置并没有发生变化。

CAAnimation

  • 所有动画对象的父类,负责控制动画的持续时间和速度,是个抽象类,不能直接使用,应该使用它具体的子类
  • 属性解析:(红色代表来自CAMediaTiming协议的属性)
  • duration:动画的持续时间
  • repeatCount:动画的重复次数
  • repeatDuration:动画的重复时间
  • removedOnCompletion:默认为YES,代表动画执行完毕后就从图层上移除,图形会恢复到动画执行前的状态。如果想让图层保持显示动画执行后的状态,那就设置为NO,不过还要设置fillMode为kCAFillModeForwards
  • fillMode:决定当前对象在非active时间段的行为.比如动画开始之前,动画结束之后
  • beginTime:可以用来设置动画延迟执行时间,若想延迟2s,就设置为CACurrentMediaTime()+2,CACurrentMediaTime()为图层的当前时间
  • timingFunction:速度控制函数,控制动画运行的节奏
  • delegate:动画代理
- (void)viewDidLoad{[super viewDidLoad];UIView* redView = [[UIView alloc] init];redView.frame = CGRectMake(100, 100, 100, 100);redView.backgroundColor = [UIColor redColor];self.layer = redView.layer;[self.view addSubview:redView];
}- (void)touchesBegan:(NSSet<UITouch*>*)touches withEvent:(UIEvent*)event{// 基本动画// 1.创建动画对象(做什么动画)CABasicAnimation* anim = [[CABasicAnimation alloc] init];// 2.怎么做动画anim.keyPath = @"position.x";//    anim.fromValue = @(10); // 从哪//    anim.toValue = @(300); // 到哪anim.byValue = @(10); // 在自身的基础上增加// 不希望回到原来的位置anim.fillMode = kCAFillModeForwards;anim.removedOnCompletion = NO;// 3.添加动画(对谁做动画)[self.layer addAnimation:anim forKey:nil];
}

CAPropertyAnimation

是CAAnimation的子类,也是个抽象类,要想创建动画对象,应该使用它的两个子类:CABasicAnimation和CAKeyframeAnimation

属性解析:

keyPath:通过指定CALayer的一个属性名称为keyPath(NSString类型),并且对CALayer的这个属性的值进行修改,达到相应的动画效果。比如,指定@”position”为keyPath,就修改CALayer的position属性的值,以达到平移的动画效果

CABasicAnimation

  • CAPropertyAnimation的子类
  • 属性解析:
  • fromValue:keyPath相应属性的初始值
  • toValue:keyPath相应属性的结束值
  • 随着动画的进行,在长度为duration的持续时间内,keyPath相应属性的值从fromValue渐渐地变为toValue
  • 如果fillMode=kCAFillModeForwards和removedOnComletion=NO,那么在动画执行完毕后,图层会保持显示动画执行后的状态。但在实质上,图层的属性值还是动画执行前的初始值,并没有真正被改变。比如,CALayer的position初始值为(0,0),CABasicAnimation的fromValue为(10,10),toValue为(100,100),虽然动画执行完毕后图层保持在(100,100)这个位置,实质上图层的position还是为(0,0)

CAKeyframeAnimation

  • CApropertyAnimation的子类,跟CABasicAnimation的区别是:CABasicAnimation只能从一个数值(fromValue)变到另一个数值(toValue),而CAKeyframeAnimation会使用一个NSArray保存这些数值
  • 属性解析:
  • values:就是上述的NSArray对象。里面的元素称为”关键帧”(keyframe)。动画对象会在指定的时间(duration)内,依次显示values数组中的每一个关键帧
  • path:可以设置一个CGPathRef\CGMutablePathRef,让层跟着路径移动。path只对CALayer的anchorPoint和position起作用。如果你设置了path,那么values将被忽略
  • keyTimes:可以为对应的关键帧指定对应的时间点,其取值范围为0到1.0,keyTimes中的每一个时间值都对应values中的每一帧.当keyTimes没有设置的时候,各个关键帧的时间是平分的 CABasicAnimation可看做是最多只有2个关键帧的CAKeyframeAnimation

- (void)touchesBegan:(NSSet<UITouch*>*)touches withEvent:(UIEvent*)event{// 关键帧动画// 1.做什么动画CAKeyframeAnimation* anim = [[CAKeyframeAnimation alloc] init];// 2.怎么做动画anim.keyPath = @"position";// -----------//    NSValue* v1 = [NSValue valueWithCGPoint:CGPointMake(100, 100)];//    NSValue* v2 = [NSValue valueWithCGPoint:CGPointMake(150, 100)];//    NSValue* v3 = [NSValue valueWithCGPoint:CGPointMake(100, 150)];//    NSValue* v4 = [NSValue valueWithCGPoint:CGPointMake(150, 150)];////    anim.values = @[ v1, v2, v3, v4 ]; // 关键的数据// -----------// 创建路径UIBezierPath* path = [UIBezierPath bezierPathWithArcCenter:CGPointMake(150, 150) radius:100 startAngle:0 endAngle:2 * M_PI clockwise:1];anim.path = path.CGPath; // 路径anim.duration = 2; // 时间anim.repeatCount = INT_MAX; // 重复次数// 3.对谁做动画[self.layer addAnimation:anim forKey:nil];
}

CAAnimationGroup

  • CAAnimation的子类,可以保存一组动画对象,将CAAnimationGroup对象加入层后,组中所有动画对象可以同时并发运行
  • 属性解析:
  • animations:用来保存一组动画对象的NSArray
  • 默认情况下,一组动画对象是同时运行的,也可以通过设置动画对象的beginTime属性来更改动画的开始时间
- (void)touchesBegan:(NSSet<UITouch*>*)touches withEvent:(UIEvent*)event{// 组动画// 1.创建动画CAAnimationGroup* group = [[CAAnimationGroup alloc] init];// ------ 基本动画(自旋转) ------// 1.创建动画对象(做什么动画)CABasicAnimation* anim = [[CABasicAnimation alloc] init];// 2.怎么做动画anim.keyPath = @"transform.rotation";anim.byValue = @(2 * M_PI * 5); // 在自身的基础上增加// ------ 基本动画(自旋转) ------// ------ 关键帧动画(绕着圆转) ------// 1.做什么动画CAKeyframeAnimation* anim1 = [[CAKeyframeAnimation alloc] init];// 2.怎么做动画anim1.keyPath = @"position";// 创建路径UIBezierPath* path = [UIBezierPath bezierPathWithArcCenter:CGPointMake(150, 150) radius:100 startAngle:0 endAngle:2 * M_PI clockwise:1];anim1.path = path.CGPath; // 路径// ------ 关键帧动画(绕着圆转) ------// 2.操作group.animations = @[ anim, anim1 ];// 时间group.duration = 3;// 重复次数group.repeatCount = INT_MAX;// 3.添加动画[self.layer addAnimation:group forKey:nil];
}

CATransition-转场动画

  • CAAnimation的子类,用于做转场动画,能够为层提供移出屏幕和移入屏幕的动画效果。iOS比Mac OS X的转场动画效果少一点 UINavigationController就是通过CATransition实现了将控制器的视图推入屏幕的动画效果
  • 属性解析:
  • type:动画过渡类型
  • subtype:动画过渡方向
  • startProgress:动画起点(在整体动画的百分比)
  • endProgress:动画终点(在整体动画的百分比)

转场动画过渡效果

类型字符串

效果说明

关键字

方向

fade

交叉淡化过渡

YES

 

push

新视图把旧视图推出去 

YES

 

moveIn

新视图移到旧视图上面

YES

 

reveal

将旧视图移开,显示下面的新视图 

YES

 

cube

立方体翻滚效果

 

 

oglFlip

上下左右翻转效果

 

 

suckEffect

收缩效果,如一块布被抽走

 

NO

rippleEffect

水滴效果

 

NO

pageCurl

向上翻页效果

 

 

pageUnCurl

向下翻页效果

 

 

cameraIrisHollowOpen

相机镜头打开效果

 

NO

cameraIrisHollowClose

相机镜头关闭效果

 

NO

@interface ViewController ()
@property (weak, nonatomic) IBOutlet UIImageView* imageView;
@property (nonatomic, assign) NSInteger imageName;
@end@implementation ViewController
// 轻扫手势执行的方法
- (IBAction)imageChange:(UISwipeGestureRecognizer*)sender{self.imageName++;if (self.imageName == 5) {self.imageName = 0;}self.imageView.image = [UIImage imageNamed:[NSString stringWithFormat:@"%ld", self.imageName + 1]];// 1.创建动画CATransition* anim = [[CATransition alloc] init];// 2.操作  动画效果anim.type = @"moveIn";if (sender.direction == UISwipeGestureRecognizerDirectionLeft) {// 从右往左// 方向anim.subtype = kCATransitionFromRight;}else if (sender.direction == UISwipeGestureRecognizerDirectionRight) {// 从左往右// 方向anim.subtype = kCATransitionFromLeft;}// 3.添加动画[self.imageView.layer addAnimation:anim forKey:nil];
}
- (void)viewDidLoad{[super viewDidLoad];self.imageName = 0;
}
- (void)didReceiveMemoryWarning{[super didReceiveMemoryWarning];
}
@end

使用UIView动画函数实现转场动画——单视图

+ (void)transitionWithView:(UIView *)view duration:(NSTimeInterval)duration options:(UIViewAnimationOptions)options animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion;

参数说明:

  • duration:动画的持续时间
  • view:需要进行转场动画的视图
  • options:转场动画的类型
  • animations:将改变视图属性的代码放在这个block中
  • completion:动画结束后,会自动调用这个block

使用UIView动画函数实现转场动画——双视图

+ (void)transitionFromView:(UIView *)fromView toView:(UIView *)toView duration:(NSTimeInterval)duration options:(UIViewAnimationOptions)options completion:(void (^)(BOOL finished))completion; 

参数说明:

  • duration:动画的持续时间
  • options:转场动画的类型
  • animations:将改变视图属性的代码放在这个block中
  • completion:动画结束后,会自动调用这个block

UIView动画

UIKit直接将动画集成到UIView类中,当内部的一些属性发生改变时,UIView将为这些改变提供动画支持

执行动画所需要的工作由UIView类自动完成,但仍要在希望执行动画时通知视图,为此需要将改变属性的代码放在[UIView beginAnimations:nil context:nil][UIView commitAnimations]之间

常见方法解析:

+ (void)setAnimationDelegate:(id)delegate 

设置动画代理对象,当动画开始或者结束时会发消息给代理对象

 + (void)setAnimationWillStartSelector:(SEL)selector

当动画即将开始时,执行delegate对象的selector,并且把beginAnimations:context:中传入的参数传进selector +

(void)setAnimationDidStopSelector:(SEL)selector 

当动画结束时,执行delegate对象的selector,并且把beginAnimations:context:中传入的参数传进selector

UIView动画

+ (void)setAnimationDuration:(NSTimeInterval)duration
动画的持续时间,秒为单位
+ (void)setAnimationDelay:(NSTimeInterval)delay
动画延迟delay秒后再开始
+ (void)setAnimationStartDate:(NSDate *)startDate
动画的开始时间,默认为now
+ (void)setAnimationCurve:(UIViewAnimationCurve)curve
动画的节奏控制,具体看下面的”备注”
+ (void)setAnimationRepeatCount:(float)repeatCount
动画的重复次数
+ (void)setAnimationRepeatAutoreverses:(BOOL)repeatAutoreverses
如果设置为YES,代表动画每次重复执行的效果会跟上一次相反
+ (void)setAnimationTransition:(UIViewAnimationTransition)transition forView:(UIView *)view cache:(BOOL)cache
设置视图view的过渡效果, transition指定过渡类型, cache设置YES代表使用视图缓存,性能较好

Block动画

+ (void)animateWithDuration:(NSTimeInterval)duration delay:(NSTimeInterval)delay options:(UIViewAnimationOptions)options animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion
参数解析:
duration:动画的持续时间
delay:动画延迟delay秒后开始
options:动画的节奏控制
animations:将改变视图属性的代码放在这个block中
completion:动画结束后,会自动调用这个block
+ (void)transitionWithView:(UIView *)view duration:(NSTimeInterval)duration options:(UIViewAnimationOptions)options animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion
参数解析:
duration:动画的持续时间
view:需要进行转场动画的视图
options:转场动画的类型
animations:将改变视图属性的代码放在这个block中
completion:动画结束后,会自动调用这个block
+ (void)transitionFromView:(UIView *)fromView toView:(UIView *)toView duration:(NSTimeInterval)duration options:(UIViewAnimationOptions)options completion:(void (^)(BOOL finished))completion
方法调用完毕后,相当于执行了下面两句代码:
// 添加toView到父视图
[fromView.superview addSubview:toView]; 
// 把fromView从父视图中移除
[fromView.superview removeFromSuperview];
参数解析:
duration:动画的持续时间
options:转场动画的类型
animations:将改变视图属性的代码放在这个block中
completion:动画结束后,会自动调用这个block

UIImageView的帧动画

UIImageView可以让一系列的图片在特定的时间内按顺序显示
相关属性解析:
animationImages:要显示的图片(一个装着UIImage的NSArray)
animationDuration:完整地显示一次animationImages中的所有图片所需的时间
animationRepeatCount:动画的执行次数(默认为0,代表无限循环)
相关方法解析:
- (void)startAnimating; 开始动画
- (void)stopAnimating;  停止动画
- (BOOL)isAnimating;  是否正在运行动画

UIActivityIndicatorView

是一个旋转进度轮,可以用来告知用户有一个操作正在进行中,一般用initWithActivityIndicatorStyle初始化
方法解析:
- (void)startAnimating; 开始动画
- (void)stopAnimating;  停止动画
- (BOOL)isAnimating;  是否正在运行动画
UIActivityIndicatorViewStyle有3个值可供选择:
UIActivityIndicatorViewStyleWhiteLarge   //大型白色指示器    
UIActivityIndicatorViewStyleWhite      //标准尺寸白色指示器    
UIActivityIndicatorViewStyleGray    //灰色指示器,用于白色背景

 


http://www.ngui.cc/el/3419344.html

相关文章

ios基础篇(十一)—— 同步/异步、进程/线程、pthread、线程状态、线程同步、自动释放池

多线程 一、同步/异步 1、1同步 我们之前写程序的时候都是从上到下,从左到右,代码执行顺序1个人执行多个任务,也是依次执行&#xff0c;1个人同一时间执行1个任务 1.2异步 多个人可以同时执行多个任务 二、进程/线程 2.1进程 进程是指在系统中正在运行的一个应用程序每个…

ios基础篇(十二)—— 消息循环、GCD、任务和队列、串行、并行、Barrier阻塞、延时操作、一次性执行

一、消息循环 什么是消息循环 Runloop就是消息循环&#xff0c;每一个线程内部都有一个消息循环只有主线程的消息循环默认开启&#xff0c;子线程的消息循环默认不开启消息循环的目的 保证程序不退出负责处理输入事件如果没有事件发生&#xff0c;会让程序进入休眠状态 1.1 消…

ios基础篇(十三)—— 调度组、NSOperationQueue

一、调度组 有时候需要在多个异步任务都执行完成之后继续做某些事情&#xff0c;比如下载歌曲&#xff0c;等所有的歌曲都下载完毕之后 转到 主线程提示用户 //1 全局队列dispatch_queue_t queue dispatch_get_global_queue(0, 0);//2 调度组dispatch_group_t group dispatc…

ios基础篇(十五)—— SDWebImage

一、SDWebImage介绍 什么是SDWebImage iOS中著名的牛逼的网络图片处理框架包含的功能&#xff1a;图片下载、图片缓存、下载进度监听、gif处理等等用法极其简单&#xff0c;功能十分强大&#xff0c;大大提高了网络图片的处理效率国内超过90%的iOS项目都有它的影子项目地址 ht…

ios基础篇(十六)—— 网络之sockct

一、网络基本概念 客户端&#xff1a;应用 C/S B/S服务器&#xff1a;为客户端提供服务、数据、资源的机器请求&#xff1a;客户端向服务器索取数据响应&#xff1a;服务器对客户端的请求作出反应&#xff0c;一般是返回给客户端数据服务器 内网服务器外网服务器本地测试服…

时序图

一、时序图简介&#xff08;Brief introduction&#xff09; 时序图&#xff08;Sequence Diagram&#xff09;是显示对象之间交互的图&#xff0c;这些对象是按时间顺序排列的。 顺序图中显示的是参与交互的对象及其对象之间消息交互的顺序。 时序图中包括的建模元素主要有&a…

《Objective-C高级编程:iOS与OS X多线程和内存管理》 一 自动引用计数

一、自动引用计数 1.1 内存管理的思考方式 对象操作与objective-c 方法的对应对象操作Object-C 方法生成并持有对象alloc、new、copy、mutableCopy持有对象retain方法释放对象release方法废弃对象dealloc方法1.1.1 自己生成的对象&#xff0c;自己持有 使用以下名称开头的方…

《Objective-C高级编程:iOS与OS X多线程和内存管理》 一 Blocks模式GCD

一、Blocks摘要 Blocks&#xff1a;带有自动变量&#xff08;局部变量&#xff09;的匿名函数。 匿名函数&#xff1a;不带有名称的函数。 int func(int cout); //声明名称为func的函数 int result func(10); // 调用该函数&#xff0c;必须使用该函数的名称 // 若像下面这…

JXCategoryTitleView的使用

最近写项目&#xff0c;遇到了一个vc下面有多个vc 指示器可以点击切换&#xff0c;也可也左右滑动进行切换&#xff0c;解除了JXCategoryTitleView 感觉很好用&#xff1b; 一般要求主vc遵循JXCategoryViewDelegate、JXCategoryListContainerViewDelegate两个协议 子vc遵循JX…

基本编程能力练习

一、首先下载Java的编译环境并安装 JDK下载地址&#xff1a;https://www.oracle.com/java/technologies/javase-jdk15-downloads.html 选择适合自己系统的版本进行安装 这里我选择的是jdk-15_windows-x64_bin.exe 下载完成后直接运行安装&#xff0c;安装位置选择默认的C盘&am…