博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iOS-UIView动画
阅读量:5929 次
发布时间:2019-06-19

本文共 2410 字,大约阅读时间需要 8 分钟。

一、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

  + (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

 

  针对图层CALayer的核心动画是一个“假象”,实质上,图层的属性值还是动画执行前的初始值,并没有真正被改变。而UIView的动画则不同,其属性值会发生改变。

 

转载于:https://www.cnblogs.com/caofutao/p/4843110.html

你可能感兴趣的文章
CSS hack:区分IE6,IE7,firefox
查看>>
简单的记录一次简单的优化
查看>>
添加遮罩弹窗
查看>>
Web开发者必备的20款超赞jQuery插件
查看>>
linux:shell脚本格式
查看>>
Win32编程原理 - 剪切板小程序
查看>>
洛谷P4009 汽车加油行驶问题(分层最短路)
查看>>
js滚轮事件
查看>>
topcoder srm 699 div1 -3
查看>>
实际开发中闭包的应用
查看>>
mui 对话框 点击按钮不关闭对话框的办法
查看>>
python基础===利用unittest进行测试用例执行的几种方式
查看>>
团队作业-个人总结
查看>>
axios 基本运用
查看>>
mysql解决外网不能连接
查看>>
打开控制台F12弹出弹窗
查看>>
《MYSQL技术精粹》读书笔记
查看>>
CSS中的字体设置
查看>>
poj1051
查看>>
区间DP UVA 10739 String to Palindrome
查看>>