草庐IT

ios - 原因 : '-[_UIFullscreenPresentationController adaptivePresentationController]:

coder 2023-09-04 原文

我已将搜索栏添加到我的表格 View 中。但是当我在我的表格 View 中搜索某些内容时,如果我按下搜索栏的取消默认按钮以关闭我的键盘,则意味着我的应用程序崩溃了。

崩溃报告:

*** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[_UIFullscreenPresentationController adaptivePresentationController]: unrecognized selector sent to instance 0x7ff10a88cd80'
*** First throw call stack:
(
    0   CoreFoundation                      0x000000010b18ed85 __exceptionPreprocess + 165
    1   libobjc.A.dylib                     0x000000010ca8adeb objc_exception_throw + 48
    2   CoreFoundation                      0x000000010b197d3d -[NSObject(NSObject) doesNotRecognizeSelector:] + 205
    3   CoreFoundation                      0x000000010b0ddcfa ___forwarding___ + 970
    4   CoreFoundation                      0x000000010b0dd8a8 _CF_forwarding_prep_0 + 120
    5   UIKit                               0x000000010dfda4c2 -[UISearchController _searchPresentationController] + 134
    6   UIKit                               0x000000010db8ad77 -[_UISearchControllerTransplantSearchBarAnimator animateTransition:] + 215
    7   UIKit                               0x000000010d6f148f __56-[UIPresentationController runTransitionForCurrentState]_block_invoke + 2638
    8   UIKit                               0x000000010d58ef62 _runAfterCACommitDeferredBlocks + 317
    9   UIKit                               0x000000010d5a2e4c _cleanUpAfterCAFlushAndRunDeferredBlocks + 95
    10  UIKit                               0x000000010d5af147 _afterCACommitHandler + 90
    11  CoreFoundation                      0x000000010b0b3c37 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 23
    12  CoreFoundation                      0x000000010b0b3ba7 __CFRunLoopDoObservers + 391
    13  CoreFoundation                      0x000000010b0a97fb __CFRunLoopRun + 1147
    14  CoreFoundation                      0x000000010b0a90f8 CFRunLoopRunSpecific + 488
    15  GraphicsServices                    0x000000010ff92ad2 GSEventRunModal + 161
    16  UIKit                               0x000000010d582f09 UIApplicationMain + 171
    17  Screen 6                            0x000000010a791e82 main + 114
    18  libdyld.dylib                       0x000000010f1c892d start + 1
    19  ???                                 0x0000000000000001 0x0 + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
(lldb) 

这是我的代码:

import UIKit
import CoreLocation

class ContainerViewController: UIViewController, CLLocationManagerDelegate, UITableViewDelegate, UITableViewDataSource {


       let searchConroller = UISearchController(searchResultsController: nil)



    @IBOutlet var TableViewList: UITableView!

       // array to store the value from json
    var arrDict = [Businessdata]()
     var filteredData = [Businessdata]()
    var marrFilteredCountryList = [String]()


    override func viewDidLoad() {

        super.viewDidLoad()
          searchConroller.searchBar.hidden = true





     searchConroller.searchResultsUpdater = self
        searchConroller.dimsBackgroundDuringPresentation = false
        definesPresentationContext = true


    }



    func filterContentForSearch(searchText: String, scope: String = "All")
    {

        filteredData = arrDict.filter { Businessdata in
            return Businessdata.BusinessName!.lowercaseString.containsString(searchText.lowercaseString)
        }
        TableViewList.reloadData()
    }

    override func viewDidAppear(animated: Bool)
    {
        self.LocationLabel.text = "in Toronto, ON"
        self.TypeLabel.text = BTdata?.BTNames
        self.BTypeId = BTdata?.BTIds
        LoadBusinesses()
    }



    override func viewWillDisappear(animated: Bool)
    {
        super.viewWillDisappear(animated)
        self.navigationController?.navigationBarHidden = false
    }


    @IBAction func searchPressed(sender: AnyObject)
    {
//        



        if searchConroller.searchBar.hidden
        {
             searchConroller.searchBar.hidden = false
            TableViewList.tableHeaderView = searchConroller.searchBar
             //yConstraint.constant = 44;
        }
        else
        {
            searchConroller.searchBar.hidden = true
            //-searchBar.bounds.height
              yConstraint.constant = 0;

        }

    }


    // web services method
    func LoadBusinesses()
    {
        self.arrDict.removeAll()

        let token = NSUserDefaults.standardUserDefaults().valueForKey("access_token") as! String

        let headers = ["x-access-token": token]

        var StringUrl:String = "http://some url”

        StringUrl += "?lat=\(self.NewCurrentLatitude)"

        StringUrl += "&long=\(self.NewCurrentLongitude)"

        let request = NSMutableURLRequest(URL: NSURL(string: StringUrl)!,
                                          cachePolicy: .UseProtocolCachePolicy,
                                          timeoutInterval: 10.0)
        request.HTTPMethod = "GET"
        request.allHTTPHeaderFields = headers

        let session = NSURLSession.sharedSession()
        let dataTask = session.dataTaskWithRequest(request, completionHandler: { (data, response, error) -> Void in
            if (error != nil)
            {
                print(error)
            }
            else
            {
                dispatch_async(dispatch_get_main_queue(),{

                if let json = (try? NSJSONSerialization.JSONObjectWithData(data!, options: [])) as? NSDictionary
                {
                    let success = json["success"] as? Int

                    if (success == 1)
                    {
                        if let reposArray = json["data"] as? [NSDictionary]
                        {
                                for item in reposArray
                                {
                                    let itemObj = item as? Dictionary<String,AnyObject>

                                    let b_type = itemObj!["business_type"]

                                    // taxis type
                                    if (b_type as? String == self.BTypeId)
                                    {
                                        self.arrDict.append(Businessdata(json:item))
                                        self.TableViewList.reloadData()
                                    }
                                }
                        }
                    }
                    else
                    {
                        let message = json["message"] as? String
                        print(message)
                    }
                }
                else
                {
                    print("Json Data error")
                }
                })
            }
        })
        dataTask.resume()
    }


    func numberOfSectionsInTableView(tableView: UITableView) -> Int
    {
        //
        var numOfSection: NSInteger = 0

        if arrDict.count > 0
        {
            self.TableViewList.backgroundView = nil
            numOfSection = 1
        }
        else
        {
            let noDataLabel: UILabel = UILabel(frame: CGRectMake(0, 0, self.TableViewList.bounds.size.width, self.TableViewList.bounds.size.height))
            noDataLabel.text = "No Data Available"
            noDataLabel.textColor = UIColor(red: 22.0/255.0, green: 106.0/255.0, blue: 176.0/255.0, alpha: 1.0)
            noDataLabel.textAlignment = NSTextAlignment.Center
            self.TableViewList.backgroundView = noDataLabel
        }
        return numOfSection
    }


    // number of rows
    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int
    {
        ResultCount.text = String(self.arrDict.count)+" Results"

//        if searchConroller.active && searchConroller.searchBar.text = "" {
//            
//            return filteredData.count
//        }

        if searchConroller.active && searchConroller.searchBar.text! != "" {

             return filteredData.count
        }
        else
        {
       return self.arrDict.count
        }
    }

    // header view
    func tableView(tableView: UITableView, viewForHeaderInSection section: Int) -> UIView?
    {
        let headerView = UIView()
        headerView.backgroundColor = UIColor.clearColor()
        return headerView
    }

    // calling each cell based on tap and users ( premium / non premium )
    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell
    {
        if((arrDict[indexPath.row].FeaturedBusiness) != nil)
        {
            let cell1:premiumUsercell = tableView.dequeueReusableCellWithIdentifier("cell3") as! premiumUsercell

            cell1.phoneNumber = arrDict[indexPath.section].ContactNumber!
            cell1.vendorName3.text = arrDict[indexPath.section].BusinessName
            cell1.vendorAdddress3.text = arrDict[indexPath.section].Address
            cell1.VendorRating3.rating = arrDict[indexPath.section].Rating!

            cell1.latlng = arrDict[indexPath.section].BusinessLatLng!

            latlng = arrDict[indexPath.section].BusinessLatLng!


            let FeaturedValues = arrDict[indexPath.row].FeaturedBusiness

            cell1.FeaturedDisplayText.text = FeaturedValues!.valueForKey("display_text") as? String

            let BImage = arrDict[indexPath.section].StoreImages

            let BMainImage = BImage![0] as! NSDictionary

            let FinalImage = BMainImage.valueForKey("url") as! String

            if let imgURL2 = NSURL(string: FinalImage)
            {
                let request: NSURLRequest = NSURLRequest(URL: imgURL2)

                let session = NSURLSession.sharedSession()

                let Imgtask = session.dataTaskWithRequest(request)
                {
                    (data, response, error) -> Void in

                    if (error == nil && data != nil)
                    {
                        func display_image()
                        {
                            cell1.vendorImage.image = UIImage(data: data!)
                        }
                        dispatch_async(dispatch_get_main_queue(), display_image)
                    }
                }
                Imgtask.resume()
            }
            cell1.getDirectionButton.addTarget(self, action: #selector(ContainerViewController.GetDirection), forControlEvents: UIControlEvents.TouchUpInside)

            return cell1
        }




        if searchConroller.active && searchConroller.searchBar.text! != "" {



            let cell:customCell = tableView.dequeueReusableCellWithIdentifier("cell") as! customCell

            cell.vendorName.text = filteredData[indexPath.row].BusinessName
            cell.vendorAddress.text = filteredData[indexPath.row].Address
            cell.VendorRating.rating = filteredData[indexPath.row].Rating!
            return cell
        }
        else

        {
            let cell:customCell = tableView.dequeueReusableCellWithIdentifier("cell") as! customCell

            cell.vendorName.text = arrDict[indexPath.row].BusinessName
            cell.vendorAddress.text = arrDict[indexPath.row].Address
            cell.VendorRating.rating = arrDict[indexPath.row].Rating!
            return cell
        }
    }


    func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath)
    {
        let storyboard: UIStoryboard = UIStoryboard(name: "Main", bundle: nil)

        let vc: BusinessDetailViewController = storyboard.instantiateViewControllerWithIdentifier("BusinessDetailViewController") as! BusinessDetailViewController

        if searchConroller.active && searchConroller.searchBar.text! != "" {
            vc.BusinessData = filteredData[indexPath.row]

        }
        else {
            vc.BusinessData = arrDict[indexPath.row]

        }


      self.presentViewController(vc, animated: true, completion: nil)


    }



}

extension ContainerViewController: UISearchResultsUpdating {
    func updateSearchResultsForSearchController(searchController: UISearchController) {
        filterContentForSearch(searchConroller.searchBar.text!)
    }

}

这是我的第一个项目,请帮助我。如何解决。

谢谢

最佳答案

如果被点击的按钮试图以模态方式呈现一个新的 View Controller ,就会发生这种情况。由于 UISearchController 已经呈现,这可能会导致意外行为或引发异常。

如果您的按钮操作中有任何代码触发了转场,请尝试将转场类型更改为显示。如果您使用的是界面构建器,这将是属性检查器中的 Kind 属性。

关于ios - 原因 : '-[_UIFullscreenPresentationController adaptivePresentationController]:,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37153754/

有关ios - 原因 : '-[_UIFullscreenPresentationController adaptivePresentationController]:的更多相关文章

  1. ruby-on-rails - rails : "missing partial" when calling 'render' in RSpec test - 2

    我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou

  2. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  3. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

  4. ruby - 在 jRuby 中使用 'fork' 生成进程的替代方案? - 2

    在MRIRuby中我可以这样做:deftransferinternal_server=self.init_serverpid=forkdointernal_server.runend#Maketheserverprocessrunindependently.Process.detach(pid)internal_client=self.init_client#Dootherstuffwithconnectingtointernal_server...internal_client.post('somedata')ensure#KillserverProcess.kill('KILL',

  5. ruby - 主要 :Object when running build from sublime 的未定义方法 `require_relative' - 2

    我已经从我的命令行中获得了一切,所以我可以运行rubymyfile并且它可以正常工作。但是当我尝试从sublime中运行它时,我得到了undefinedmethod`require_relative'formain:Object有人知道我的sublime设置中缺少什么吗?我正在使用OSX并安装了rvm。 最佳答案 或者,您可以只使用“require”,它应该可以正常工作。我认为“require_relative”仅适用于ruby​​1.9+ 关于ruby-主要:Objectwhenrun

  6. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

  7. ruby-on-rails - 新 Rails 项目 : 'bundle install' can't install rails in gemfile - 2

    我已经像这样安装了一个新的Rails项目:$railsnewsite它执行并到达:bundleinstall但是当它似乎尝试安装依赖项时我得到了这个错误Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/bin/rubyextconf.rbcheckingforlibkern/OSAtomic.h...yescreatingMakefilemake"DESTDIR="cleanmake"DESTDIR="

  8. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

  9. ruby-on-rails - Rails 中的 NoMethodError::MailersController#preview undefined method `activation_token=' for nil:NilClass - 2

    似乎无法为此找到有效的答案。我正在阅读Rails教程的第10章第10.1.2节,但似乎无法使邮件程序预览正常工作。我发现处理错误的所有答案都与教程的不同部分相关,我假设我犯的错误正盯着我的脸。我已经完成并将教程中的代码复制/粘贴到相关文件中,但到目前为止,我还看不出我输入的内容与教程中的内容有什么区别。到目前为止,建议是在函数定义中添加或删除参数user,但这并没有解决问题。触发错误的url是http://localhost:3000/rails/mailers/user_mailer/account_activation.http://localhost:3000/rails/mai

  10. ruby - 如何验证 IO.copy_stream 是否成功 - 2

    这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下

随机推荐