iOS-仿写京东"加入购物车"转场动画

一. 转场效果演示:

"加入购物车"转场动画

二. 实现原理

      上图显示的动画分为Presentation animations 和Dismissal animations. 

      点击右下角紫色按钮(即"加入购物车"按钮), 即触发Presentation: 先设置toView(橙色视图)的frame, 并将toView平移到屏幕下方, 然后使用块动画让fromView(展示手表信息的视图)X方向上旋转 π / 16 度, Z方向上移动-100, 并恢复toView的transform为默认值. 在当前块动画完成的回调中嵌套一个块动画, 以实现fromView在X. Y方向上缩放为原先的0.9. 嵌套块动画的完成回调中, 调用UIView的扩展方法toRetinaImage() -> (UIImage)来绘制fromView, 将其添加到transitionContext的containerView第0层.并调用 transitionContext.completeTransition(true)告知转场结束.还有一个蒙版的细节,这个实现比较简单,直接添加在fromView和toView之间. 

        在蒙版上添加一个tap手势, 触发Dismissal. 此时的fromView是指橙色视图. 而toView是指展示手表信息的控制器视图,由于它在Presentation完成时即已从屏幕上移除(并未释放). toView默认是显示在fromView之上的, 所以通过insert在fromView之下改变两者的层级关系, 然后在Dismissal animations的块动画中使fromView平移到屏幕下方, toView的transform恢复成默认值, 动画完成的回调中调用 transitionContext.completeTransition(true).

源码地址:https://github.com/moonCai/AddShoppingCartTransitionAnimation

三. 思考讨论

    苹果官方文档对于自定义转场动画的介绍中:

" Swapping the values makes it easier to write a single animator that handles both presentations and dismissals. When you design your animator, all you have to do is include a property to know whether it is animating a presentation or dismissal. The only required difference between the two is the following:

For a presentation, add the “to” view to the container view hierarchy.

For a dismissal, remove the “from” view from the container view hierarchy."

     在Dismissal animations执行完之后, 我的代码中没有移除“from” view, 但是通过视图断点, 却看不到“from” view. 之前添加到转场环境容器视图上的截图和蒙版貌似也未显示. 通过认真研读文档和测试, 本人得出以下两个观点(如有不同见解, 欢迎交流指正):

1. Presentation animations转场执行完后, 通过控制台打印发现"from"View的frame 是frame = (20.7 36.8; 372.6 662.4), 但视图层级上并未显示.基于此, 我认为此时fromView和转场环境的容器视图的父子视图关系解除.

2. Dismissal animations执行完以后, 打印转场环境的容器视图, 显示此时容器视图已被释放. 那么添加在它上面的子视图也对应会执行一次release. 但我在自定义push和pop的转场时发现此时容器视图并未销毁, 那么添加在其上的子视图(fromView dimmingView 和imageView)都应该removeFromSuperView, 及时释放内存. 所以,在这里还是建议按照苹果文档中所说的:  For a dismissal, remove the “from” view from the container view hierarchy.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,881评论 4 368
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,052评论 1 301
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 110,598评论 0 250
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,407评论 0 217
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,823评论 3 294
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,872评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,037评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,778评论 0 204
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,505评论 1 247
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,745评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,233评论 1 264
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,568评论 3 260
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,231评论 3 241
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,141评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,939评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,954评论 2 283
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,784评论 2 275

推荐阅读更多精彩内容