Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/swift/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Swift 我能';t使用MKPointAnnotation添加多个管脚_Swift_Mapkit_Mkpointannotation - Fatal编程技术网

Swift 我能';t使用MKPointAnnotation添加多个管脚

Swift 我能';t使用MKPointAnnotation添加多个管脚,swift,mapkit,mkpointannotation,Swift,Mapkit,Mkpointannotation,我是Xcode新手,我从未用swift为iphone创建过应用程序,所以我在这方面仍然有很多问题 在我的应用程序中,我想打开地图页面,并希望为我拥有的每个地址显示一个pin。为此,我创建了一个带有一些位置的json。到目前为止,我只能访问这个本地文件并用它生成打印。但是当我试图调用函数在地图上创建pin时,出现了一个错误 import UIKit import MapKit class ViewController: UIViewController, MKMapViewDelegate, C

我是Xcode新手,我从未用swift为iphone创建过应用程序,所以我在这方面仍然有很多问题

在我的应用程序中,我想打开地图页面,并希望为我拥有的每个地址显示一个pin。为此,我创建了一个带有一些位置的json。到目前为止,我只能访问这个本地文件并用它生成打印。但是当我试图调用函数在地图上创建pin时,出现了一个错误

import UIKit
import MapKit

class ViewController: UIViewController, MKMapViewDelegate, CLLocationManagerDelegate {

@IBOutlet weak var mapa: MKMapView!
var gerenciadorLocalizacao = CLLocationManager()


override func viewDidLoad() {
    super.viewDidLoad()
    configurarGerenciadorLocalizacao()


    guard let path = Bundle.main.path(forResource: "testeJSON", ofType: "json") else {return}
    let url = URL(fileURLWithPath: path)
    do {
        let data = try Data(contentsOf: url)
        let json = try JSONSerialization.jsonObject(with: data, options: JSONSerialization.ReadingOptions.mutableContainers) as! NSArray
        print(json)
        guard let array = json as? [Any] else {return}
        for user in array {

            guard let userDict = user as? [String: Any] else {return}
            guard let userId = userDict["id"] as? String else {return}
            guard let name = userDict["nome"] as? String else {return}
            guard let lat = userDict["latitude"] as? String else {return}
            guard let lon = userDict["longitude"] as? String else {return}
            guard let note = userDict["nota"] as? String else {return}

            exibirLocalMapa(latitude: Double(lat)!, longitude: Double(lon)!, titulo: name, nota: note)

            print(userId)
            print(name)
            print(lat)
            print(lon)
            print(note)
            print(" ")  

        }
    }catch {
        print(error)
    }
}


func exibirLocalMapa(latitude: Double, longitude: Double, titulo: String, nota: String) {
    let latitude: CLLocationDegrees = latitude
    let longitude: CLLocationDegrees = longitude

    let deltaLatitude: CLLocationDegrees = 0.01
    let deltaLongitude: CLLocationDegrees = 0.01

    let localizacao: CLLocationCoordinate2D = CLLocationCoordinate2DMake(latitude, longitude)
    let areaVisualizacao: MKCoordinateSpan = MKCoordinateSpanMake(deltaLatitude, deltaLongitude)

    let regiao: MKCoordinateRegion = MKCoordinateRegionMake(localizacao, areaVisualizacao)

    self.mapa.setRegion(regiao, animated: true)


    let anotacao = MKPointAnnotation()
    //Configurar a anotação
    anotacao.coordinate = localizacao
    anotacao.title = titulo
    anotacao.subtitle = nota
    self.mapa.addAnnotation(anotacao)
}

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

func configurarGerenciadorLocalizacao(){
    gerenciadorLocalizacao.delegate = self
    gerenciadorLocalizacao.desiredAccuracy = kCLLocationAccuracyBest
    gerenciadorLocalizacao.requestWhenInUseAuthorization()
    gerenciadorLocalizacao.startUpdatingLocation()
}

func locationManager(_ manager: CLLocationManager, didChangeAuthorization status: CLAuthorizationStatus) {
    if status != .authorizedWhenInUse {
        let alertaController = UIAlertController(title: "Permissão de Localização", message: "Necessário permissão para acesso à sua localização. Favor habilitar esta funcionalidade", preferredStyle: .alert)
        let acaoConfiguracoes = UIAlertAction(title: "Abrir Configurações", style: .default, handler: {(alertaConfiguracoes) in
            if let configuracoes = NSURL(string: UIApplicationOpenSettingsURLString) {
                UIApplication.shared.open(configuracoes as URL)
            }
        })
        let acaoCancelar = UIAlertAction(title: "Cancelar", style: .default, handler: nil)
        alertaController.addAction(acaoConfiguracoes)
        alertaController.addAction(acaoCancelar)
        present(alertaController, animated: true, completion: nil)
    }
}
}

按照以下步骤将所有管脚放在地图上:

  • 您必须使用for loop从JSON文件中获取所有细节,并将其存储在数组中

  • 调用函数,该函数将使用存储数组中的纬度、经度、地名和注释在地图上标记注释


  • 快乐编码

    也许您可以尝试创建自己的扩展MKPointAnnotation的类,然后将JSON元素映射到该自定义类的数组中,最后调用mapView.addAnnotations(YourAnnotationsArray)

    请尝试以下示例:


    我建议您从iOS开发开始使用此网站

    非常感谢你的帮助。但是,你能解释一下怎么做吗,因为我没有太多的知识。我能想到的唯一原因是你试图用viewDidLoad发布PIN。这不是viewDidLoad的目的。