2017-10-29 1 views
0

スワイプ時にnavbarを非表示にして、とviewDidLoad()navigationController?.hidesBarsOnSwipe = trueを実装しましたが、navBarは表示されません。私の場合は、2つの異なるtableViewControllerを切り替えるnavBarの下にカスタムsegmentedControllerを実装しました。スワイプ時にNavBarを非表示にすることができません

これがnavBarが非表示になる理由がわからない場合は、私のアプリはこのように見え、隠したい部分は「チケット」部分です。などenter image description here

マイコード:

class TicketsViewController: UIViewController { 

    var upcomingTableViewController: UpcomingTableViewController! 
    var pastTransactionTableViewController: PastTransactionsTableViewController! 

    let segmentedControllerView: SegmentedController = { 
     let sc = SegmentedController() 
     sc.translatesAutoresizingMaskIntoConstraints = false 
     sc.segmentedController.addTarget(self, action: #selector(segmentedControlValueChanged), for: .valueChanged) 
     sc.segmentedController.selectedSegmentIndex = 0 
     return sc 
    }() 

    let containerView: UIView = { 
     let v = UIView() 
     v.translatesAutoresizingMaskIntoConstraints = false 
     return v 
    }() 

    override func viewWillAppear(_ animated: Bool) { 
     super.viewWillAppear(animated) 
     navigationController?.hidesBarsOnSwipe = true 
    } 

    override func viewDidLoad() { 
     super.viewDidLoad() 

     //These are the two tableViewControllers that are being toggled 
     upcomingTableViewController = UpcomingTableViewController() 
     pastTransactionTableViewController = PastTransactionsTableViewController() 

     setupNavigationBar() 
     setupViews() 
    } 

    @objc func segmentedControlValueChanged(_ sender: UISegmentedControl) { 
     let segmentedControl = sender 

     if segmentedControl.selectedSegmentIndex == 0 { 
      configureChildViewController(childController: upcomingTableViewController, onView: containerView) 
     } else { 
      configureChildViewController(childController: pastTransactionTableViewController, onView: containerView) 
     } 
    } 

    func setupNavigationBar() { 
     Helper.sharedInstance.setupNavigationBar(title: "Tickets", homeVC: self) 
     navigationController?.navigationBar.isTranslucent = false 
     navigationController?.navigationBar.shadowImage = UIImage() 
     navigationController?.hidesBarsOnSwipe = true 
     navigationItem.backBarButtonItem = UIBarButtonItem(title: "", style: UIBarButtonItemStyle.plain, target: nil, action: nil) 
    } 

    func setupViews() { 

     view.addSubview(segmentedControllerView) 
     view.addSubview(containerView) 

     segmentedControllerView.topAnchor.constraint(equalTo: view.topAnchor).isActive = true 
     segmentedControllerView.leftAnchor.constraint(equalTo: view.leftAnchor).isActive = true 
     segmentedControllerView.rightAnchor.constraint(equalTo: view.rightAnchor).isActive = true 
     segmentedControllerView.heightAnchor.constraint(equalToConstant: 44).isActive = true 

     containerView.topAnchor.constraint(equalTo: segmentedControllerView.bottomAnchor, constant: 0).isActive = true 
     containerView.leftAnchor.constraint(equalTo: view.leftAnchor).isActive = true 
     containerView.rightAnchor.constraint(equalTo: view.rightAnchor).isActive = true 
     containerView.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true 

     configureChildViewController(childController: upcomingTableViewController, onView: containerView) 

    } 

    func configureChildViewController(childController: UIViewController, onView: UIView?) { 
     var holderView = UIView() 

     if let onView = onView { 
      holderView = onView 
     } else { 
      holderView = self.view 
     } 

     addChildViewController(childController) 
     holderView.addSubview(childController.view) 
     constraintViewEqual(to: holderView, childControllerView: childController.view) 
     childController.didMove(toParentViewController: self) 
    } 


    func constraintViewEqual(to containerView: UIView, childControllerView: UIView) { 
     childControllerView.translatesAutoresizingMaskIntoConstraints = false 

     childControllerView.topAnchor.constraint(equalTo: containerView.topAnchor).isActive = true 
     childControllerView.leftAnchor.constraint(equalTo: containerView.leftAnchor).isActive = true 
     childControllerView.rightAnchor.constraint(equalTo: containerView.rightAnchor).isActive = true 
     childControllerView.bottomAnchor.constraint(equalTo: containerView.bottomAnchor).isActive = true 
    } 

} 

上記のコードは、このticketsViewControllerのための私の完全なコードです。 hideBarsWhenSwipeが私のnavBarを隠していない理由についていくつかのアドバイスを感謝します。ありがとう。

+0

'viewWillAppear'の中でこのコードを' navigationController?.hidesBarsOnSwipe = true'と呼んでください。 – Mannopson

+0

@Mannopson私はこれを試しました。それも仕事をしなかった。 – Koh

答えて

0

ビューコントローラの高さに合わせて、下にある要素のサイズを変更してみてください。

+0

あなたは2つのtableViewControllerを意味しますか?またはsegmentedControllerView? – Koh

+0

@ Kohあなたはそれらのどれかを使うことができますが、合計はビューコントローラと同じ高さでなければならず、フルサイズをカバーしなければなりません。 –

関連する問題