iOS 9中的UISearchController-UISearchBar中的TextField从导航项中裁剪出来

时间:2019-03-27 21:17:50

标签: ios swift ios9 uisearchcontroller

我正在尝试在iOS 9的导航项上获得一个平滑的搜索栏,这意味着我无法使用navigationItem.searchController属性,因为它仅是iOS 11。

class SearchContainerViewController: UITableViewController {
    let dataSource = ["1", "2", "3", "4", "5"]

    override public func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return dataSource.count
    }

    override public func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = UITableViewCell(style: .default, reuseIdentifier: nil)
        cell.textLabel?.text = dataSource[indexPath.row]

        return cell
    }

    override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        dismiss(animated: true, completion: nil)
    }
}

class SearchViewController: UISearchController {
    override func viewDidLoad() {
        super.viewDidLoad()
    }
}

class MyViewController : UIViewController, UISearchResultsUpdating, UISearchBarDelegate {
    lazy var searchButton = UIBarButtonItem(title: "Search", style: UIBarButtonItem.Style.plain, target: self, action: #selector(showSearchBar))

    var searchViewController: SearchViewController = {
        let container = SearchContainerViewController()
        let searchController = SearchViewController(searchResultsController: container)

        return searchController
    }()

    override func viewDidLoad() {
        super.viewDidLoad()

        setupSearchController()
        setupSearchButton()
    }

    func setupSearchController() {
        searchViewController.searchResultsUpdater = self
        searchViewController.searchBar.delegate = self

        searchViewController.dimsBackgroundDuringPresentation = false
        searchViewController.hidesNavigationBarDuringPresentation = false
        searchViewController.searchBar.searchBarStyle = .minimal
        searchViewController.searchBar.showsCancelButton = true

        definesPresentationContext = true
    }

    @objc func showSearchBar() {
        UIView.animate(withDuration: 0.75) {
            self.navigationItem.titleView = self.searchViewController.searchBar
            self.navigationItem.rightBarButtonItem = nil
            self.searchViewController.searchBar.becomeFirstResponder()
        }
    }

    func setupSearchButton() {
        UIView.animate(withDuration: 0.75) {
            self.navigationItem.titleView = nil
            self.navigationItem.rightBarButtonItem = self.searchButton
        }
    }

    //  MARK: Conforms to UISearchResultUpdating

    public func updateSearchResults(for searchController: UISearchController) { }

    func searchBarCancelButtonClicked(_ searchBar: UISearchBar) {
        setupSearchButton()
    }

    override func viewDidAppear(_ animated: Bool) {
        super.viewDidAppear(animated)
        view.layoutSubviews()
    }
}


@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?

    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        // Override point for customization after application launch.
        let newWindow = UIWindow(frame: UIScreen.main.bounds)

        let mainViewController = MyViewController()
        let navigationController = UINavigationController(rootViewController: mainViewController)

        newWindow.backgroundColor = .white
        newWindow.rootViewController = navigationController
        newWindow.makeKeyAndVisible()

        window = newWindow

        return true
    }
}

虽然结果有点令人失望,因为带有StatusBar的textview已从导航项上下文中剪裁出来,但是我做错了什么,还可以做得更好吗?

感谢您的支持。

1 个答案:

答案 0 :(得分:0)

在人们无缘无故地否决该问题之前,我将做一些不同的事情并回答我自己的问题。

之所以发生剪裁,是因为在这两种情况下NavigationItem的高度都不同,因为如果将较大的内容放在titleView中(如searchBar),它们的伸缩性会有所提高。

我已经从navigationItem的开始设置了searchBar,并在应完成的时候略过了他们的isHidden属性。

    @objc private func activateSearch() {
        UIView.animate(withDuration: 0.75) {
            self.navigationItem.titleView?.isHidden = false
            self.navigationItem.rightBarButtonItem = nil
            self.searchController.isActive = true
        }
    }

    private func deactivateSearch() {
        UIView.animate(withDuration: 0.75) {
            self.navigationItem.titleView?.isHidden = true
            self.navigationItem.rightBarButtonItem = self.searchButton
            self.searchController.isActive = false
        }
    }