iOS动画之向右拉的抽屉3D效果_IOS

首先我们忽略掉3D效果,先要做的是一个右拉的抽屉效果.

总体思路:

     1.创建一个ContainerViewController容器控制器,然后把左侧选择菜单的SideMenuViewController,和右侧负责显示内容的MainViewController 添加到ContainerViewController中.

     2.给容器控制器ContainerViewController添加一个手势监听,通过修改偏移量完成抽屉效果.

     3.设置anchorPoint,给左侧SideMenuViewController的view以及左上角的图片按钮添加3D效果.

如果想知道详情请看代码,我们这边把核心的部分说下:

给ContainerViewController添加手势监听,然后在监听方法中该去怎么处理:

 func handleGesture(recognizer: UIPanGestureRecognizer) {
    let translation = recognizer.translationInView(recognizer.view!.superview!)

    // (isOpening ? 1.0 : -1.0) isOpening为BOOL值,表示打开或者关闭
    var progress = translation.x / menuWidth * (isOpening ? 1.0 : -1.0)

    // 保证在0~1之间
    progress = min(max(progress, 0), 1.0)

    switch recognizer.state {
    case .Began:

      let isOpen = mainVC.view.frame.origin.x/menuWidth
      isOpening = isOpen == 1.0 ? false:true

      // 为layer的效果添加一个缓存,作用是避免旋转的时候产生锯齿
      sideMenuVC.view.layer.shouldRasterize = true;
      // 设置渲染的范围
      sideMenuVC.view.layer.rasterizationScale = UIScreen.mainScreen().scale

    case .Changed:

      // 核心代码:调整容器中视图的位置 3D效果 以及透明度 以及左上角按钮的翻转效果
      setToPercent(isOpening ? progress: (1.0 - progress))

    case .Ended: fallthrough
    case .Cancelled: fallthrough
    case .Failed:
      // 分页效果
      var targetProgress: CGFloat
      if (isOpening) {
        targetProgress = progress < 0.5 ? 0.0 : 1.0
      }else {
        targetProgress = progress < 0.5 ? 1.0 : 0.0
      }

      // 设置failed状态下的sideMenuVC的view的效果
      UIView.animateWithDuration(animationTime, animations: { () -> Void in
        self.setToPercent(targetProgress)
        }, completion: { (_) -> Void in
        // 记得关闭layer的缓存渲染
        self.sideMenuVC.view.layer.shouldRasterize = false
      })
    default: break
    }
  }

setToPercent方法中的设置:

  func setToPercent(percent: CGFloat) {

    // 调整mainVC.view的位置
    mainVC.view.frame.origin.x = menuWidth * CGFloat(percent)
    // 设置3D效果及透明度
    sideMenuVC.view.layer.transform = menuTransformForPercent(percent)
    sideMenuVC.view.alpha = CGFloat(max(0.2, percent))

    // 左上角按钮的翻转设置
    let mainVc = (mainVC as! UINavigationController).viewControllers.first as? MainViewController
    if let menuButton = mainVc?.menuButton {
      menuButton.imageView.layer.transform = buttonTransformForPercent(percent)
    }
  }

3D效果的核心代码:

  // 根据百分比添加一个3D特效
  func menuTransformForPercent(percent: CGFloat) -> CATransform3D {

    var identify = CATransform3DIdentity
    // m34负责z轴方向的translation(移动),m34= -1/D, 默认值是0, D越小透视效果越明显,这边的1000视情况调整的
    identify.m34 = -1.0/1000

    let remainingPercent = 1.0 - percent
    let angle = remainingPercent * CGFloat(-M_PI_2)

    // 后面3个数为 x y z
    let rotationTransform = CATransform3DRotate(identify, angle, 0.0, 1.0, 0.0)
    // 将值转换成一个矩阵
    let translationTransform =
    CATransform3DMakeTranslation(menuWidth * percent, 0, 0)
    // 将上面两者结合起来
    return CATransform3DConcat(rotationTransform,
      translationTransform)
  }

  // 为按钮添加一个3D效果
  func buttonTransformForPercent(percent: CGFloat) -> CATransform3D {

    var identity = CATransform3DIdentity
    identity.m34 = -1.0/1000

    let angle = percent * CGFloat(-M_PI)
    let rotationTransform = CATransform3DRotate(identity, angle, 1.0, 1.0, 0.0)

    return rotationTransform
  }

以上就是iOS中右拉的抽屉3D效果的实现实例代码,效果是不是很好呢,相信IOS开发的小伙伴通过上面的实例代码一样可以实现这个动画哦。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索ios
, 抽屉效果
抽屉效果ios实现
android 抽屉动画、抽屉动画、ios抽屉效果实现原理、android 抽屉效果、android上下抽屉效果,以便于您获取更多的相关知识。

时间: 2024-12-05 06:32:18

iOS动画之向右拉的抽屉3D效果_IOS的相关文章

iOS点击文字按钮变转圈加载效果_IOS

