UITabBarController всегда открывает страницу вверху UIViewController - PullRequest
0 голосов
/ 13 ноября 2018

Я недавно реализовал в своем коде способ прокрутки к вершине UIViewController, дважды нажав значок в UITabBar. Код находится внутри моего UITabBarController кода. Это прекрасно работает, однако неприятный побочный эффект, который я обнаружил, заключается в том, что каждый раз, когда я открываю страницу в своем приложении, он теперь находится на вершине UIViewController вместо того места, где я остановился в последний раз. Я уверен, что где-то в этом коде есть ошибка

   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) {
        pressedCount += 1
        if pressedCount > 1 {
            scrollToTop()
        } else {
            //do something for first press
        }
        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
    }
}

1 Ответ

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

Проблема в том, что когда ваш ViewController исчезает, свойство pressedCount по-прежнему имеет значение 2

То есть к viewWillAppear добавьте эту строку, чтобы сбросить это:

pressedCount = 0

также исправляет оператор if в tabBar didSelect элемент для сброса pressedCount каждый раз, когда пользователь нажимает элемент tabBar дважды

if pressedCount > 1 {
    scrollToTop()
    pressedCount = 0
} else {
    //do something for first press
}
...