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

CA_EXTERN NSString * const kCATransitionFromRight //动画从右往左
CA_EXTERN NSString * const kCATransitionFromLeft //动画从左往右
CA_EXTERN NSString * const kCATransitionFromTop //动画从下往上
CA_EXTERN NSString * const kCATransitionFromBottom //动画从上往下
具体实例如下:
实现功能:往工程中导入5张图片素材,创建图像视图控件,然后通过向左或向右扫动手势实现图像视图中图片的轮换,即实现转场动画。
代码如下:
//导入图片素材
//声明属性
- #import "ViewController.h"
- @interface ViewController ()
- @property (strong,nonatomic)UIImageView *imageView;//图像视图
- @property (assign,nonatomic)NSInteger index; //当前图片的索引
- @end
//初始化,创建图像视图控件并设置图片,同时创建扫动手势,添加扫动事件
- - (void)viewDidLoad {
- [super viewDidLoad];
- //设置当前图片为第一张
- self.index = ;
- //初始化图像视图
- self.imageView = [[UIImageView alloc]initWithFrame:self.view.frame];
- self.imageView.contentMode = UIViewContentModeScaleAspectFit;
- [self.imageView setImage:[UIImage imageNamed:[NSString stringWithFormat:@"s%ld.jpg",self.index]]];
- //允许图像视图进行用户交互
- self.imageView.userInteractionEnabled = YES;
- [self.view addSubview:self.imageView];
- //创建扫动手势
- UISwipeGestureRecognizer *leftswipe = [[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(swipe:)];
- //设置扫动方向为向左扫
- leftswipe.direction = UISwipeGestureRecognizerDirectionLeft;
- //添加扫动手势
- [self.imageView addGestureRecognizer:leftswipe];
- //创建扫动手势
- UISwipeGestureRecognizer *rightswipe = [[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(swipe:)];
- //设置扫动方向为向右扫
- rightswipe.direction = UISwipeGestureRecognizerDirectionRight;
- //添加扫动手势
- [self.imageView addGestureRecognizer:rightswipe];
- }
//处理扫动手势事件,进行转场动画的创建并执行动画
- #pragma mark -扫动手势
- -(void)swipe:(UISwipeGestureRecognizer *)sender
- {
- //根据手势的方向改变图片的索引,一共5张图片
- if (sender.direction == UISwipeGestureRecognizerDirectionLeft)//向左扫
- {
- if (self.index > )
- {
- self.index--;
- }
- else
- {
- self.index = ;
- }
- }
- else //向右扫
- {
- if (self.index <)
- {
- self.index++;
- }
- else
- {
- self.index = ;
- }
- }
- //添加转场动画
- CATransition *transition = [[CATransition alloc]init];
- //过渡类型类立方体翻转效果
- transition.type = @"cube";
- //过渡方向为从下往上翻转
- transition.subtype = kCATransitionFromBottom;
- //动画持续时间
- transition.duration = 1.0f;
- //添加转场动画
- [self.imageView.layer addAnimation:transition forKey:@"transition"];
- //设置每一次转场动画后的图像视图的图片
- [self.imageView setImage:[UIImage imageNamed:[NSString stringWithFormat:@"s%ld.jpg",self.index]]];
- }
演示结果如下:
开始时: 左扫或者右扫时:动画立体式的从上往下翻转
iOS:核心动画之转场动画CATransition的更多相关文章
- iOS 页面之间的转场动画控制器间的转换
CATransition类实现层的转场动画.你可以从一组预定义的转换或者通过提供定制的CIFilter实例来指定转场效果. 例如:控制器之间的跳转 LoginViewController *myVC ...
- iOS 7 present/dismiss转场动画
前言 iOS 7以后提供了自定义转场动画的功能,我们可以通过遵守协议完成自定义转场动画.本篇文章讲解如何实现自定义present.dismiss自定义动画. 效果图 本篇文章实现的动画切换效果图如下: ...
- iOS-自定义Model转场动画-仿酷我音乐播放器效果
周末,闲来无事,仿写了酷我音乐播放器效果: 效果图如下: 实现思路: 1.实现手势处理视图旋转 2.自定义Model动画: 1.手势是利用了一个UIPanGestureRecognizer手势: 注意 ...
- 【Swift】IOS开发中自定义转场动画
在IOS开发中,我们model另外一个控制器的时候,一般都使用默认的转场动画. 其实我们可以自定义一些转场动画.达到不同的转场效果. 步骤如下:(photoBrowser是目标控制器) 1.在源控制器 ...
- Android转场动画,Avtivity转场动画;
转场动画 - 共享元素动画 先看效果: Activity1点击小图标开启Activity2: 开启Activity2效果就像是小图标放大了填充上去的,关闭Activity2回到Activity1时又像 ...
- ios开发核心动画五:转场动画
#import "ViewController.h" @interface ViewController () @property (weak, nonatomic) IBOutl ...
- IOS 动画专题 --iOS核心动画
iOS开发系列--让你的应用“动”起来 --iOS核心动画 概览 通过核心动画创建基础动画.关键帧动画.动画组.转场动画,如何通过UIView的装饰方法对这些动画操作进行简化等.在今天的文章里您可以看 ...
- ios基础动画、关键帧动画、动画组、转场动画等
概览 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌.在这里你可以看到iOS中如何使用图层精简非交互式绘图,如何通过核心动画创建基础动画.关键帧动画 ...
- iOS核心动画以及UIView动画的介绍
我们看到很多App带有绚丽狂拽的特效,别出心裁的控件设计,很大程度上提高了用户体验,在增加了实用性的同时,也赋予了app无限的生命力.这些华丽的效果很多都是基于iOS的核心动画原理实现的,本文介绍一些 ...
随机推荐
- 容器适配器之priority_queue
template <class T, class Container = vector<T>, class Compare = less<type ...
- ubuntu 下root用户无法访问声音设备的解决方案
原因:root用户没有对pulsaudio的访问权限,而且pulsaudio默认是不能在root下自动启动解决办法: 一.修改自动启动:编辑 gedit /etc/default/pulseaudio ...
- Readhat Linux5.5 安装SVNService(经验总结)
Subversion独立服务和与apache整合服务. 一 .Svn独立服务安装 操作系统: Redhat Linux5.5 安装包获取: 下载 http://subversion.tigris.or ...
- 开始学习C++ Templates
设计模式的学习以及各种设计模式的C++实现已经告一段落了,解释器模式和迭代器模式,以及模版办法简单的看了一下. 画UML图的时候再重点学习 从今天开始学习Templates.
- poi生成excel
转自:http://www.cnblogs.com/bmbm/archive/2011/12/08/2342261.html 1.首先下载poi-3.6-20091214.jar,下载地址如下: ht ...
- 禁用backspace键的后退功能
禁用backspace键的后退功能,但是可以删除文本内容<script language="JavaScript">document.onkeydown = check ...
- c++中的原子操作
1. c/c++标准中没有定义任何操作符为原子的,操作符是否原子和平台及编译器版本有关 2. GCC提供了一组内建的原子操作,这些操作是以函数的形式提供的,这些函数不需要引用任何头文件 2.1 对变量 ...
- Guava官方文档-RateLimiter类
转载自并发编程网 – ifeve.com RateLimiter 从概念上来讲,速率限制器会在可配置的速率下分配许可证.如果必要的话,每个acquire() 会阻塞当前线程直到许可证可用后获取该许可证 ...
- 算术编码Arithmetic Coding-高质量代码实现详解
关于算术编码的具体讲解我不多细说,本文按照下述三个部分构成. 两个例子分别说明怎么用算数编码进行编码以及解码(来源:ARITHMETIC CODING FOR DATA COIUPRESSION): ...
- AIZU 2251
Merry Christmas Time Limit : 8 sec, Memory Limit : 65536 KB Problem J: Merry Christmas International ...