1、将对应UI控件的层调用以下接口即可

  • 1.1 .h文件

    //
    // 文 件 名:CALayer+Transition.h
    //
    // 版权所有:Copyright © 2018年 leLight. All rights reserved.
    // 创 建 者:leLight
    // 创建日期:2018/7/6.
    // 文档说明:
    // 修 改 人:
    // 修改日期:
    // #import <QuartzCore/QuartzCore.h> @interface CALayer (Transition) /************ 动画类型 *****************************/
    typedef enum { TransitionAnimTypeRippleEffect=0, // 水波
    TransitionAnimTypeSuckEffect, // 吸走
    TransitionAnimTypePageCurl, // 翻开书本
    TransitionAnimTypeOglFlip, // 正反翻转
    TransitionAnimTypeCube, // 正方体
    TransitionAnimTypeReveal, // push推开
    TransitionAnimTypePageUnCurl, // 合上书本
    TransitionAnimTypeRamdom, // 随机
    } TransitionAnimType; /************ 动画方向 *****************************/
    typedef enum { TransitionSubtypesFromTop=0, // 从上
    TransitionSubtypesFromLeft, // 从左
    TransitionSubtypesFromBotoom, // 从下
    TransitionSubtypesFromRight, // 从右
    TransitionSubtypesFromRamdom, // 随机
    } TransitionSubType; /************ 动画曲线 *****************************/
    typedef enum { TransitionCurveDefault, // 默认
    TransitionCurveEaseIn, // 缓进
    TransitionCurveEaseOut, // 缓出
    TransitionCurveEaseInEaseOut, // 缓进缓出
    TransitionCurveLinear, // 线性
    TransitionCurveRamdom, // 随机
    } TransitionCurve; /**
    * 转场动画
    *
    * @param animType 转场动画类型
    * @param subType 转动动画方向
    * @param curve 转动动画曲线
    * @param duration 转动动画时长
    *
    * @return 转场动画实例
    */
    - (CATransition *)transitionWithAnimType:(TransitionAnimType)animType subType:(TransitionSubType)subType curve:(TransitionCurve)curve duration:(CGFloat)duration; @end
  • 1.2 .m文件

    //
    // 文 件 名:CALayer+Transition.m
    //
    // 版权所有:Copyright © 2018年 leLight. All rights reserved.
    // 创 建 者:leLight
    // 创建日期:2018/7/6.
    // 文档说明:
    // 修 改 人:
    // 修改日期:
    // #import "CALayer+Transition.h" @implementation CALayer (Transition) /**
    * 转场动画
    *
    * @param animType 转场动画类型
    * @param subType 转动动画方向
    * @param curve 转动动画曲线
    * @param duration 转动动画时长
    *
    * @return 转场动画实例
    */
    - (CATransition *)transitionWithAnimType:(TransitionAnimType)animType subType:(TransitionSubType)subType curve:(TransitionCurve)curve duration:(CGFloat)duration { NSString *key = @"transition"; if([self animationForKey:key] != nil){
    [self removeAnimationForKey:key];
    } CATransition *transition = [CATransition animation]; // 动画时长
    transition.duration = duration;
    // 动画类型
    transition.type = [self animaTypeWithTransitionType:animType];
    // 动画方向
    transition.subtype = [self animaSubtype:subType];
    // 缓动函数
    transition.timingFunction = [CAMediaTimingFunction functionWithName:[self curve:curve]];
    // 完成动画删除
    transition.removedOnCompletion = YES;
    [self addAnimation:transition forKey:key];
    return transition;
    } /************ 返回动画曲线 *****************************/
    - (NSString *)curve:(TransitionCurve)curve{ // 曲线数组
    NSArray *funcNames = @[
    kCAMediaTimingFunctionDefault,
    kCAMediaTimingFunctionEaseIn,
    kCAMediaTimingFunctionEaseInEaseOut,
    kCAMediaTimingFunctionEaseOut,
    kCAMediaTimingFunctionLinear
    ]; return [self objFromArray:funcNames index:curve isRamdom:(TransitionCurveRamdom == curve)];
    } /************ 返回动画方向 *****************************/
    - (NSString *)animaSubtype:(TransitionSubType)subType { // 设置转场动画的方向
    NSArray *subtypes = @[
    kCATransitionFromTop,
    kCATransitionFromLeft,
    kCATransitionFromBottom,
    kCATransitionFromRight
    ]; return [self objFromArray:subtypes index:subType isRamdom:(TransitionSubtypesFromRamdom == subType)];
    } /************ 返回动画类型 *****************************/
    - (NSString *)animaTypeWithTransitionType:(TransitionAnimType)type { // 设置转场动画的类型
    NSArray *animArray = @[
    @"rippleEffect",
    @"suckEffect",
    @"pageCurl",
    @"oglFlip",
    @"cube",
    @"reveal",
    @"pageUnCurl",
    @"push"
    ];
    return [self objFromArray:animArray index:type isRamdom:(TransitionAnimTypeRamdom == type)];
    } /************ 统一从数据返回对象 *****************************/
    - (id)objFromArray:(NSArray *)array index:(NSUInteger)index isRamdom:(BOOL)isRamdom { NSUInteger count = array.count;
    NSUInteger i = isRamdom?arc4random_uniform((u_int32_t)count):index;
    return array[i];
    } @end

