【Swift】IOS开发中自定义转场动画
在IOS开发中,我们model另外一个控制器的时候,一般都使用默认的转场动画。
其实我们可以自定义一些转场动画。达到不同的转场效果。
步骤如下:(photoBrowser是目标控制器)
1.在源控制器中,设置目标控制器的转场代理为 self
//设置Model转场代理
photoBrowser.transitioningDelegate = self
2.同时设置目标控制器的model类型
//设置Model类型
photoBrowser.modalPresentationStyle=UIModalPresentationStyle.Custom
3.定义一个变量记录转场还是退场 (true为转场,false为退场
var isPersent = false
4.在源控制器中设置跳转,目标控制器中设置关闭(动画要选择true)
presentViewController(photoBrowser, animated: true) { () -> Void in }
dismissViewControllerAnimated(true){SVProgressHUD.dismiss()}
5.源控制器遵守两个代理
UIViewControllerTransitioningDelegate,
UIViewControllerAnimatedTransitioning
6.源控制器实现2个代理方法
func animationControllerForPresentedController(presented: UIViewController, presentingController presenting: UIViewController, sourceController source: UIViewController) -> UIViewControllerAnimatedTransitioning?{
//转场
isPersent = true
//源控制器自己负责转场
return self
}
func animationControllerForDismissedController(dismissed: UIViewController) -> UIViewControllerAnimatedTransitioning?{
//退场
isPersent = false
//源控制器自己负责转场
return self
}
7.源控制器再实现2个代理方法
//转场时间
func transitionDuration(transitionContext: UIViewControllerContextTransitioning) -> NSTimeInterval //转场上下文,负责转场动画的具体内容
func animateTransition(transitionContext: UIViewControllerContextTransitioning){
//转场动画
if isPersent{
if let toView = transitionContext.viewForKey(UITransitionContextToViewKey){
//将傀儡视图(用于动画时展现的画面)加入containerView()
transitionContext.containerView().addSubview(self.persentedDummyView!)
toView.frame = CGRectZero
self.persentedDummyView?.frame = CGRectZero UIView.animateWithDuration(2.0, animations: { () -> Void in
self.persentedDummyView?.frame = transitionContext.containerView().frame
toView.frame = UIScreen.mainScreen().bounds
}, completion: { (_) -> Void in
//移除傀儡视图
self.persentedDummyView?.removeFromSuperview()
//加入要正常显示的视图
transitionContext.containerView().addSubview(toView)
//结束
transitionContext.completeTransition(true)
})
}
}
//退场动画
if !isPersent{
if let fromView = transitionContext.viewForKey(UITransitionContextFromViewKey){
//隐藏目标控制器
let fromVC = transitionContext.viewControllerForKey(UITransitionContextFromViewControllerKey) as! HJCPhotoBrowserViewController
fromVC.view.hidden = true
//获得fromVC的快照
let dummy = fromVC.collectionView.visibleCells().last!.snapshotViewAfterScreenUpdates(false)
//将傀儡视图放入containerView
transitionContext.containerView().addSubview(dummy)
//执行动画
UIView.animateWithDuration(2.0, animations: { () -> Void in
dummy.frame = CGRectZero
}, completion: { (_) -> Void in
//移除傀儡视图
dummy.removeFromSuperview()
//结束
transitionContext.completeTransition(true)
})
}
}
} }
【Swift】IOS开发中自定义转场动画的更多相关文章
- iOS开发中自定义字体的方法
http://www.cnblogs.com/iyou/archive/2014/05/25/3751669.html 1. 首先下载你想要设置的字体库,例如设置方正启体简体 2. 添加到工程,一定要 ...
- 【swift,oc】ios开发中巧用自动布局设置自定义cell的高度
ios开发中,遇到自定义高度不定的cell的时候,我们通常的做法是抽取一个frame类,在frame类中预算好高度,再返回. 但是苹果出来自动布局之后...春天来了!!来看看怎么巧用自动布局设置自定义 ...
- Swift开发小技巧--自定义转场动画
自定义转场动画 个人理解为重写了被弹出控制器的modal样式,根据自己的样式来显示modal出来的控制器 例:presentViewController(aVC, animated: true, co ...
- iOS开发——自定义转场动画
首先是UIPresentationController,这个控制器给modal新的viewController提供了下一步的view和转场的管理,从一个viewController被modal出来到被 ...
- iOS开发自定义转场动画
1.转场动画 iOS7之后开发者可以自定义界面切换的转场动画,就是在模态弹出(present.dismiss),Navigation的(push.pop),TabBar的系统切换效果之外自定义切换动画 ...
- 一行代码实现自定义转场动画--iOS自定义转场动画集
WXSTransition 这款非常不错,力推 这是作者源码简书地址: http://www.jianshu.com/p/fd3154946919 这是作者源码github地址 https://git ...
- iOS自定义转场动画实战讲解
iOS自定义转场动画实战讲解 转场动画这事,说简单也简单,可以通过presentViewController:animated:completion:和dismissViewControllerA ...
- iOS自定义转场动画的实现
iOS中熟悉的是导航栏中的push和pop这两种动画效果,在这里我们可以自己实现自己想要的一些转场动画 下面是我自己创建转场动画的过程 1.新建一个文件继承自NSObject ,遵循协议UIViewC ...
- iOS 自定义转场动画
代码地址如下:http://www.demodashi.com/demo/12955.html 一.总效果 本文记录分享下自定义转场动画的实现方法,具体到动画效果:新浪微博图集浏览转场效果.手势过渡动 ...
随机推荐
- alpha冲刺第五天
一.合照 二.项目燃尽图 三.项目进展 调整了一些界面的布局 细化了部分小功能的界面 注册界面和服务器响应了,但是在insert数据库方面出现了错误 四.明日规划 继续研究如何将注册的内容插入数据库 ...
- Twisted 介绍 及TCP广播系统实例
twisted 提供更多传输层 udp,tcp,tls及应用层HTTP,FTP等协议的支持,在开发方法上更提供了丰富的特性来支持异步编程 安装twisted 建议使用anaconda 安装,conda ...
- git中级技能
中级技能(上) 一.实验说明 从本节开始,我们会介绍一些中级和高级的用法,这些用法很少用到,前面三节的内容已经满足了日常工作需要,从本节开始的内容可以简单了解,需要的时候再 ...
- 关于GPUImage的导入
对于GPUImage的使用方面,GitHub上已经非常详细了,就不一一赘述了,但是对于项目的导入来说,最好的方式是 1.下载GPUImage并解压 2.打开压缩包后如图 3.打开终端,cd到此目录 4 ...
- 分布式版本控制系统Git的安装及使用
Git的安装分为客户端安装和服务端安装,鉴于我平时码代码在windows环境下,因此本文客户端安装直接在windows环境,服务端安装在linux环境下(centos). Git客户端安装 客户端下载 ...
- OpenShift实战(三):OpenShift持久化存储Redis
1.模板定义 修改OpenShift自带模板 [root@master1 pv]# oc edit template redis-persistent 添加如下: 2.创建PV 编辑redis pv ...
- confluence搭建详情
Confluence安装&破解&汉化 编辑时间: 2017年7月7日18:01:13 1.介绍 Atlassian Confluence(简称Confluence)是一个专业的wiki ...
- 初次面对c++
第一次实验 2-4源码: #include<iostream> using namespace std; int main() { int day; cin>>day; swi ...
- docker实践
我的docker 学习笔记2 ps axf docker run -d cyf:sshd /usr/sbin -D docker ps docker-enter.sh 686 ps axf ...
- 微信小程序授权获取用户详细信息openid
小程序获取用户的头像昵称openid之类 第一种使用wx.getUserInfo直接获取微信头像,昵称 wx.getUserInfo({ success: function (res) { that. ...