本文实例为大家分享了iOS点击文字按钮变转圈加载效果的相关代码,供大家参考,具体内容如下 实现效果: 实现代码: // 画弧线 - (void)drawHalfCircle { loadingLayer = [self drawCircle]; // 这个是用于指定画笔的开始与结束点 loadingLayer.strokeStart = 0.0; loadingLayer.strokeEnd = 0.75; } - (CAShapeLayer *)drawCircle { CGRect fram

iOS实现淘宝上拉进入详情页交互效果_IOS

前言 这篇文章主要给大家介绍的是利用iOS实现淘宝中上拉进入详情页交互的效果,下面话不多说,来看看详细的实现过程. 实现分析 可以看到,该页面是分为两部分的,一部分是一开始就能看到的商品信息,然后我们上拉屏幕,屏幕不断往上滚动,滚动到第一部分结束时可以看到底部有"继续拖动,查看图文详情"一行文本出现.继续上拉到一个临界点便触发了翻页,此时第二部分以动画的形式从底部涌出占满整个屏幕.而且效果是该页面整体上移了,即第一部分和第二部分都是上移的. 此时,第二部分占满着整个屏幕,若我们下拉屏幕

iOS动画开发之五——炫酷的粒子效果

iOS动画开发之五--炫酷的粒子效果         在上几篇博客中,我们对UIView层的动画以及iOS的核心动画做了介绍,基本已经可以满足iOS应用项目中所有的动画需求,如果你觉得那些都还不够炫酷,亦或是你灵光一现,想用UIKit框架写出一款炫酷的休闲游戏,那个有一个东西可以帮到你:iOS的粒子效果引擎. 一.粒子发射器         iOS中的粒子效果有两部分组成,一部分为发射器,设置例子发射的宏观属性,另一部分是粒子单元,用于设置相应的粒子属性.粒子发射器是基于Layer层,没错,又是

IOS开发UI篇--IOS动画(Core Animation)总结

一.简介 IOS 动画主要是指Core Animation框架.官方使用文档地址为:Core Animation Guide. Core Animation是IOS和OS X平台上负责图形渲染与动画的基础框架.Core Animation可以作用与动画视图或者其他可视元素,为你完成了动画所需的大部分绘帧工作.你只需要配置少量的动画参数(如开始点的位置和结束点的位置)即可使用Core Animation的动画效果.Core Animation将大部分实际的绘图任务交给了图形硬件来处理,图形硬件会加

IOS动画(Core Animation)总结

一.简介 IOS 动画主要是指Core Animation框架.官方使用文档地址为:Core Animation Guide. Core Animation是IOS和OS X平台上负责图形渲染与动画的基础框架.Core Animation可以作用与动画视图或者其他可视元素,为你完成了动画所需的大部分绘帧工作.你只需要配置少量的动画参数(如开始点的位置和结束点的位置)即可使用Core Animation的动画效果.Core Animation将大部分实际的绘图任务交给了图形硬件来处理,图形硬件会加

iOS动画开发之三——UIView的转场切换

iOS动画开发之三--UIView的转场切换         前两篇博客中,我们分别介绍了UIView动画的两种使用方式,分别为,带block的方式:http://my.oschina.net/u/2340880/blog/484457 ,传统的属性配置的方式:http://my.oschina.net/u/2340880/blog/484538.通过UIView动画的类方法,我们可以十分方便的使View某些属性改变的同时拥有动画效果.这篇博客主要讨论View切换的动画操作.         两

iOS动画开发之二——UIView动画执行的另一种方式

iOS动画开发之二--UIView动画执行的另一种方式         上一篇博客中介绍了UIView的一些常用动画,通过block块,我们可以很方便简洁的创建出动画效果:http://my.oschina.net/u/2340880/blog/484457,这篇博客再介绍一种更加传统的执行UIView的动画的方法.         这种方式相比如block的方式,显得要麻烦一些,apple官方也推荐我们使用带block的创建动画的方式,我们可以将编程重心更多的放在动画逻辑的实现上.使用begi

iOS动画开发之一——UIViewAnimation动画的使用

iOS动画开发之一--UIViewAnimation动画的使用 一.简介       一款APP的成功与否,除了完善的功能外,用户体验也占有极大的比重,动画的合理运用,可以很好的增强用户体验.iOS开发中,常用的动画处理有UIView动画编程和核心动画编程,其中UIView动画使用简便,开发中应用十分广泛.这篇博客,主要讨论UIView的动画使用. 二.UIView动画的几个方法 + (void)animateWithDuration:(NSTimeInterval)duration anima

iOS动画开发之四——核心动画编程(CoreAnimation)

iOS动画开发之四--核心动画编程(CoreAnimation) 一.引言         前几篇博客详细介绍了有关UIView层的动画使用与相关的效果,然而这些动画是UIKit为我们封装好的核心动画层的方法,通过这些方法,我们可以用的更加简便,当然功能也十分强大,基本能达到我们项目的大多需求.但是如果你想更加自由的通过动画操作视图的属性,你就需要跳过UIKit的封装,使用CoreAnimation核心动画层的方法来实现动画. 二.开始前的准备 1.认识一个的朋友         在开始介绍核心