0

我正在使用 GeoFire 搜索给定的半径,用户可以在我的应用程序中设置并存储在 FireBase 上。当页面加载时,在运行 GeoFire 查询之前,我从 Firebase 获取半径。但是,当我运行下面的代码时,我收到以下错误:由于未捕获的异常“NSInvalidArgumentException”而终止应用程序,原因:“精度必须小于 23!”

通过玩一些策略性放置的打印语句,看起来 searchRadius 在 GeoFire 查询运行时返回为 0,这让我怀疑异步加载正在发挥作用。

我的问题是,由于我的 searchRadius 为 0,我是否会收到此错误,如果是这样,我如何确保获取我的用户搜索半径的 FireBase 块在我的 GeoFire 查询之前运行?

    self.ref.childByAppendingPath("users/\(self.ref.authData.uid)/searchRadius").observeEventType(.Value, withBlock: { snapshot in
        self.searchRadius = snapshot.value as! Double
    })

    let center = CLLocation(latitude: 37.331469, longitude: -122.029825)
    let circleQuery = geoFire.queryAtLocation(center, withRadius: self.searchRadius)



    circleQuery.observeEventType(GFEventTypeKeyEntered, withBlock: { (key: String!, location: CLLocation!) in

        //Do code for each result returned

    }) //End GeoFire query
4

1 回答 1

0

是的,这是一个异步加载问题。即使 Firebase 已经缓存了searchRadius值回调的值,也不会内联执行。该线程将在值更新之前继续设置 GeoFire 查询。

基于此代码段,您可以通过将查询代码移动到回调内部来确保在运行查询之前设置半径。您可能还想观察单个事件,以便在值searchRadius更改时不会再次运行查询。

self.ref.childByAppendingPath("users/\(self.ref.authData.uid)/searchRadius").observeSingleEventOfType(.Value, withBlock: { snapshot in
    self.searchRadius = snapshot.value as! Double
    let center = CLLocation(latitude: 37.331469, longitude: -122.029825)
    let circleQuery = geoFire.queryAtLocation(center, withRadius: self.searchRadius)
    circleQuery.observeEventType(GFEventTypeKeyEntered, withBlock: { (key: String!, location: CLLocation!) in
        //Do code for each result returned
    }) //End GeoFire query
}) // End observeSingleEventOfType
于 2016-07-30T04:23:54.163 回答