zoukankan      html  css  js  c++  java
  • Swift

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

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

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

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


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

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    import UIKit
     
    class ViewController: UIViewController {
         
        override func viewDidLoad() {
            super.viewDidLoad()
             
            var redView:UIView = UIView(frame: CGRectMake(20,20,280,400))
            redView.backgroundColor = UIColor.redColor()
            self.view.insertSubview(redView, atIndex: 0)
             
            var blueView:UIView = UIView(frame: CGRectMake(20,20,280,400))
            blueView.backgroundColor = UIColor.blueColor()
            self.view.insertSubview(blueView, atIndex: 1)
        }
         
        //点击切换两个红蓝视图
        override func touchesBegan(touches: Set<NSObject>, withEvent event: UIEvent) {
            var 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()
        }
    }
  • 相关阅读:
    2017/09/02笔记:ps
    207/08/3学习笔记:pc端网站如何实现移动端适配知识点
    2017/0828xueix笔记:图像替代文本&css绘制的图形
    20170824:面试题笔记
    目前比较全的CSS重设(reset)方法总结
    学习笔记:css3实现多行文字溢出显示省略号&display:box;
    SVG圆形<circle> 标签
    k8s节点分配nodeSelector, Affinity和Anti-Affinity 亲和性和反亲和性
    kubernetes网络介绍
    centos6.7 安装docker
  • 原文地址:https://www.cnblogs.com/Free-Thinker/p/4843421.html
Copyright © 2011-2022 走看看