在Firebase数据库

时间:2018-05-14 03:17:28

标签: ios swift firebase firebase-realtime-database mkmapview

我正在创建一个iOS应用程序,该应用程序使用Apple Maps在本地区域显示车库/场地销售的标记。到目前为止,我已经能够弄清楚如何从Firebase数据库在Apple Maps上放置一个标记,但我不知道如何使用多个标记来完成它。我已经完成了类似的任务,使用单元格在Firebase数据库的UITableView中显示不同的内容,但这是我第一次按地图进行操作。我正在阅读一篇文章here,该文章展示了JSON数据是如何实现的,但由于标记信息将是实时的,因此我的应用程序不可能采用这种方式。将多个标记添加到MKMapView的最佳方法是什么?

ViewController的片段(仅设置一个标记)

Database.database().reference().child("posts").observeSingleEvent(of: .value, with: { (snapshot) in
        if let dictionary = snapshot.value as? [String: AnyObject] {
            let artwork = Artwork(title: dictionary["title"] as! String,
                                  locationName: dictionary["location"] as! String,
                                  discipline: dictionary["category"] as! String,
                                  coordinate: CLLocationCoordinate2D(latitude: dictionary["lat"] as! Double, longitude: dictionary["long"] as! Double))
            self.mapView.addAnnotation(artwork)
        }
    })

Artwork.swift

class Artwork: NSObject, MKAnnotation {
    let title: String?
    let locationName: String
    let discipline: String
    let coordinate: CLLocationCoordinate2D

    init(title: String, locationName: String, discipline: String, coordinate: CLLocationCoordinate2D) {
        self.title = title
        self.locationName = locationName
        self.discipline = discipline
        self.coordinate = coordinate

        super.init()
    }

    var subtitle: String? {
        return locationName
    }
}

3 个答案:

答案 0 :(得分:2)

由于张贴了link @ kosuke-ogawa,我能够找到解决方法。

ViewController.swift中的代码段

override func viewDidLoad() {
        super.viewDidLoad()    
        let ref = Database.database().reference()
        let postsRef = ref.child("posts")
        postsRef.observeSingleEvent(of: .value, with: { (snapshot) in
            for snap in snapshot.children {
                let postSnap = snap as! DataSnapshot
                if let dict = postSnap.value as? [String:AnyObject] {
                    let title = dict["title"] as! String
                    let locationName = dict["location"] as! String
                    let discipline = dict["category"] as! String
                    let coordinate = CLLocationCoordinate2D(latitude: dict["lat"] as! Double, longitude: dict["long"] as! Double)
                    let artwork = Artwork(title: title, locationName: locationName, discipline: discipline, coordinate: coordinate)
                    self.mapView.addAnnotation(artwork)
                }
            }
        })
    }

如果有更简洁的方法,请随时编辑我的代码,以便将来帮助其他人。

答案 1 :(得分:1)

对于MKMapView上的多个位置标记,您可以使用已创建的ArtWork阵列,请尝试以下方法解决方案

var arrArtworks: [Artwork] = []

override func viewDidLoad() {
    super.viewDidLoad()
    intializeData()
    PlaceMarker()
}

func intializeData(){
    Database.database().reference().child("posts").observeSingleEvent(of: .value, with: { (snapshot) in
        if let dictionary = snapshot.value as? [String: AnyObject] {
            let artwork = Artwork(title: dictionary["title"] as! String,
                                  locationName: dictionary["location"] as! String,
                                  discipline: dictionary["category"] as! String,
                                  coordinate: CLLocationCoordinate2D(latitude: dictionary["lat"] as! Double, longitude: dictionary["long"] as! Double))
            arrArtworks.append(Artwork)
        }
    })
}

func PlaceMarker() {
    mapView.addAnnotations(arrArtworks)
}

答案 2 :(得分:0)

例如,您可以使用 Cast from '(key: Any, value: Any)' to unrelated type '[String : Any]' always fails 循环:

for

比照http://takeip.com/swift-3-firebase-to-mapkit.html