【问题标题】:Googlemaps not allowing me to locate the users location?谷歌地图不允许我定位用户位置?
【发布时间】:2018-06-11 21:39:01
【问题描述】:

我正在尝试在 swift 上创建一个显示用户所在位置的视图控制器。我已经实现了谷歌地图,所以现在我要做的就是插入正确的代码。这样做时,我不断收到这两条错误消息,然后应用程序崩溃。有人可以帮我找出解决方案吗>感谢所有帮助。

import UIKit
import Foundation
import Firebase
import MapKit
import GoogleMaps
import CoreLocation

class mainViewController: UIViewController, MKMapViewDelegate, CLLocationManagerDelegate {

    let defaults = UserDefaults.standard
    let locationManager = CLLocationManager()
    var mapView = GMSMapView()
    var camera = GMSCameraPosition()


    override func viewDidLoad() {
        super.viewDidLoad()

        self.locationManager.delegate = self
        self.locationManager.desiredAccuracy = kCLLocationAccuracyBest
        self.locationManager.requestWhenInUseAuthorization()
        self.locationManager.startUpdatingLocation()

        GMSServices.provideAPIKey("AIzaSyBDOLisA3c-wDTbkbSssAxEb3iLw7Y5vHo")

        let camera = GMSCameraPosition.camera(withLatitude: (self.locationManager.location?.coordinate.latitude)!, longitude: (self.locationManager.location?.coordinate.latitude)!, zoom: 17)
        let mapView = GMSMapView.map(withFrame: CGRect.zero, camera: camera)
        view = mapView

        let marker = GMSMarker()
        marker.position = CLLocationCoordinate2D(latitude: (self.locationManager.location?.coordinate.latitude)!, longitude: (self.locationManager.location?.coordinate.latitude)!)
        marker.snippet = "Current Location"
        marker.map = mapView
        self.mapView.addSubview(mapView)

        view.backgroundColor = GREEN_Theme
        navigationController?.navigationBar.prefersLargeTitles = true
        navigationItem.title = "Welcome"
        navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Logout", style: .plain, target: self, action: #selector(Logout))
        }
    @objc func Logout() {
        print("Logged Out")
        do {

// I am receiving this error message on the auth.auth().signOut() "Use of unresolved identifier 'Auth'"
            try  Auth.auth().signOut()
            defaults.set(false, forKey: "user is logged in")
            let loginController = UINavigationController(rootViewController: LoginController())
            present(loginController, animated: true, completion: nil)
        } catch let err {
            print(err.localizedDescription)
        }

    }
}

【问题讨论】:

  • 抱歉,我在这里收到错误消息(让 camera = GMSCameraPosition.camera(withLatitude: (self.locationManager.location?.coordinate.latitude)!, longitude: (self.locationManager.location? .coordinate.latitude)!, zoom: 17) let mapView = GMSMapView.map(withFrame: CGRect.zero, camera: camera) view = mapView) 消息说 Thread 1: EXC_BAD_INSTRUCTION (code=EXC_I386_INVOP, subcode=0x0) 请帮忙我解决这个问题!
  • 你通过声明变量mapView创建了一个GMSMapView的实例,然后你又声明了一个mapView的常量?
  • @Do2 谢谢,你能解释一下如何解决这个问题吗?
  • @Do2 当我删除 let 时,我得到一个“使用未解析的标识符‘mapView’
  • 你试过 self.mapView 吗?

标签: swift firebase firebase-authentication gmsmapview


【解决方案1】:

您的问题是CLLocationManager 没有足够的时间来获取信息,同时其他函数要求该信息仍然为零。

下面会解决这个问题,它还会一直停止更新位置,这可能会耗尽电池电量,尤其是考虑到您已设置 AccuracyBest。

func getLocation(){
    locationManager=CLLocationManager()
    locationManager.delegate = self
    locationManager.desiredAccuracy = kCLLocationAccuracyBest
    locationManager.requestWhenInUseAuthorization()
    locationManager.startUpdatingLocation()
}

func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]){
    let lastLocation=locations[locations.count-1]
    if lastLocation.horizontalAccuracy>0{
        locationManager.stopUpdatingLocation()
        let latitude = lastLocation.coordinate.latitude
        let longitude = lastLocation.coordinate.longitude

        GMSServices.provideAPIKey("AIzaSyBDOLisA3c-wDTbkbSssAxEb3iLw7Y5vHo")
// everything that is going to require the latitude and longitude from the location manager goes here
        let camera = GMSCameraPosition.camera(withLatitude: (self.locationManager.location?.coordinate.latitude)!, longitude: (self.locationManager.location?.coordinate.latitude)!, zoom: 17)
        let mapView = GMSMapView.map(withFrame: CGRect.zero, camera: camera)
        self.view = mapView

        let marker = GMSMarker()
         marker.position = CLLocationCoordinate2D(latitude: (self.locationManager.location?.coordinate.latitude)!, longitude: (self.locationManager.location?.coordinate.latitude)!)
         marker.snippet = "Current Location"
         marker.map = mapView
         self.mapView.addSubview(mapView)
      }
 }

你的viewDidLoad 应该有:

 override func viewDidLoad() {
    super.viewDidLoad()

    getLocation()

    view.backgroundColor = GREEN_Theme
    navigationController?.navigationBar.prefersLargeTitles = true
    navigationItem.title = "Welcome"
    navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Logout", style: .plain, target: self, action: #selector(Logout))
    } 

【讨论】:

  • 非常感谢!但是,我的应用程序不再崩溃,我不再拥有 mapView。它只是背景颜色
  • 你的问题是如何修复你的崩溃,我回答了。现在你在问一个新问题,El Tomato 回答了它。您也就此发布了一个新问题。
【解决方案2】:

您正在使用 Google 地图作为地图视图,这意味着您创建了一个 GMSMapView 类的实例。那是一个对象。你有一个。我假设它是 IBOutlet-wired。它带有几个委托方法。所以你可能想设置它的委托。并且您希望您的视图控制器从 GMSMapView 接收数据。因此,您将该类的委托设置为 self(您的视图控制器)。

import UIKit
import Foundation
import Firebase
import GoogleMaps
import CoreLocation

class mainViewController: UIViewController, CLLocationManagerDelegate, GMSMapViewDelegate {
    // MARK: - Instance variables
    private let locationManager = CLLocationManager()

    // MARK: - IBOutlets
    @IBOutlet weak var mapView: GMSMapView!

    // MARK: - IBActions

    // MARK: - Life cycle
    override func viewDidLoad() {
        super.viewDidLoad()

        mapView.delegate = self
        mapView.isMyLocationEnabled = true
    }
    // MARK: - Life cycle


    // MARK: - GMSMapView delegate methods
    func mapView(_ mapView: GMSMapView, idleAt position: GMSCameraPosition) {
        reverseGeocodeCoordinate(position.target) // sending data when the mapView is not moved or pinched by the finger //
    }

    func reverseGeocodeCoordinate(_ coordinate: CLLocationCoordinate2D) {
        let geocoder = GMSGeocoder()
        geocoder.reverseGeocodeCoordinate(coordinate) { response, error in
            guard let address = response?.firstResult(), let lines = address.lines else {
                return
            }

            ...
            ...
        }
    }
}

【讨论】:

  • 感谢您帮我解决了这个问题!我仍然遇到问题,因为我认为我不知道在哪里正确插入这些..
  • 我没有使用界面生成器。我正在以编程方式插入我的所有代码
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2016-05-10
  • 2015-05-30
  • 2019-03-11
  • 2012-11-25
  • 2011-06-02
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多