2017-04-11 6 views
0

ich meine Bewerbung will aktiv und Hintergrund-Modi nehmen Lage in (wenn Gebrauch nur NSLocationAlwaysUsageDescription Erlaubnis dann myLocationButton nicht zeigen). stellte ich in Info.plist:Zeigt nur ein Ort Erlaubnis Alarm

<key>NSLocationAlwaysUsageDescription</key> 
<string>$(PRODUCT_NAME) location use</string> 
<key>NSLocationWhenInUseUsageDescription</key> 
<string>$(PRODUCT_NAME) location use</string> 
<key>UIBackgroundModes</key> 

Und MapViewController

self.locationManager.requestWhenInUseAuthorization() 
self.locationManager.requestAlwaysAuthorization() 

hinzufügen Aber wenn die Anwendung gestartet wird, werden nur der erste Lage Erlaubnis Alarm angezeigt wird, und die zweite Erlaubnis Warnung wird angezeigt, nachdem die Anwendung wiedereröffnet.

Update:

override func viewDidLoad() { 
     super.viewDidLoad() 
...  
locationManager.delegate = self 
locationManager.requestWhenInUseAuthorization() 
viewMap.addObserver(self, forKeyPath: "myLocation", options: NSKeyValueObservingOptions.new, context: nil) 
     self.startLocationUpdates() 
... 
} 

func startLocationUpdates() { 
    self.locationManager.delegate = self 
    self.locationManager.desiredAccuracy = kCLLocationAccuracyBest 
    self.locationManager.activityType = CLActivityType.automotiveNavigation 
    self.locationManager.distanceFilter = distanceFilterMetr 
    self.locationManager.requestAlwaysAuthorization() 
    self.locationManager.startUpdatingLocation() 
} 

override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?) { 

     let myLocation: CLLocation = change?[NSKeyValueChangeKey.newKey] as! CLLocation 
     viewMap.camera = GMSCameraPosition.camera(withTarget: myLocation.coordinate, zoom: observeZoom) 
     mapRoute.coordinateLatitude = myLocation.coordinate.latitude 
     mapRoute.coordinateLongitude = myLocation.coordinate.longitude 
     viewMap.delegate = self 
     viewMap.settings.myLocationButton = true 
     viewMap.settings.compassButton = true 
     didFindMyLocation = true 
} 
+0

Sie müssen nur die Autorisierung "immer" anfordern. Dies gibt Ihrer App die Erlaubnis, den Standort im Vordergrund und im Hintergrund zu verwenden. – Paulw11

+0

@ Paulw11 Ich schreibe über, wenn nur NSLocationAlwaysUsageDescription Erlaubnis dann MyLocationButton nicht zeigen (Standort-Update, aber Schaltfläche don 't Show) iOS 10.3 swift 3 – Roman

+1

Wie entscheiden Sie, ob diese Schaltfläche angezeigt wird? Ich kann Ihnen versichern, dass nur Always-Authentifizierung für Vorder- und Hintergrund erforderlich ist. – Paulw11

Antwort

0

Fügen Sie diese Delegierten in Ihrer Klasse:

CLLocationManagerDelegate 

in dir Klasse Jetzt:

var locationManager:CLLocationManager! 
var map = GMSMapView() 
var currentLatitude:Double! 
var currentLongitude:Double! 

Danach fügen Sie diese in Ihrem Code:

override func loadView() { 

    print("loadView called") 

    // Enable some map settings 

    map.isMyLocationEnabled = true 
    map.settings.myLocationButton = true 
    map.settings.compassButton = true 
    map.settings.scrollGestures = true 
    map.settings.zoomGestures = true 
    map.delegate = self 

    view = map 
} 

override func viewDidLoad() { 

    super.viewDidLoad() 

    print("ViewDidLoad called") 

    // Configuring location manager. 

    locationManager = CLLocationManager() 
    locationManager.delegate = self 
    locationManager.requestAlwaysAuthorization() 
    locationManager.desiredAccuracy = kCLLocationAccuracyBest 
    locationManager.startUpdatingLocation() 
    locationManager.startMonitoringSignificantLocationChanges() 
} 

func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { 

    print("locationManager function called") 

    // Fetch current location coordinates 

    let locValue:CLLocationCoordinate2D = (locationManager.location?.coordinate)! 
    currentLatitude = locValue.latitude 
    currentLongitude = locValue.longitude 
    print("Current Location = \(currentLatitude!), \(currentLongitude!)") 

    // Zoom to current location 

    let target = CLLocationCoordinate2D(latitude: currentLatitude!, longitude: currentLongitude!) 
    map.camera = GMSCameraPosition.camera(withTarget: target, zoom: 17) 

    locationManager.stopUpdatingLocation() 

} 

Nachdem Sie diesen Code hinzugefügt haben, klicken Sie mit der rechten Maustaste auf Ihre Info.plist und "Als Quellcode öffnen". Fügen Sie dies in Ihrer Info.plist hinzu.

<key>LSApplicationQueriesSchemes</key> 
<array> 
    <string>googlechromes</string> 
    <string>comgooglemaps</string> 
</array> 
<key>LSRequiresIPhoneOS</key> 
<true/> 
<key>NSBluetoothPeripheralUsageDescription</key> 
<string></string> 
<key>NSCameraUsageDescription</key> 
<string></string> 
<key>NSContactsUsageDescription</key> 
<string></string> 
<key>NSLocationUsageDescription</key> 
<string></string> 
<key>NSLocationWhenInUseUsageDescription</key> 
<string></string> 
<key>NSLocationAlwaysUsageDescription</key> 
<string></string> 
<key>NSMicrophoneUsageDescription</key> 
<string></string> 
<key>NSMotionUsageDescription</key> 
<string></string> 
<key>NSPhotoLibraryUsageDescription</key> 
<string></string> 
<key>NSRemindersUsageDescription</key> 
<string></string> 
<key>NSSiriUsageDescription</key> 
<string></string> 
<key>NSSpeechRecognitionUsageDescription</key> 
<string></string> 
<key>NSVideoSubscriberAccountUsageDescription</key> 
<string></string> 
Verwandte Themen