0

我想将 MKLocalSearch 以前在 Core Data 中找到的 MKMapItem 存储起来,以便将来在视图加载时将其显示给用户。

我所拥有的是我在 xcdatamodeld 文件中创建了一个实体并创建了一个名为 mapItem 的 binaryData 属性。

我想将找到的 MKMapItem 编码为二进制数据并将其存储在核心数据中。

稍后我想将其解码为 MKMapItem。

我注意到 MKMapItem 有一个需要 NSCoder 对象的编码方法。

我对 NSCoding 不是很熟悉,因此我们将不胜感激。

我总是可以通过为实体创建多个属性来将来自 MKMapItem 的字符串属性保存在核心数据中,但我想知道是否有一种简单的方法。

谢谢!

4

1 回答 1

1

我想到了。为了将 MapItem 存储在 Core Data 中,我使用了 NSKeyedArchiver。它将 MapItem 编码为 Data 并进行解码,您可以使用 NSKeyedUnarchiver

func saveMapItems(_ mapItems: [MKMapItem]) {
    do {
        let data = try NSKeyedArchiver.archivedData(withRootObject: mapItems, requiringSecureCoding: false)
        let request: NSFetchRequest<RecentSearchLocation> = RecentSearchLocation.fetchRequest()
        if
            let recentLocations = try? coreDataManager.persistentContainer.viewContext.fetch(request).first,
            let location = recentLocations {
            location.mapItems = data
        } else {
            let location = RecentSearchLocation(context: coreDataManager.persistentContainer.viewContext)
            location.mapItems = data
        }
    } catch {
        print("Can't encode data: \(error)")
    }
    do {
        try coreDataManager.persistentContainer.viewContext.save()
    } catch {
        print("Error saving context \(error)")
    }
}

为了解码我做了这个

func readMapItems() -> [MKMapItem] {
        let request: NSFetchRequest<RecentSearchLocation> = RecentSearchLocation.fetchRequest()
        guard
            let data = try? coreDataManager.persistentContainer.viewContext.fetch(request).first?.mapItems,
            let dataToUnarchive = data else {
                print("Cannot get mapItems from coreData data")
                return []
        }
        do {
            guard let recentSearchLocations = try NSKeyedUnarchiver.unarchiveTopLevelObjectWithData(dataToUnarchive) as? [MKMapItem] else {
                return []
            }
            return recentSearchLocations
        } catch {
            print("Error unarchiving mapItems, \(error)")
            return []
        }
    }
于 2019-03-22T23:09:10.400 回答