文档章节

实现两个页面的转场动画

鹿微微鹿
 鹿微微鹿
发布于 2016/04/13 21:21
字数 1020
阅读 105
收藏 0
appdelegete.m



#import "AppDelegate.h"

#import "FirstViewController.h"

@interface AppDelegate ()


@end


@implementation AppDelegate



- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {

    // Override point for customization after application launch.

     _window = [[UIWindow alloc]initWithFrame:[UIScreen mainScreen].bounds];

    

    [_window setBackgroundColor:[UIColor whiteColor]];

    //1.创建第一个视图控制器的对象


    FirstViewController *first = [[FirstViewController alloc]init];

    

    //2.作为window的根视图控制器

    _window.rootViewController = first;

    

    

    

    

    [_window makeKeyAndVisible];



    return YES;

}


@end


FirstViewController.m

//

//  FirstViewController.m

//  05-模态视图控制器的切换

//

//  Created by 千锋 on 16/4/12.

//  Copyright (c) 2016 樊娟. All rights reserved.

//


#import "FirstViewController.h"

#import "SecondViewController.h"

#import "UIView+FJView.h"

@interface FirstViewController ()


@end


@implementation FirstViewController


#pragma mark -点击按钮实现跳转


- (void)nextView:(UIButton *)btn{

    

//    //1.创建下一个界面的对象

    SecondViewController *second = [[SecondViewController alloc]init];

//    

//#pragma mark -模态化弹出一个界面

//    //2.模态化弹出一个界面

//    //参数1:需要弹出的那个视图控制器对象

//    //参数2:是否有动画

//    //参数3:弹出动画结束后需要做的事情.写在这个block

////    [self presentViewController:second

////        animated:NO completion:^{

////           

////            NSLog(@"下一个界面弹出后需要做的事情写在这儿");

////            

////        }];

////    

//    

//#pragma mark -字符串转场动画

//    //3.切换动画(转场动画) -- 专门用于界面之间切换的动画效果

//    //a.创建一个转场动画的对象

//    

//    CATransition * transition = [CATransition animation];

//    

//    //b.设置动画时间(单位是秒)

//    transition.duration = 1;

//    

//    //c.设置动画效果

//    

//    //字符串

////         pageCurl            向上翻一页

////         pageUnCurl          向下翻一页

////         rippleEffect        滴水效果

////         suckEffect          收缩效果,如一块布被抽走

////         cube                立方体效果

////         oglFlip             上下翻转效果

////         cameraIrisHollowOpen  打开相机的效果

////         cameraIrisHollowClose 关闭相机的效果

//    

//#pragma mark -宏定义动画效果

////    kCATransitionFade   交叉淡化过渡

////         kCATransitionMoveIn 新视图移到旧视图上面

////         kCATransitionPush   新视图把旧视图推出去

////         kCATransitionReveal 将旧视图移开,显示下面的新视图

//    

//    [transition setType:@"pageCurl"];

//    

//    

//    //d.设置动画方向(不是所有的动画效果都有效)

//#pragma mark -设置动画方向

////    kCATransitionFromRight

////        kCATransitionFromLeft(默认值)

////        kCATransitionFromTop

////        kCATransitionFromBottom

//    [transition setSubtype:@"fromLeft"];

//    

//    

//    //e.添加动画效果

//    //转场动画只能添加到layer

//    [self.view.window.layer addAnimation:transition forKey:nil ];

//    

//    //在这儿后面的所有的视图切换都有上面的动画效果

//    //必须关闭切换视图自带的动画效果

//    [self presentViewController:second animated:NO completion:nil];

    

    [self.view.window addTransitionAnimationWithDuration:0.1 animationType:(FJTransitionType) FJ_pageCurl direction:FJ_UP];

    

    [self presentViewController:second animated:YES completion:nil];

}



#pragma mark -生命周期相关的方法

//加载view的时候会调用

- (void)loadView{

    

    [super loadView];

    

    

    

    NSLog(@"%s",__func__);

    

    

}


//view已经加载成功

- (void)viewDidLoad {

    [super viewDidLoad];

    

    //设置当前这个界面的背景颜色

    self.view.backgroundColor = [UIColor lightGrayColor];

    

    //添加一个按钮

    UIButton *button = [[UIButton alloc]initWithFrame:

                        CGRectMake(100, 100, 50, 50)];

    

    button.backgroundColor = [UIColor orangeColor];

    

    [self.view addSubview:button];

    

    //添加事件

    [button addTarget:self action:@selector(nextView:)

     forControlEvents:UIControlEventTouchUpInside];

    

    

    NSLog(@"%s",__func__);

}


//view将要显示

- (void)viewWillAppear:(BOOL)animated{

    

    [super viewWillAppear:animated];

     NSLog(@"%s",__func__);

}


//view已经显示

- (void)viewDidAppear:(BOOL)animated{


    [super viewDidAppear:animated];

     NSLog(@"%s",__func__);

}


//view将要消失

- (void)viewWillDisappear:(BOOL)animated{

    

    [super viewWillDisappear:animated];

     NSLog(@"%s",__func__);

    

}


//view已经消失

-(void)viewDidDisappear:(BOOL)animated{

    

    [super viewWillDisappear:animated];

     NSLog(@"%s",__func__);

}


- (void)didReceiveMemoryWarning {

    [super didReceiveMemoryWarning];

    // Dispose of any resources that can be recreated.

}


@end



SecondViewController.m



#import "SecondViewController.h"

#import "FirstViewController.h"

#import "UIView+FJView.h"

@interface SecondViewController ()


@end


@implementation SecondViewController


#pragma mark -点击按钮回到第一个页面

