美文网首页
iOS-常用动画

iOS-常用动画

作者: Imkata | 来源:发表于2019-11-07 16:39 被阅读0次

一. UIView的block动画

UIKit直接将动画集成到UIView类中,当内部的一些属性发生改变时,UIView将为这些改变提供动画支持,其中最常用的就是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
//参数解析:
//view:需要进行转场动画的视图
//duration:动画的持续时间
//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 removeFromSuperview];

//参数解析:
//fromView:被替换的view
//toView:替换的view
//duration:动画的持续时间
//options:转场动画的类型
//completion:动画结束后,会自动调用这个block

二. UIView的首尾式动画

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

常见方法解析:

//设置动画代理对象,当动画开始或者结束时会发消息给代理对象
+ (void)setAnimationDelegate:(id)delegate
//当动画即将开始时,执行delegate对象的selector,并且把beginAnimations:context:中传入的参数传进selector
+ (void)setAnimationWillStartSelector:(SEL)selector   
// 当动画结束时,执行delegate对象的selector,并且把beginAnimations:context:中传入的参数传进selector
+ (void)setAnimationDidStopSelector:(SEL)selector 
//动画的持续时间,秒为单位
+ (void)setAnimationDuration:(NSTimeInterval)duration   
//动画延迟delay秒后再开始
+ (void)setAnimationDelay:(NSTimeInterval)delay  
//动画的开始时间,默认为now
+ (void)setAnimationStartDate:(NSDate *)startDate   
//动画的节奏控制
+ (void)setAnimationCurve:(UIViewAnimationCurve)curve  
//动画的重复次数
+ (void)setAnimationRepeatCount:(float)repeatCount  
//如果设置为YES,代表动画每次重复执行的效果会跟上一次相反
+ (void)setAnimationRepeatAutoreverses:(BOOL)repeatAutoreverses  
//设置视图view的过渡效果, transition指定过渡类型, cache设置YES代表使用视图缓存,性能较好
+ (void)setAnimationTransition:(UIViewAnimationTransition)transition forView:(UIView *)view cache:(BOOL)cache  

补充:

  1. UIView动画与核心动画的区别?
    ① 核心动画只作用在layer层
    ② 核心动画看到的都是假像,它并没有去修改UIView的真实位置

  2. 什么时候使用核心动画?
    ① 当不需要与用户进行交互,使用核心动画
    ② 当要根据路径做动画时,使用核心动画
    ③ 当做转场动画时,使用核心动画(核心动画转场类型比较多)

三. UIImageView的帧动画

UIImageView可以让一系列的图片在特定的时间内按顺序显示。

相关属性解析:

animationImages:要显示的图片(一个装着UIImage的NSArray)
animationDuration:完整地显示一次animationImages中的所有图片所需的时间
animationRepeatCount:动画的执行次数(默认为0,代表无限循环)

相关方法解析:

- (void)startAnimating; 开始动画
- (void)stopAnimating;  停止动画
- (BOOL)isAnimating;  是否正在运行动画

四. UIActivityIndicatorView菊花

UIActivityIndicatorView是一个旋转进度轮,可以用来告知用户有一个操作正在进行中,一般用initWithActivityIndicatorStyle:初始化。

方法解析:

- (void)startAnimating; 开始动画
- (void)stopAnimating;  停止动画
- (BOOL)isAnimating;  是否正在运行动画

UIActivityIndicatorViewStyle有3个枚举值

UIActivityIndicatorViewStyleWhiteLarge   //大型白色指示器    
UIActivityIndicatorViewStyleWhite      //标准尺寸白色指示器    
UIActivityIndicatorViewStyleGray    //灰色指示器,用于白色背景

相关文章

  • iOS-常用动画

    一. UIView的block动画 UIKit直接将动画集成到UIView类中,当内部的一些属性发生改变时,UIV...

  • iOS-常用动画【基础+进阶】

    最近写项目发现越来越没动力了, 底层的东西实在太让人头疼了。。。 所幸研究一点好玩的东西~~那就是特效!!! bi...

  • 随手记

    核心动画翻译https://zsisme.gitbooks.io/ios-/content/chapter14/l...

  • 随手记

    核心动画翻译https://zsisme.gitbooks.io/ios-/content/chapter14/l...

  • 2019-07-15

    iOS高级核心动画技巧 浏览地址:https://zsisme.gitbooks.io/ios-/content/...

  • 转:iOS-常用动画【基础+进阶】

    https://www.jianshu.com/p/995f2816a796 https://www.jiansh...

  • iOS常用的小功能:扫描和生成二维码,涂鸦,得到一些信息设备

    不多说了,附上链接 https://github.com/helloLiYong/iOS- 常用小功能

  • 感觉有用的文章留存

    0.ios核心动画高级技巧https://zsisme.gitbooks.io/ios-/content/inde...

  • iOS-动画

    前言 在我们开发App中,会经常使用到动画去实现一些提示或者更友好的表达一些需要表达的事情,使用动画可以让我们的A...

  • ios-动画

    1.Core Animation是一个复合引擎,它的职责就是尽可能快地组合屏幕上不同的可视内容,这个内容是被分解成...

网友评论

      本文标题:iOS-常用动画

      本文链接:https://www.haomeiwen.com/subject/ouuvbctx.html