本文介绍了UISearchController导致黑屏Swift 2.0的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我在 iOS 9中使用Swift 2.0 时遇到了一个奇怪的问题。我在我的 tableViewController 中添加了 UISearchController 但它会导致一个奇怪的黑屏问题。当我按下搜索栏并写一些东西时,它显示我的过滤结果没有任何问题,但当我点击另一个标签栏按钮,如书签,之后我点击tableViewController 观看次数最多再次显示黑幕像屏幕截图。

I have a strange problem in iOS 9 with Swift 2.0. I added UISearchController in my tableViewController but it causes a strange black screen problem. When I press the search bar and write something it shows my filtered results without any problem but when I tap another tab bar button like Bookmarks and after that when I tap tableViewController which is Most Viewed again it shows black screen like screen shot.

我的 tableViewController ;

import UIKit

class CitiesTableViewController: UITableViewController, UISearchResultsUpdating {

// MARK: - Class Properties

private var cities = [String]()
private var veterinaries = [Veterinary]()
private var filteredVeterinaries = [Veterinary]()
private var resultSearchController: UISearchController!

// MARK: - TableViewController Life Cycle Methods

override func viewDidLoad() {
    super.viewDidLoad()
    self.getCitiesList()
    self.configureResultsSearchController()
}

override func viewDidDisappear(animated: Bool) {
    super.viewDidDisappear(animated)
    self.resultSearchController.active = false
}

// MARK: - Configuring Search Bar Controller

private func configureResultsSearchController() {
    self.resultSearchController = UISearchController(searchResultsController: nil)
    self.resultSearchController.searchResultsUpdater = self
    self.resultSearchController.dimsBackgroundDuringPresentation = false
    self.resultSearchController.hidesNavigationBarDuringPresentation = false
    self.resultSearchController.searchBar.sizeToFit()
    self.resultSearchController.searchBar.placeholder = "Klinik veya ilçe adı"
    self.tableView.tableHeaderView = self.resultSearchController.searchBar
}

// MARK: - Table view data source

override func numberOfSectionsInTableView(tableView: UITableView) -> Int { return 1 }
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    if self.resultSearchController.active { return self.filteredVeterinaries.count }
    else { return self.cities.count }
}

// MARK: - Table view Delegate Methods

override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
    if (self.resultSearchController.active) {
        self.performSegueWithIdentifier(Constants.ShowDetailViewControllerSegueIdentifier, sender: nil)
    } else {
        self.performSegueWithIdentifier(Constants.ShowTownsTableViewControllerSegueIdentifier, sender: nil)
    }
}

override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCellWithIdentifier(Constants.CellIdentifier, forIndexPath: indexPath)
    if (self.resultSearchController.active) {
        cell.textLabel?.text = self.filteredVeterinaries[indexPath.row].name
        cell.detailTextLabel?.text = self.filteredVeterinaries[indexPath.row].address
        return cell
    } else {
        cell.textLabel?.text = self.cities[indexPath.row]
        return cell
    }
}

// MARK: - PARSE Query Methods

private func getCitiesList() {
    let parseQueries = ParseQueries()
    parseQueries.downloadListData() {
        (let parseResults) in
        if let veterinaries = parseResults as? [Veterinary] {
            self.veterinaries = veterinaries
            for vet in veterinaries {
                if let city = vet.city {
                    self.cities.append(city)
                }
            }
            dispatch_async(dispatch_get_main_queue()) {
                self.cities = HelperMethods().removeDuplicatesAndSort(array: self.cities)
                self.tableView.reloadData()
            }
        }
    }
}

// MARK: - UISearchController Delegate Methods

func updateSearchResultsForSearchController(searchController: UISearchController) {
    self.filteredVeterinaries.removeAll(keepCapacity: false)
    if let searchBarText = searchController.searchBar.text{
        let searchText = searchBarText.lowercaseString
        // Searching with Veterinary Name and Veterinary City
        self.filteredVeterinaries = self.veterinaries.filter({$0.name?.lowercaseString.rangeOfString(searchText) != nil})
        self.filteredVeterinaries += self.veterinaries.filter({$0.town?.lowercaseString.rangeOfString(searchText) != nil})
        tableView.reloadData()
    }
}

这是来自iOS 9的黑屏图像模拟器与真实设备相同。

This is the black screen image from iOS 9 simulator same as real device.

我认为当我点击searchBar时它会消除我的tableView,它无法再次启动。这是一个错误还是什么?

I think its deiniting my tableView when I tap the searchBar and it can't init again. Is this a bug or something ?

如何解决这个问题?

谢谢!

推荐答案

朋友,在 viewDidLoad()中插入此代码行:

Friend, in your viewDidLoad() insert this code line:

self.definesPresentationContext = true

看看我如何放(第29行):

See how I put (line 29):

这篇关于UISearchController导致黑屏Swift 2.0的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

06-22 09:11