转场动画CALayer (Transition)的更多相关文章

  1. iOS:核心动画之转场动画CATransition

    转场动画——CATransition CATransition是CAAnimation的子类,用于做转场动画,能够为层提供移出屏幕和移入屏幕的动画效果.iOS比Mac OS X的转场动画效果少一点 U ...

  2. Android开发之Activity转场动画

    引子 相信开发过iOS的程序员都知道iOS ViewController之间的跳转动画非常多,很酷对不对?这让开发Android的羡慕不已,曾几何时,Android中的Activity跳转是何等的生硬 ...

  3. Transition 过渡/转场动画(一)

    UIViewController 的转场效果 当viewController通过push 或 present 进行转场时, 系统自带的动画是从右侧push进来一个新的viewControler (或从 ...

  4. ios基础动画、关键帧动画、动画组、转场动画等

    概览 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌.在这里你可以看到iOS中如何使用图层精简非交互式绘图,如何通过核心动画创建基础动画.关键帧动画 ...

  5. iOS 自定义转场动画浅谈

    代码地址如下:http://www.demodashi.com/demo/11612.html 路漫漫其修远兮,吾将上下而求索 前记 想研究自定义转场动画很久了,时间就像海绵,挤一挤还是有的,花了差不 ...

  6. iOS7 push/pop转场动画

    前言 iOS 7之后,苹果提供了自定义转场动画的API,我们可以自己去定义任意动画效果.本篇为笔者学习push.pop自定义转场效果的笔记,如何有任何不正确或者有指导意见的,请在评论中留下您的宝贵意见 ...

  7. CATransition自定义转场动画

    我们可以通过CATransiton来自定义一些漂亮的转场动画, CATransition继承自CAAnimation, 所以用法跟CAAnimation差不多 先直接上一个代码: #import &q ...

  8. iOS 开发--转场动画

    "用过格瓦拉电影,或者其他app可能都知道,一种点击按钮用放大效果实现转场的动画现在很流行,效果大致如下:" 本文主讲SWIFT版,OC版在后面会留下Demo下载 在iOS中,在同 ...

  9. 第六十五篇、OC_iOS7 自定义转场动画push pop

    自定义转场动画,在iOS7及以上的版本才开始出现的,在一些应用中,我们常常需要定制自定义的的跳转动画 1.遵守协议:<UIViewControllerAnimatedTransitioning& ...

随机推荐

  1. 通过PowerShell命令给Azure VM添加CustomScriptExtension

    Azure的VM提供了一种管理工具叫Azure VM Extension.它实现了一些管理虚拟机所需要的重要功能,比如:重设密码.设置RDP参数.以及许多其他关键的功能,并且Azure VM一直在添加 ...

  2. ArcGis教程

    91卫图助手帮助中心-如何导出ArcGIS Server瓦片格式并进行发布 http://help.91weitu.com/rhdcarcgis%20serverwpgsbjxfb.html ArcG ...

  3. java bean Format注解用法

    @NumberFormat(style=Style.NUMBER)    private int number; @DateTimeFormat(pattern="yyyy-MM-dd&qu ...

  4. 通过maven的jar包库找到对应的jar包。

    查找连接: http://search.maven.org/ 查找实例 http://search.maven.org/#search|ga|1|a%3A%22log4j%22

  5. Java基础--HashCode

    如果一个类的对象要用做hashMap的key,那么一定要注意覆盖该类的equals和hashCode方法. equals()是基类Object的方法,用于判断对象是否有相同地址及是否为同一对象 pub ...

  6. MySQL 备份脚本--mysqldump在slave 上进行备份

    MySQL 备份脚本--mysqldump在slave 上进行备份 使用mysqldump在slave上进行备份,建议使用stop slave sql_thread,start slave sql_t ...

  7. 未在本地计算机上注册 Microsoft.ACE.OLEDB.12.0 提供程序

    Visual Studio 8使用了Access数据库,provider选择了ACE.OLEDB,但是运行时出现了错误,提示未在本地计算机上注册"Microsoft.ACE.OLEDB.12 ...

  8. spring Annotation

    使用注解替代xml 在前几章的笔记基础上添加使用注解的形式 1.配置applicationContext 添加context schema <?xml version="1.0&quo ...

  9. 第十章 Executor框架

    在Java中,使用线程来异步执行任务.Java线程的创建与销毁需要一定的开销,如果我们为每一个任务创建一个新线程来执行,这些线程的创建与销毁将消耗大量的计算资源.同时,为每一个任务创建一个新线程来执行 ...

  10. AFNetworking-2.5-源码阅读剖析--网络请求篇

    一.前言 AFNetworking,非常友好简单的网络请求第三方框架,在GitHub中已经获得了25000++的star,链接地址:https://github.com/AFNetworking/AF ...