Swift - CATransition制作过渡动画(页面切换转场效果)

CATransition动画主要在过渡时使用,比如两个页面层级改变的时候添加一个转场效果。CATransition分为两类,一类是公开的动画效果,一类是非公开的动画效果。

1,公开动画效果:
kCATransitionFade:翻页 kCATransitionMoveIn:弹出 kCATransitionPush:推出 kCATransitionReveal:移除

2,非公开动画效果:
"cube":立方体 "suckEffect":吸收 "oglFlip":翻转 "rippleEffect":波纹 "pageCurl":卷页 "cameraIrisHollowOpen":镜头开 "cameraIrisHollowClose":镜头关

3,动画方向类型:
kCATransitionFromRight:从右侧开始实现过渡动画 kCATransitionFromLeft:从左侧开始实现过渡动画 kCATransitionFromTop:从顶部开始实现过渡动画 kCATransitionFromBottom:从底部开始实现过渡动画

4,下面通过一个样例演示:
页面上添加两个分别是红色,蓝色的UIView。当点击屏幕的时候,这两个UIView层级切换,同时会有从左向右推出的效果。


import UIKit
 
class ViewController: UIViewController {
     
    override func viewDidLoad() {
        super.viewDidLoad()
         
        let redView:UIView = UIView(frame: CGRectMake(20,20,280,400))
        redView.backgroundColor = UIColor.redColor()
        self.view.insertSubview(redView, atIndex: 0)
         
        let blueView:UIView = UIView(frame: CGRectMake(20,20,280,400))
        blueView.backgroundColor = UIColor.blueColor()
        self.view.insertSubview(blueView, atIndex: 1)
    }
     
    //点击切换两个红蓝视图
    override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {
        let transition = CATransition()
        transition.duration = 3.0
        transition.type = kCATransitionPush //推送类型
        transition.subtype = kCATransitionFromLeft //从左侧
        self.view.exchangeSubviewAtIndex(1, withSubviewAtIndex: 0)
        self.view.layer.addAnimation(transition, forKey: nil)
    }
     
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 【iOS开发】30多个iOS常用动画,带详细注释 (2014-04-20 14:55:54)转载▼标签: ios开...
    Fun箱Dao柜阅读 5,474评论 0 50
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌。在这里你可以看...
    F麦子阅读 10,531评论 5 13
  • 前言 本文只要描述了iOS中的Core Animation(核心动画:隐式动画、显示动画)、贝塞尔曲线、UIVie...
    GitHubPorter阅读 9,004评论 7 11
  • 2UIView动画 2.1概述 UIView视图的动画功能,可以使在更新或切换视图时有放缓节奏、产生流畅的动画效果...
    Kevin_Junbaozi阅读 5,607评论 0 0
  • 你想减肥,可你觉得减肥不容易,而且你管不住自己的嘴,所以你一推再推,至今也没有制定一份合理的减肥计划 你想有合理的...
    一個傻瓜阅读 1,950评论 0 2