swift 动画切换View心地层次顺序

1.动画效果




2.代码

//
//  AppDelegate.swift
//  AnimationDemo
//
//  Created by 赵超 on 14-6-27.
//  Copyright (c) 2014年 赵超. All rights reserved.
//

import UIKit

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
                            
    var window: UIWindow?
    //响应点击事件
    func onclick(){
        //开始动画
        UIView.beginAnimations("test",context: nil)
        //动画时长
        UIView.setAnimationDuration(1)
        // FlipFromRight
        // CurlUp
        //动画样式
        UIView.setAnimationTransition(UIViewAnimationTransition.CurlUp,
            forView :self.window!,
            cache:true)
        //更改view顺序
        self.window!.exchangeSubviewAtIndex(0,withSubviewAtIndex :1)
        //提交动画
        UIView.commitAnimations()

    }
    func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: NSDictionary?) -> Bool {
        self.window = UIWindow(frame: UIScreen.mainScreen().bounds)
        // Override point for customization after application launch.
        self.window!.backgroundColor = UIColor.whiteColor()
        self.window!.makeKeyAndVisible()
        
        //第一个view
        var vc1=UIView(frame:UIScreen.mainScreen().applicationFrame)
        vc1.backgroundColor=UIColor.grayColor()
        //第二个view
        var vc2 = UIView(frame:UIScreen.mainScreen().applicationFrame)
        vc2.backgroundColor=UIColor.blueColor()
        //添加点击按钮
        var btn=UIButton(frame:CGRectMake(40,40,200,40))
        btn.backgroundColor=UIColor.redColor()
        btn.setTitle("点击切换View",forState: .Normal)
        btn.addTarget(self,action:"onclick",forControlEvents : UIControlEvents.TouchUpInside)
        
        self.window!.addSubview(btn)
        self.window!.addSubview(vc1)
        self.window!.addSubview(vc2)
        //将按钮放到顶层
        self.window!.bringSubviewToFront(btn)
        
        
        return true
    }

    func applicationWillResignActive(application: UIApplication) {
        // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.
        // Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game.
    }

    func applicationDidEnterBackground(application: UIApplication) {
        // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.
        // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
    }

    func applicationWillEnterForeground(application: UIApplication) {
        // Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background.
    }

    func applicationDidBecomeActive(application: UIApplication) {
        // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
    }

    func applicationWillTerminate(application: UIApplication) {
        // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.
    }


}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赵侠客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值