- (void)preView:(UIButton *)btn{


    //1.回到上一个界面

    //让当前这个视图控制器对象消失

    //参数1:是否动画

    //参数2:动画结束后的事情在这里写block

    //self可以调用这个方法的前提是:self对象是通过present方式弹出的

    //当前调用dismiss方法的视图控制器对象,调用完dismiss方法后会被销毁;

    [self.view.window addTransitionAnimationWithDuration:0.3 animationType:

     FJ_rippleEffect direction:FJ_DOWN];

    [self dismissViewControllerAnimated:NO completion:^{

        

    }];

    

    

}



#pragma mark - 第二个页面的生命周期方法


//加载view的时候会调用

- (void)loadView{

    

    [super loadView];

    

    

    

    NSLog(@"%s",__func__);

    

    

}


//view已经加载成功

- (void)viewDidLoad {

    [super viewDidLoad];

    

    //设置当前这个界面的背景颜色

    self.view.backgroundColor = [UIColor orangeColor];

    

    //添加一个按钮

    UIButton *button = [[UIButton alloc]initWithFrame:

                        CGRectMake(100, 100, 50, 50)];

    

    button.backgroundColor = [UIColor blackColor];

    

    [self.view addSubview:button];

    

    //添加事件

    [button addTarget:self action:@selector(preView:)

     forControlEvents:UIControlEventTouchUpInside];

    

    

    NSLog(@"%s",__func__);

}


//view将要显示

- (void)viewWillAppear:(BOOL)animated{

    

    [super viewWillAppear:animated];

    NSLog(@"%s",__func__);

}


//view已经显示

- (void)viewDidAppear:(BOOL)animated{

    

    [super viewDidAppear:animated];

    NSLog(@"%s",__func__);

}


//view将要消失

- (void)viewWillDisappear:(BOOL)animated{

    

    [super viewWillDisappear:animated];

    NSLog(@"%s",__func__);

    

}


//view已经消失

-(void)viewDidDisappear:(BOOL)animated{

    

    [super viewWillDisappear:animated];

    NSLog(@"%s",__func__);

}




- (void)didReceiveMemoryWarning {

    [super didReceiveMemoryWarning];

    // Dispose of any resources that can be recreated.

}


@end










© 著作权归作者所有

鹿微微鹿
粉丝 8
博文 116
码字总数 71882
作品 0
程序员
私信 提问
VCTransitionsLibrary –自定义iOS交互式转场动画的库

简介 VCTransitionsLibrary 提供了许多适用于入栈,出栈,模态等场景下控制器切换时的转场动画.它本身提供了一个定义好的转场动画库,你可以拖到自己工程中直接使用;也提供了许多拥有不同转场动...

ios122
2015/08/27
2.9K
0
Android转场动画深度解析(3)

终于到了material design转场动画中最好玩,最有特色的一部分了。我们沿用上一篇的图,不过将跳转Activity的代码作如下更改: 然后在BBBActivity的布局文件想要设置共享元素的部分设置,值和...

大头呆
2017/09/11
0
0
iOS视图控制器转场动画

屏幕左边缘右滑返回,TabBar 滑动切换,你是否喜欢并十分依赖这两个操作,甚至觉得 App 不支持这类操作的话简直反人类?这两个操作在大屏时代极大提升了操作效率,其背后的技术便是今天的主题...

_誌念
2017/10/12
0
0
[译]Workcation App – 第四部分. 场景(Scenes)和 RecyclerView 的共享元素转场动画(Shared Element Transition)

原文地址:Workcation App – Part 4. Shared Element Transition with RecyclerView and Scenes 原文作者:Mariusz Brona 译文出自:掘金翻译计划 译者:龙骑将杨影枫 校对者:张拭心、Fex...

龙骑将杨影枫
2017/06/05
0
0
Android转场动画深度解析(2)

紧接着上一篇介绍了Scene和Transition的基本用法后,这篇开始介绍如何运用这些到转场动画中。从A页面到B页面,再从B页面返回到A页面,这就是一个完整的转场过程。而转场动画就是负责来优雅地...

大头呆
2017/09/09
0
0

没有更多内容

加载失败,请刷新页面

加载更多

一套基于SpringBoot+Vue+Shiro 前后端分离 开发的代码生成器

一、前言 最近花了一个月时间完成了一套基于Spring Boot+Vue+Shiro前后端分离的代码生成器,目前项目代码已基本完成 止步传统CRUD,进阶代码优化: 该项目可根据数据库字段动态生成 controll...

郑清
33分钟前
2
0
javascript-十六进制随机颜色

<script> // 编写一个函数,获得一个十六进制的随机颜色的字符串(如#20CD4F) // function randomColor(){ // var r = random(0,255).toString(16); // var g = random(0,255).toString(16......

ACKo
34分钟前
2
0
springBoot +mybatis 出现sql 语句在数据库可以查询到,但是赋值到实体类上就没有的情况?

1.不要老是反复查看自己是否写错了,为啥有的能出来有的出不来? 可以查看配置文件中是否配置全: 如果在application.yml 文件中是如下配置: mybatis: mapper-locations: classpath:mapp...

kuchawyz
47分钟前
2
0
正则表达式

一、RegExp对象 进行验证和查找的API 1、创建对象: (1)用/创建(直接量):var reg=/正则/ig,表达式固定不变时使用 (2)用new创建:var reg=new RegExp(‘正则’,‘ig’),表达式需要...

wytao1995
47分钟前
2
0
实战限流(guava的RateLimiter)

关于限流 常用的限流算法有漏桶算法和令牌桶算法,guava的RateLimiter使用的是令牌桶算法,也就是以固定的频率向桶中放入令牌,例如一秒钟10枚令牌,实际业务在每次响应请求之前都从桶中获取...

程序员欣宸
48分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部