CLLocationManager致命错误:在展开可选值Swift时意外发现nil

时间:2015-03-15 06:59:07

标签: ios swift mkmapview cllocationmanager

我遇到了一个问题,因为当我尝试获取位置用户并且在我的.plist中获得了我的代码权限时,我的应用程序崩溃了。

import UIKit
import MapKit
import CoreLocation

class mapClass : UIViewController,MKMapViewDelegate,CLLocationManagerDelegate{

    var location4 = CLLocation()
    var lm  = CLLocationManager ()

    @IBOutlet  var propMapa: MKMapView!

    lm.delegate=self
    lm.desiredAccuracy = kCLLocationAccuracyNearestTenMeters
    lm.distanceFilter = kCLDistanceFilterNone
    lm.startUpdatingLocation()

    println("\(lm.location)") <---- nil

   location4 = lm.location <---- crash

}

日志:致命错误:在解包可选值时意外发现nil

3 个答案:

答案 0 :(得分:6)

调用lm.startUpdatingLocation()后,位置管理员会在检测到位置更改时调用didUpdateLocations(),因此您需要实施CLLocationManager::didUpdateLocations来检索位置:

import UIKit
import MapKit
import CoreLocation

class mapClass : UIViewController,MKMapViewDelegate,CLLocationManagerDelegate{

    var location4 = CLLocation()
    var lm  = CLLocationManager ()

    @IBOutlet  var propMapa: MKMapView!

    ...

    lm.delegate=self
    lm.desiredAccuracy = kCLLocationAccuracyNearestTenMeters
    lm.distanceFilter = kCLDistanceFilterNone
    lm.startUpdatingLocation()
}

func locationManager(manager: CLLocationManager!, didUpdateLocations locations: [AnyObject]!) {

    let currentLocation = locations.last as CLLocation
    println(currentLocation)
    ...
}

答案 1 :(得分:0)

import UIKit
import MapKit
import CoreLocation
class ViewController: UIViewController,MKMapViewDelegate,CLLocationManagerDelegate
{
    @IBOutlet weak var mapView: MKMapView!
    @IBOutlet weak var textField: UITextField!
    @IBOutlet weak var searchButton: UIButton!
    let locationManager = CLLocationManager()
    var location:CLLocationCoordinate2D!

    override func viewDidLoad() {
        super.viewDidLoad()

        println("Search Button Clicked");
        mapView.showsUserLocation = true;
    }

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

    @IBAction func searchButtonClicked(sender:AnyObject)
    {
        locationManager.distanceFilter = kCLDistanceFilterNone
        locationManager.desiredAccuracy = kCLLocationAccuracyBest
        locationManager.delegate = self

        locationManager.requestWhenInUseAuthorization()

        locationManager.startUpdatingLocation()
    }

    func locationManager(manager: CLLocationManager!, didUpdateLocations locations: [AnyObject]!) {

        println("delegate called")
        if manager.location != nil
        {
            println(locationManager.location.coordinate.latitude)
            let artwork = Artwork(title: "Ram",
                locationName: "Infotech",
                discipline: "Testing",
                coordinate: CLLocationCoordinate2D(latitude:manager.location.coordinate.latitude, longitude:manager.location.coordinate.longitude))

            mapView.addAnnotation(artwork)
        }

    }

    func locationManager(manager: CLLocationManager!, didFailWithError error: NSError!)
    {

        println(error)
    }
}

答案 2 :(得分:0)

Acces控制可能尚未完成。您可以检查autorisation是否可用。

func locationManager(_ manager: CLLocationManager, didChangeAuthorization status: CLAuthorizationStatus) {
    if CLLocationManager.locationServicesEnabled() {
        switch CLLocationManager.authorizationStatus() {
        case .notDetermined, .restricted, .denied:
            print("No access")
        case .authorizedAlways, .authorizedWhenInUse:
            let sourceCoordinate = locationManager.location?.coordinate
            showRouteOnMap(pickupCoordinate: sourceCoordinate!, destinationCoordinate: CLLocationCoordinate2DMake(41.037141,28.9834662))
        }
    } else {
        print("Location services are not enabled")
    }
}