IOS中Swift仿QQ最新版抽屉侧滑和弹框视图

导读

简单用Swift写了一个抽屉效果,可以直接使用并且简单;

很多软件都运了抽屉效果,比如qq的左抽屉,英雄联盟,滴滴打车,和uber等等都运用了抽屉;

效果

iOS抽屉式结构实现分析

主要是在控制器的View上添加了两个View,一个左侧leftView和一个mainView。这里我们自定义一个DrawerViewController,init(mainVC: UIViewController, leftMenuVC: UIViewController, leftWidth: CGFloat)设置,一个mainVC,一个leftMenuVC,和一个宽度,将mainVC和leftMenuVC的view添加到controller的view上(menuVC的view在下面)。

   view.addSubview(leftMenuVC.view)
   view.addSubview(mainVC.view)

   addChildViewController(leftMenuVC)
   addChildViewController(mainVC)

然后首先实现点击方法openLeftMenu和closeLeftMenu(这两个方法主要是计算mainVC的view的位置)方便以后调用。

//MARK: - 打开左侧菜单
  func openLeftMenu() {

    UIView.animate(withDuration: 0.25, delay: 0, options: UIViewAnimationOptions.curveLinear, animations: {

      self.leftVC?.view.transform = CGAffineTransform.identity
      self.mainVC?.view.transform = CGAffineTransform(translationX: self.maxWidth, y: 0)

    }, completion: {

      (finish: Bool) -> () in

      self.mainVC?.view.addSubview(self.coverBtn)

    })

  }

  //MARK: - 关闭左侧菜单
  func closeLeftMenu() {

    UIView.animate(withDuration: 0.25, delay: 0, options: UIViewAnimationOptions.curveLinear, animations: {

      self.leftVC?.view.transform = CGAffineTransform(translationX: -self.maxWidth, y: 0)
      self.mainVC?.view.transform = CGAffineTransform.identity

    }, completion: {

      (finish: Bool) -> () in

      self.coverBtn.removeFromSuperview()

    })

  }

最后给mainVC的view添加屏幕边缘手势,实现mainVC的view跟随手指移动。循环遍历view给每一个一级视图添加手势

for childViewController in (mainVC?.childViewControllers)! {

     addScreenEdgePanGestureRecognizerToView(view: childViewController.view)

   }
