Панель вкладок прокручивается в верхнюю часть UIViewController при двойном нажатии - PullRequest
0 голосов
/ 13 ноября 2018

Я пытаюсь сделать мой UITabBarController прокрутку к началу страницы при двойном нажатии. Я несколько раз пытался заставить это работать безуспешно. На данный момент у меня есть только один класс для UITabBarController на раскадровке, который связан с кодом. Должен ли я также связать UITabBar? Вот мой код, который я пробовал до сих пор.

  import UIKit

class TabViewController: UITabBarController, UITabBarControllerDelegate {
    var pressedCount: Int = 0


    override func viewDidLoad() {
        super.viewDidLoad()
        self.delegate = self


        // Do any additional setup after loading the view.
    }
    @IBAction func unwindToMain(segue: UIStoryboardSegue) {}

    override func viewWillAppear(_ animated: Bool) {

        super.viewWillAppear(animated)

        self.navigationController?.isNavigationBarHidden = true
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
    override func tabBar(_ tabBar: UITabBar, didSelect item: UITabBarItem) {
        print("Selected item")
    }

    // UITabBarControllerDelegate
    func tabBarController(_ tabBarController: UITabBarController, didSelect viewController: UIViewController) {
        print("Selected view controller")
    }
    func tabBarController(_ TabViewController: UITabBarController, shouldSelect viewController: UIViewController) -> Bool {
        guard let viewControllers = viewControllers else { return false }
        if viewController == viewControllers[selectedIndex] {
            if let nav = viewController as? UINavigationController {
                guard let topController = nav.viewControllers.last else { return true }
                if !topController.isScrolledToTop {
                    topController.scrollToTop()
                    return false
                } else {
                    nav.popViewController(animated: true)
                }
                return true
            }
        }

        return true
    }
}


extension UIViewController {
    func scrollToTop() {
        func scrollToTop(view: UIView?) {
            guard let view = view else { return }

            switch view {
            case let scrollView as UIScrollView:
                if scrollView.scrollsToTop == true {
                    scrollView.setContentOffset(CGPoint(x: 0.0, y: -scrollView.contentInset.top), animated: true)
                    return
                }
            default:
                break
            }

            for subView in view.subviews {
                scrollToTop(view: subView)
            }
        }

        scrollToTop(view: view)
    }

    var isScrolledToTop: Bool {
        if self is UITableViewController {
            return (self as! UITableViewController).tableView.contentOffset.y == 0
        }
        for subView in view.subviews {
            if let scrollView = subView as? UIScrollView {
                return (scrollView.contentOffset.y == 0)
            }
        }
        return true
    }
}

Ответы [ 2 ]

0 голосов
/ 13 ноября 2018

Например:

   var pressedCount: Int = 0

   func tabBar(tabBar: UITabBar, didSelectItem item: UITabBarItem) {

    pressedCount += 1
    if pressedCount > 1 {
        scrollToTop(view: self.view)
        } else {
        //do something for first press
        }
    }
0 голосов
/ 13 ноября 2018

Настройте UITabBar, а затем используйте время уведомления, чтобы заставить внешний мир реагировать! Или запишите количество кликов через агента UITabBarController, а затем уведомите внешний мир, чтобы он ответил!

...