iOS 中的 Delayed Transition
2024-10-18 15:13:32
Android 的动画体系中,存在一类由 TransitionManager. beginDelayedTransition 管理的动画.这个方法,很特殊.执行此方法后,其后续的 UI 变化,不会立即作用到视图上,而是等下一次更新周期到来时,以动画的形式批量作用到视图上.
至少在我看来,这种设定很新颖.写法也很自然.除此之外,它能批量执行多个 UI 属性值变化的特性,也让人眼前一亮.
iOS 动画,用的最多的也最顺手的是 animateWithDuration, 总感觉它有点 Delayed Transition 的感觉,应该也可以实现类似的执行批量动画的效果.以前,大都是在 Block 里面写某一个视图,某一个属性的变化后的值.那加入里面,同时写多个视图的多个属性变化的值,会发生什么事呢?
竟然真的是,会批量执行多个动画效果,很酷.感兴趣的,可以自己跑下代码.
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
UIView * viewA = [[UIView alloc]initWithFrame:CGRectMake(0, 0, 100, 100)];
viewA.backgroundColor = [UIColor redColor];
[self.view addSubview:viewA];
UIView * viewB = [[UIView alloc] initWithFrame:CGRectMake(0, 100, 100, 100)];
viewB.backgroundColor = [UIColor blueColor];
[self.view addSubview:viewB];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
[UIView animateWithDuration:3 animations:^{
viewA.frame = CGRectMake(100, 150, 30, 100);
viewA.backgroundColor = [UIColor orangeColor];
viewB.frame = CGRectMake(200, 30, 100, 20);
viewB.backgroundColor = [UIColor grayColor];
}];
});
}
另外,Android 动画的 Scene 设定,也会特别,让我对动画的理解又进了一层.Scene 中,存储的是视图的状态视图,而不是一个图片形式的截图.所以,基于两个 Scene,可以做到节点级别的动画切换. Android 中的Scenne,会在 id 相同的节点间加动画效果.如此,也就能解决了我一直以来的一个困惑: 基于图片, 为什么有些 App 可以实现那么复杂精确的动画效果?==> 因为根本就不是以图片来记录视图某一瞬间的状态的,而是真的会记录下视图的完整状态信息.
参考文档
https://developer.android.com/training/transitions/transitions.html
最新文章
- Code Snippets 代码片段
- 关于 android 的setOnItemClickListener 和 setOnItemLongClickListener 同时触发的解决方法
- 多级弹出菜单jQuery插件ZoneMenu
- Phylab2.0 文档汇总
- Sql Server Alter语句
- JDK中的设计模式
- ActiveRecord中andFilterWhere使用
- nginx try_files命令
- 生产环境服务CPU高问题分析
- could not read data from '/Users/xxxx/myapp-Info.plist'
- c#画正弦波
- PYTHON-进阶-ITERTOOLS模块
- 【Debian 8.8】Java 8 安装以及环境变量配置
- jS判断浏览器终端
- linux 下yum使用技巧
- 【工具篇】Sublime Text 2 安装汉化破解、插件包安装教程详解
- 微信小程序数组对象
- 问题:计算foldRight(1)(_-_) 与foldLeft(1)(_-_)值不一样
- datatables 配套bootstrap3样式使用小结(1)
- .NET项目引用黄色小三角以及找不到依赖的解决方法
热门文章
- 《MATLAB从入门到放弃》二维曲线和图形绘制基础(二):使用Help文档学习line、plot、plotyy、subplot、hold绘图函数
- Writing Science 7.10 (The Opening and The Funnel)
- Linux入门之常用命令(6)Bash命令重定向 管线命令
- hdu3065 ac自动机
- PHP浮点型(float)转换为整形(int)/round()保留小数点后几位
- Canal 同步异常分析:Could not find first log file name in binary log index file
- JS表单提交的几种方式
- Python自学笔记-面向对象编程(Mr seven)
- asp.net或者MVC定时自动执行某操作
- windows mysql 操作实践