//MARK: - 添加屏幕边缘手势
  private func addScreenEdgePanGestureRecognizerToView(view: UIView) {

    let pan = UIScreenEdgePanGestureRecognizer(target: self, action: #selector(edgPanGesture(_:)))
    pan.edges = UIRectEdge.left
    view.addGestureRecognizer(pan)

  }

在平移手势调用的方法中,通过偏移量来确定mainView的frame,实现动画效果

  1. 首先通过pan.translation(in: pan.view).x方法获取偏移量,通过偏移量的正负确定拖动的方向
  2. 当手指松开后需要根据mainView的x值确定其视图是定位到原始位置还是其缩放的位置

打开手势

//MARK: - 屏幕左边缘手势
  func edgPanGesture(_ pan: UIScreenEdgePanGestureRecognizer) {

    let offsetX = pan.translation(in: pan.view).x

    if pan.state == UIGestureRecognizerState.changed && offsetX <= maxWidth {

      mainVC?.view.transform = CGAffineTransform(translationX: max(offsetX, 0), y: 0)
      leftVC?.view.transform = CGAffineTransform(translationX: -maxWidth + offsetX, y: 0)

    } else if pan.state == UIGestureRecognizerState.ended || pan.state == UIGestureRecognizerState.cancelled || pan.state == UIGestureRecognizerState.failed {

      if offsetX > screenW * 0.5 {

        openLeftMenu()

      } else {

        closeLeftMenu()
      }

    }

  }

关闭遮盖手势

//MARK: - 遮盖按钮手势
  func panCloseLeftMenu(_ pan: UIPanGestureRecognizer) {

    let offsetX = pan.translation(in: pan.view).x
    if offsetX > 0 {return}

    if pan.state == UIGestureRecognizerState.changed && offsetX >= -maxWidth {

      let distace = maxWidth + offsetX

      mainVC?.view.transform = CGAffineTransform(translationX: distace, y: 0)
      leftVC?.view.transform = CGAffineTransform(translationX: offsetX, y: 0)

    } else if pan.state == UIGestureRecognizerState.ended || pan.state == UIGestureRecognizerState.cancelled || pan.state == UIGestureRecognizerState.failed {

      if offsetX > screenW * 0.5 {

        openLeftMenu()

      } else {

        closeLeftMenu()
      }

    }

  }

UIPresentationController简介

  1. UIPresentationController是 iOS8 新增的一个API,苹果的官方定义是:对象为所呈现的视图控制器提供高级视图的转换管理(从呈现视图控制器的时间直到它被消除期间);
  2. iOS 8以前就是自定义view,去画一个三角和长方形;
  3. 简单直接的方法用图片

直接贴代码不讲废话

@IBAction func showAlert(_ sender: UIBarButtonItem) {

    let popVC = PopViewController()
    popVC.modalPresentationStyle = UIModalPresentationStyle.popover
    popVC.popoverPresentationController?.barButtonItem = sender
    popVC.popoverPresentationController?.delegate = self
    //可控制三角颜色
    popVC.popoverPresentationController?.backgroundColor = UIColor.white
    present(popVC, animated: true, completion: nil)

  }

  func adaptivePresentationStyle(for controller: UIPresentationController) -> UIModalPresentationStyle {
    return UIModalPresentationStyle.none
  }

  func popoverPresentationControllerShouldDismissPopover(_ popoverPresentationController: UIPopoverPresentationController) -> Bool {
    return true
  }

具体代码可以从这里下载:WLDrawerView_jb51.rar

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • IOS 中弹框的实现方法整理

    IOS 中弹框的实现方法整理 #define iOS8Later ([UIDevice currentDevice].systemVersion.doubleValue >= 8.0) ios 8以前的弹框 @interface RootViewController ()<UIAlertViewDelegate> @end UIAlertView * alert = [[UIAlertView alloc] initWithTitle:@"登陆失败" message:

  • IOS中Swift仿QQ最新版抽屉侧滑和弹框视图

    导读 简单用Swift写了一个抽屉效果,可以直接使用并且简单; 很多软件都运了抽屉效果,比如qq的左抽屉,英雄联盟,滴滴打车,和uber等等都运用了抽屉; 效果 iOS抽屉式结构实现分析 主要是在控制器的View上添加了两个View,一个左侧leftView和一个mainView.这里我们自定义一个DrawerViewController,init(mainVC: UIViewController, leftMenuVC: UIViewController, leftWidth: CGFloat

  • iOS 中Swift仿微信添加提示小红点功能(无数字)

    具体内容详情如下所示: 以分类的方式实现 代码 UITabBar+Extenstion.swift fileprivate let lxfFlag: Int = 666 extension UITabBar { // MARK:- 显示小红点 func showBadgOn(index itemIndex: Int, tabbarItemNums: CGFloat = 4.0) { // 移除之前的小红点 self.removeBadgeOn(index: itemIndex) // 创建小红点

  • iOS中Swift UISearchController仿微信搜索框

    创建一个UISearchController 如果传入的searchResultsController为nil,则表示搜索的结果在当前控制器中显示,现在我让它在searchResultVC中显示 // 创建searchResultVC let searchResultVC = UIViewController() // 设置背景颜色为红色 searchResultVC.view.backgroundColor = UIColor.red let searchController = UISear

  • iOS中Swift指触即开集成Touch ID指纹识别功能的方法

    1.前言 随着移动支付时代的到来,Touch ID 指纹验证迅速被支付宝,微信钱包普及,相信各位朋友使用后也大呼方便.今天写一篇关于指纹解锁的文章. 关于3D Touch 感兴趣的朋友可以看我前篇blog *    iOS- 指压即达,如何集成iOS9里的3D Touch http://www.jb51.net/article/108922.htm 2.指纹验证Touch ID的介绍 相比3D Touch来说,指纹验证Touch ID 的使用比较简单 主要分成两步 1.第一步当然是检测你的手机是

  • Android App中ListView仿QQ实现滑动删除效果的要点解析

    本来准备在ListView的每个Item的布局上设置一个隐藏的Button,当滑动的时候显示.但是因为每次只要存在一个Button,发现每个Item上的Button相互间不好控制.所以决定继承ListView然后结合PopupWindow. 首先是布局文件: delete_btn.xml:这里只需要一个Button <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=

  • iOS中WKWebView仿微信加载进度条

    本文实例为大家分享了WKWebView仿微信加载进度条的具体代码,供大家参考,具体内容如下 WKWebView添加了estimatedProgress属性(double类型),我们可以利用该属性来设置UIProgressView github代码仓库上存放的Demo 为页面添加UIProgressView属性 @property (nonatomic, strong) WKWebView *mywebView; @property (nonatomic, strong) UIProgressVi

  • uniapp中常用的几种提示弹框

    目录 一.成功提示弹框 二.加载提示弹框 三.确认取消提示框 四.列表选择提示弹框 五.自定义图标 总结 一.成功提示弹框 在执行增.删.改.查等提交成功后弹出提示. uni.showToast({ title: '成功提示', //将值设置为 success 或者直接不用写icon这个参数 icon: 'success', //显示持续时间为 2秒 duration: 2000 }) 效果如下: 若icon参数值设置为none,将不显示“√”图标,只显示文字提示. uni.showToast(

  • iOS中仿QQ侧滑菜单功能

    UITabBarController做QQ侧滑菜单效果: 首先要了解UITabBarController的层级结构: UITabBarController加载的其它UIViewController的View都是被添加在UITransitionView上(这是一个私有API),UITransitionView在self.view的0层,UITabBar在的第一层. 所以我的思路是这样的: UITransitionView与UITabBar转移到一个新的View1上去,作为滑动的部分: 在View1

  • iOS中关于Swift UICollectionView横向分页的问题

    下面通过图文并茂的形式给大家介绍UICollectionView横向分页的问题,具体内容详情如下所示: 情况 直接看图 滚前 滚后 已经设置collectionView的isPagingEnabled为true了,可是出现了这种情况,原因就是collectionView的contentSize不够. <UICollectionView: 0x7fc565076000; frame = (0 0; 375 197); clipsToBounds = YES; gestureRecognizers

  • iOS开发中Swift 指纹验证功能模块实例代码

    iOS调用TouchID代码: override func viewDidLoad() { super.viewDidLoad() let context = LAContext() var error: NSError? = nil let canEvaluatePolicy = context.canEvaluatePolicy(LAPolicy.deviceOwnerAuthenticationWithBiometrics, error: &error) as Bool if error

随机推荐