2017-05-03 99 views
0

我正在製作一個應用程序,它使用google地方api來搜索用戶位置附近的所有餐館。所以我可以成功檢索餐廳座標(lat,lng),然後我想添加一個標記或一個圓圈到每個地方,但我無法做到這一點。我可以將標記或圓圈添加到一個位置,但是當我嘗試添加到多個位置時,它不顯示標記或圓圈。 這裏是我寫在GMSMapView上放置多個標記Swift

func setUpMarkersForLibraries(locations: [CLLocationCoordinate2D]){ 
    print("Setting up Markers") 
    var i = 0 
    for l in locations{ 
     let circleCenter = l 
     let circ = GMSCircle(position: circleCenter, radius: 30) 

     circ.fillColor = UIColor(red: 0, green: 0.89, blue: 0, alpha: 0.8) 
     circ.strokeColor = .black 
     circ.strokeWidth = 5 
     circ.title = "\(i)" 
     //print("\(i)") 
     i += 1 
     circ.map = mapView 

    } 
} 

的代碼我肯定數組包含了所有的位置和我打印增量i的值在循環,它打印的所有值。但圈子沒有顯示在地圖上。我怎樣才能做到這一點。請幫我解決這個問題。

這裏是我寫的所有代碼。

進口的UIKit 進口的GoogleMaps

類MapsViewController:UIViewController中,CLLocationManagerDelegate {

var mapSet = false 
var allLibraries = [CLLocationCoordinate2D]() 
var loaded = false 
var mapView: GMSMapView? 
var locationManager: CLLocationManager = CLLocationManager() 
var camera = GMSCameraPosition.camera(withLatitude: 0, longitude: 0, zoom: 12) 

override func viewDidLoad() { 
    super.viewDidLoad() 
    locationManager.desiredAccuracy = kCLLocationAccuracyBest 
    locationManager.delegate = self 
    locationManager.requestWhenInUseAuthorization() 
    locationManager.startUpdatingLocation() 
    mapView = GMSMapView(frame: CGRect.zero) 
    view = mapView 
    loadNearByLibraries() 
    //mapView?.animate(to: camera) 
    //mapView.showsUserLocation = true 
    //setUpMap() 
    // Do any additional setup after loading the view. 
} 

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


private func setUpMap(location: CLLocation){ 

    camera = GMSCameraPosition.camera(withLatitude: location.coordinate.latitude, longitude: location.coordinate.longitude, zoom: 15) 
    let updateCamera = GMSCameraUpdate.setCamera(camera) 
    self.mapView?.animate(with: updateCamera) 
    let marker = GMSMarker() 
    marker.position = camera.target 
    marker.title = "My Place" 
    marker.map = self.mapView 

} 


func loadNearByLibraries(){ 
    let urlString = "https://maps.googleapis.com/maps/api/place/nearbysearch/json?location=-33.8670522,151.1957362&radius=500&type=restaurant&keyword=cruise&key=AIzaSyBIDJ50ak-caS3M-6nSVbxdN_SmssAlTRI" 
    let theUrl = URL(string: urlString) 
    if let url = theUrl{ 
     print("Search Called") 
     var urlRequest = URLRequest(url: url) 
     urlRequest.httpMethod = "GET" 
     print("URL : " + url.absoluteString) 
     let task = URLSession.shared.dataTask(with: urlRequest, completionHandler: { 
      (data, response, error) in 

      if response != nil{ 
       if let res = response as? HTTPURLResponse{ 
        if(res.statusCode == 408) 
        { 
         MessageBox.Show(message: "Error : Request TimeOut", title: "Error", view: self) 
        } 

       } 
      } 

      if error != nil{ 
       print("Error \(error?.localizedDescription)") 
       MessageBox.Show(message: (error?.localizedDescription)!, title: "An error occurred", view: self) 

      } 
      else{ 
       print("Printing Json") 
       self.processJson(data: data!) 

      } 
     }) 
     task.resume() 
    } 
} 

func processJson(data: Data){ 
    allLibraries.removeAll() 
    do{ 

     let jsonData = try JSONSerialization.jsonObject(with: data, options: JSONSerialization.ReadingOptions.mutableContainers) as AnyObject 

     let locations = jsonData 
     let results = jsonData["results"] as! NSArray 
     for i in results{ 
      let item = i as! NSDictionary 
      let geom = item["geometry"] as! NSDictionary 
      let loc = geom["location"] as! NSDictionary 

      let lat = loc["lat"] as! NSNumber 
      let lng = loc["lng"] as! NSNumber 
      if let l: NSNumber = lat, let ln: NSNumber = lng{ 
       var latitude = CLLocationDegrees(l.floatValue) 
       var longitude = CLLocationDegrees(ln.floatValue) 
       var cord = CLLocationCoordinate2D(latitude: latitude, longitude: longitude) 
       allLibraries.append(cord) 
      } 
      //print(loc) 

     } 


    }catch let error as Error{ 
     print("Error : \(error.localizedDescription)") 
    } 
    loaded = true 
    //setUpMarkersForLibraries(locations: allLibraries) 
    print("All Libraries : \(allLibraries.count)") 
} 


func setUpMarkersForLibraries(locations: [CLLocationCoordinate2D]){ 
    print("Setting up Markers") 
    var i = 0 
    for l in locations{ 
     let circleCenter = l 
     let circ = GMSCircle(position: circleCenter, radius: 30) 

     circ.fillColor = UIColor(red: 0, green: 0.89, blue: 0, alpha: 0.8) 
     circ.strokeColor = .black 
     circ.strokeWidth = 5 
     circ.title = "\(i)" 
     //print("\(i)") 
     i += 1 
     circ.map = mapView 

    } 
} 


func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { 
    let lastLocation: CLLocation = locations[locations.count - 1] 
    if(mapSet == false) 
    { 
     setUpMap(location: lastLocation) 
     mapSet = true 
    } 
    if (loaded == true) 
    { 
     setUpMarkersForLibraries(locations: allLibraries) 
     loaded = false 
    } 
    //print("Location Updated") 
} 


/* 
// MARK: - Navigation 

// In a storyboard-based application, you will often want to do a little preparation before navigation 
override func prepare(for segue: UIStoryboardSegue, sender: Any?) { 
    // Get the new view controller using segue.destinationViewController. 
    // Pass the selected object to the new view controller. 
} 
*/ 

}

請不要讓我知道了問題的原因,我應該如何刪除這個問題。謝謝。

回答

2

第1步: 創建一個模型「餐廳」,其中創建兩個變量經度和緯度。

第2步: 創建模型的數組像這樣

var datasource : [Restaurants] = Array() 

第3步: 當你打的Web服務命中,加上緯度和經度模型類是這樣的。 fir例如我們在NSArray中的迴應。

let restaurantslist = result as NSArray 
for restaurantsListIteration in restaurantslist { 
self.datasource.append(Restaurants(value: restaurantsListIteration)) 
} 

步驟4: 在模型映射之後。現在添加在mapView中放置多個標記的代碼。

for (index,restaurantsPin) in self.datasource.enumerated() { 
      let latDouble = Double(restaurantsPin.latitude!) 
      let longDouble = Double(restaurantsPin.longitude!) 
      let marker = GMSMarker() 
      marker.map = self.viewMap 
      marker.iconView = UIImageView(image: #imageLiteral(resourceName: "pin")) 
      marker.iconView?.tag = index 
      marker.position = CLLocationCoordinate2DMake(latDouble!,longDouble!) 
      self.view.addSubview(self.viewMap) 
      self.viewMap.delegate = self 
    } 

確保您創建MapView插座。

相關問題