如果NSUserDefault存在于Swift中,则尝试更新CLLocation

时间:2016-09-20 21:56:44

标签: ios swift function nsuserdefaults cloudkit

最初我尝试将CLLocation保存为NSUserDefault值,然后将其作为CKRecord存储在CLoudkit中,但我收到错误:" defaults.setObject(locationRecord.recordID,forKey:&#34 ; locationRecordID&#34)"原因是"尝试将非属性列表对象设置为密钥locationRecordID "的NSUserDefaults / CFPreferences值。所以现在我试图将lat和long保存为默认值并替换Cloudkit中的旧位置。我目前正在获得一个' 主题1 SIGABRT '行上的错误" publicDB.fetchRecordWithID((defaults.objectForKey(" Location")as!CKRecordID),completionHandler:"原因是&# 34; 无法将类型' __ NSCFDictionary'(0x1a1bec968)的值转换为' CKRecordID'。"

func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation])
    {
        let location = locations.last
        self.loc1 = location!
        let center = CLLocationCoordinate2D(latitude: location!.coordinate.latitude, longitude: location!.coordinate.longitude)
        let region = MKCoordinateRegion(center: center, span: MKCoordinateSpan(latitudeDelta: 0.004, longitudeDelta: 0.004))
        self.mapView.setRegion(region, animated: true)
        self.locationManager.stopUpdatingLocation()
        self.locationManager.startMonitoringSignificantLocationChanges()

        self.getRecordToUpdate(locations)

        let lat: CLLocationDegrees = center.latitude
        self.lat1 = lat
        let long: CLLocationDegrees = center.longitude
        self.long1 = long

        locationRecord.setObject(location, forKey: "location")
        let publicData = CKContainer.defaultContainer().publicCloudDatabase
        publicData.saveRecord(locationRecord) { record, error in
        }
        if error == nil
        {
            print("Location saved")
        }
    }

func getRecordToUpdate(locations:[CLLocation])
    {
        let defaults = NSUserDefaults.standardUserDefaults()
        var locationRecord:CKRecord

        if defaults.objectForKey("Location") == nil{
            locationRecord = CKRecord(recordType: "location")
            let locationDict = ["lat": lat1, "lng": long1]//
            defaults.setObject(locationDict, forKey: "Location")//
            self.updateLocationRecord(locationRecord, locations: locations)
            print("new")
        }else{
            let publicDB = CKContainer.defaultContainer().publicCloudDatabase
            publicDB.fetchRecordWithID((defaults.objectForKey("Location") as! CKRecordID),completionHandler: {  
                (record, error) in
                if error == nil{
                    self.updateLocationRecord(record!, locations: locations)
                    print("fetched record")
                }else{
                    print("Error fetching previous record")
                }
            })
        }
    }
    func updateLocationRecord(locationRecord:CKRecord, locations:[CLLocation])
    {
        let location = locations.last
        locationRecord.setObject(location, forKey: "location")
        let publicData = CKContainer.defaultContainer().publicCloudDatabase
        publicData.saveRecord(locationRecord) { record, error in
        }
        if error == nil
        {
            print("Location saved")
        }
    }

1 个答案:

答案 0 :(得分:4)

试试这个

您可以将NSData保存到NSUserDefaults。所以你需要的是将你的CLLocation对象转换为NSData,如下所示:

// saving your CLLocation object
let locationData = NSKeyedArchiver.archivedDataWithRootObject(your location here)
NSUserDefaults.standardUserDefaults().setObject(locationData, forKey: "locationData")

// loading it
if let loadedData = NSUserDefaults.standardUserDefaults().dataForKey("locationData") {
    if let loadedLocation = NSKeyedUnarchiver.unarchiveObjectWithData(loadedData) as? CLLocation {
        println(loadedLocation.coordinate.latitude)
        println(loadedLocation.coordinate.longitude)
    }
}