iOS:没有针脚显示的MapView注释

时间:2015-11-20 03:02:12

标签: ios swift mkmapview

由于某些奇怪的原因,viewForAnnotation仅适用于viewDidLoad中设置的引脚(这是一个测试引脚)。在其他地方加载的引脚在按下时不会被注释。我已经设置了代表。我认为它与mapView调用中的标识符有关?但我不确定如何解决它。任何帮助表示赞赏!谢谢!

这是我的代码:

import Foundation
import UIKit
import MapKit
import CoreLocation
import Alamofire

class MapViewController: UIViewController, MKMapViewDelegate {

var locationManager:CLLocationManager = CLLocationManager()


@IBOutlet weak var potholeMapView: MKMapView!

var listData: Array<String> = []
var idData: Array<Int> = []
var descriptionData: Array<String> = []

var latitudeData:Array<Double> = []
var longitudeData:Array<Double> = []

override func viewDidLoad() {
    super.viewDidLoad()
    potholeMapView.delegate = self
    locationManager.requestWhenInUseAuthorization()
    potholeMapView!.region = sanDiegoCountyLocation()
    potholeMapView!.mapType = MKMapType.Standard
    potholeMapView!.showsUserLocation = true
    potholeMapView!.showsTraffic = true
    print(potholeMapView!.userLocationVisible)

    // WORKING HERE ACCESSORY VIEW SHOWS
    let encinitas = CLLocationCoordinate2DMake(32.955, -117.2459)
    let marker = AnnotatedLocation(
        coordinate: encinitas,
        title: "There",
        subtitle: "You are not here")
    potholeMapView!.addAnnotation(marker)

}

override func viewWillAppear(animated: Bool) {
    super.viewWillAppear(animated)

    //HERE ACCESSORY VIEWS DONT SHOW
    loadPotholeData()
}


func sanDiegoCountyLocation()-> MKCoordinateRegion {
    let center = CLLocationCoordinate2DMake(32.76572795, -117.07319880 )
    let widthMeters:CLLocationDistance = 100
    let heightMeters:CLLocationDistance = 1000*120
    return MKCoordinateRegionMakeWithDistance(center, widthMeters, heightMeters)
}

func loadPotholeData(){
    let url = "http://bismarck.sdsu.edu/city/fromDate"
    let parametersGet = ["type" : "street", "user" : "008812"]
    Alamofire.request(.GET, url, parameters: parametersGet)
        .responseJSON { response in
            if let dataGet = response.result.value {
                let dataDict:NSArray = dataGet as! NSArray
                for item in dataDict{
                    let descrip = item["created"]
                    self.listData.append(descrip!! as! String)
                    let ids = item["id"]
                    self.idData.append(ids! as! Int)
                    let description = item["description"]
                    self.descriptionData.append(description!! as! String)
                    let latitude = item["latitude"]
                    self.latitudeData.append(latitude as! Double)
                    let longitude = item["longitude"]
                    self.longitudeData.append(longitude as! Double)
                }
            }
            else {
                print("There was some error getting data")
            }
    }
    createAllPins()
}

func createAllPins(){
    for (x, y) in zip(self.latitudeData, self.longitudeData) {
        let location = CLLocationCoordinate2DMake(x, y)
        let marker = AnnotatedLocation(
            coordinate: location,
            title: "",
            subtitle: "")
        potholeMapView!.addAnnotation(marker)
    }
}

func mapView(mapView: MKMapView, viewForAnnotation annotation: MKAnnotation) -> MKAnnotationView? {
    if let annotation = annotation as? AnnotatedLocation {
        let identifier = "pin"
        var view: MKPinAnnotationView
        if let dequeuedView = mapView.dequeueReusableAnnotationViewWithIdentifier(identifier)
            as? MKPinAnnotationView {
                dequeuedView.annotation = annotation
                view = dequeuedView
        } else {
            view = MKPinAnnotationView(annotation: annotation, reuseIdentifier: identifier)
            //view = MKPinAnnotationView(annotation: <#T##MKAnnotation?#>, reuseIdentifier: <#T##String?#>)
            view.canShowCallout = true
            view.calloutOffset = CGPoint(x: -5, y: 5)
            view.rightCalloutAccessoryView = UIButton(type: .DetailDisclosure)
        }
        return view
    }
    return nil
}


func mapView(mapView: MKMapView, annotationView view: MKAnnotationView, calloutAccessoryControlTapped control: UIControl) {
    self.performSegueWithIdentifier("pushAnnotation", sender: view)
}

override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
    if let identifier = segue.identifier {
        switch identifier {
            case "pushAnnotation":
                let nextVC = segue.destinationViewController as! MapAnnotationDetailViewController
                //nextVC.
            default: break
        }
    }
}

}

2 个答案:

答案 0 :(得分:6)

这似乎是因为你的标题和副标题是空白的。我测试了没有任何引文和添加内容,这似乎解决了这个问题。

答案 1 :(得分:1)

对我来说,这是在指定了自定义mapView.mapType之后,我还必须将mapView告知“ showAnnotations”。

直到我告诉它显示它们,注释才会显示。

    mapView.mapType = mapTypes[Preference.mapType]
    mapView.showAnnotations(mapView.annotations, animated: true) //this fixed it