Swift 2 - SWRevealViewController:当菜单打开时删除前视图上的交互

时间:2016-02-20 20:12:09

标签: ios swift swrevealviewcontroller

我在Swift应用程序中为滑出菜单实现了SWRevealViewController。该框架的一个问题是,当扩展菜单(rearView)时,用户仍然可以与frontView进行交互。由于我的frontView是一个完整的出血地图,因此通过点击frontView来关闭菜单是非常困难的,因为不是将其识别为平移/点按以关闭它而只是移动地图。

Objective-C here存在相同的问题。来自@hardluckbaby的top answer似乎是最好的解决方案,但它在Objective-C中。我已经在Swift中得到了答案的第一部分,我需要第二部分的帮助。

在我的rearView控制器中添加了这两个功能,当后视图(菜单)打开时,这两个功能成功禁用了frontView上的交互:

override func viewWillAppear(animated: Bool) {
  self.revealViewController().frontViewController.view.userInteractionEnabled = false  
}

override func viewWillDisappear(animated: Bool) {
  self.revealViewController().frontViewController.view.userInteractionEnabled = true
}

最后一部分我需要帮助转换为Swift。我想为我的frontView重新启用平移/轻击手势。在我的frontView中,我想将以下内容放在我的ViewDidLoad函数中:

SWRevealViewController *revealController = [self revealViewController];
[revealController panGestureRecognizer];
[revealController tapGestureRecognizer];

如何在Swift中编写最后一部分?

我尝试将其添加到此功能,但它无法识别我的水龙头。我是否需要将其从IF声明中删除?

override func viewDidLoad() {
   super.viewDidLoad()

   if self.revealViewController() != nil {
     self.view.addGestureRecognizer(self.revealViewController().panGestureRecognizer())
     self.view.addGestureRecognizer(self.revealViewController().tapGestureRecognizer())
   }
}

2 个答案:

答案 0 :(得分:4)

找到了一个仍然可以达到相同结果的不同解决方案(当后视图/菜单打开时禁用与frontView的交互)。它还具有“调暗”frontView以使用户专注于菜单的额外好处。

menuController中没有代码,我删除了我在问题中引用的viewWillAppearviewWillDisappear中的代码。

以下是我添加到frontView控制器的内容。一个缺点是,当您打开菜单时,此代码需要包含在您要禁用交互的所有控制器上。

确保将SWRevealViewControllerDelegate添加到您声明课程的位置。

完整的frontViewController代码:

// make sure to add SWRevealViewControllerDelegate to the class declaration
class LocationConfirmViewController: UIViewController, SWRevealViewControllerDelegate {    

  @IBOutlet weak var menuBtn: UIBarButtonItem!

  override func viewDidLoad() {
      super.viewDidLoad()

      //menu button control
      if self.revealViewController() != nil {
        menuBtn.target = self.revealViewController()
        menuBtn.action = "revealToggle:"

        //new line to declare delegate
        self.revealViewController().delegate = self
        self.view.addGestureRecognizer(self.revealViewController().panGestureRecognizer())
      }
  }


  // MARK: - Navigation

  //controls the frontView when the menu is opened.
  //creates a mask that dims the view and blocks any interaction except for tap or pan to close the menu.
  func revealController(revealController: SWRevealViewController!, willMoveToPosition position: FrontViewPosition){
      let tagId = 4207868622

      if revealController.frontViewPosition == FrontViewPosition.Right {
          let lock = self.view.viewWithTag(tagId)
          UIView.animateWithDuration(0.25, animations: {
              lock?.alpha = 0
              }, completion: {(finished: Bool) in
                  lock?.removeFromSuperview()
              }
          )
          lock?.removeFromSuperview()
      } else if revealController.frontViewPosition == FrontViewPosition.Left {
          let lock = UIView(frame: self.view.bounds)
          lock.autoresizingMask = [.FlexibleWidth, .FlexibleHeight]
          lock.tag = tagId
          lock.alpha = 0
          lock.backgroundColor = UIColor.blackColor()
          lock.addGestureRecognizer(UITapGestureRecognizer(target: self.revealViewController(), action: "revealToggle:"))
          self.view.addSubview(lock)
          UIView.animateWithDuration(0.5, animations: {
              lock.alpha = 0.333
              }
          )
      }
  }
}

将@mixth和他的answer here归功于类似的问题。我做了一些更改,并添加了更多关于如何准确实现的描述。由于我是Swift的新手,我很难理解他的答案。希望这有助于其他人。

答案 1 :(得分:1)

您需要将该代码移动到viewDidAppear,因为viewDidLoad只会在第一次调用时调用,而另一个函数将在每次视图显示在屏幕上时调用。