2016-11-03 19 views
0

私は間違ってアップロードする場合は私と一緒にご負担ください。Swift 3コンパイラエラー:関数型以外の値を呼び出すことはできません 'Any ?!'

この2行
let lat = ((((dic["results"] as AnyObject).value(forKey: "geometry") as AnyObject).value(forKey: "location") as AnyObject).value(forKey: "lat") as AnyObject).object(0) as! Double 
let lon = ((((dic["results"] as AnyObject).value(forKey: "geometry") as AnyObject).value(forKey: "location") as AnyObject).value(forKey: "lng") as AnyObject).object(0) as! Double 

はというエラーを持ち出す:私は、次の2行とのトラブルを抱えてい

ここ

は、すべてのコードです...これを解決する方法

Cannot call value of non-function type 'Any?!'

わかりませんビューコントローラから。

import UIKit 

protocol LocateOnTheMap { 
    func locateWithLongitude(_ lon: Double, andLatitude lat: Double, andTitle title: String) 
} 

class SearchResultsController: UITableViewController { 

    var searchResults: [String]! 
    var delegate: LocateOnTheMap! 

    override func viewDidLoad() { 
     super.viewDidLoad() 
     self.searchResults = Array() 
     self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: "cellIdentifier") 

    } 

    override func didReceiveMemoryWarning() { 
     super.didReceiveMemoryWarning() 
     // Dispose of any resources that can be recreated. 
    } 

    // MARK: - Table view data source 

    override func numberOfSections(in tableView: UITableView) -> Int { 

     return 1 
    } 

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 

     return self.searchResults.count 
    } 


    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 
     let cell = tableView.dequeueReusableCell(withIdentifier: "cellIdentifier", for: indexPath) 

     cell.textLabel?.text = self.searchResults[indexPath.row] 
     return cell 
    } 



    override func tableView(_ tableView: UITableView, 
          didSelectRowAt indexPath: IndexPath){ 
     // 1 
     self.dismiss(animated: true, completion: nil) 
     // 2 
     let correctedAddress:String! = self.searchResults[indexPath.row].addingPercentEncoding(withAllowedCharacters: CharacterSet.symbols) 
     let url = URL(string: "https://maps.googleapis.com/maps/api/geocode/json?address=\(correctedAddress)&sensor=false") 

     let task = URLSession.shared.dataTask(with: url!, completionHandler: { (data, response, error) -> Void in 
      // 3 
      do { 
       if data != nil{ 
        let dic = try JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.mutableLeaves) as! NSDictionary 

        let lat = ((((dic["results"] as AnyObject).value(forKey: "geometry") as AnyObject).value(forKey: "location") as AnyObject).value(forKey: "lat") as AnyObject).object(0) as! Double 
        let lon = ((((dic["results"] as AnyObject).value(forKey: "geometry") as AnyObject).value(forKey: "location") as AnyObject).value(forKey: "lng") as AnyObject).object(0) as! Double 
        // 4 
        self.delegate.locateWithLongitude(lon, andLatitude: lat, andTitle: self.searchResults[indexPath.row]) 
       } 

      } catch { 
       print("Error") 
      } 
     }) 
     // 5 
     task.resume() 
    } 


    func reloadDataWithArray(_ array:[String]){ 
     self.searchResults = array 
     self.tableView.reloadData() 
    } 
} 
+0

は 'AnyObject'があなたの'聞かせLON =((((DIC [ "結果"]にキャスト交換してみてください。 .. 'このような辞書との行' [String:Any] ' –

答えて

1

Swift 3では、仲介のJSONベースのオブジェクトを右にキャストする必要がありますチェーンを降りる前にタイプしてください。

あなたはこのように行くことができる:

let dic = try JSONSerialization.jsonObject(with: data!, options: JSONSerialization.ReadingOptions.mutableLeaves) as! [String:Any] 

、その後:

let lon = (((dic["results"] as! [String:Any])["geometry"] as! [String:Any]).["location"] as! [String:Any])["lng"] as! Double 
+0

@LBIMBA:これはあなたを助けましたか? –

関連する問題