0

私はswiftにはかなり慣れていないので、我慢してみてください。

現在、CKRecords をダウンロードして配列「birdFacts」に挿入できます。各レコードには、いくつかの文字列、画像 (CKAsset)、日付、および int が含まれます。最初に iCloud からダウンロードすると、すべて正常に動作します。

画像を除いて、すべてが期待どおりに保存されています。データをリロードすると、アセットが表示されません。

保存されたデータをロードするコードは次のとおりです。

    if let savedFacts = loadFacts() {
        birdFacts = savedFacts
        print("successfully loaded saved bird facts")
    }

func loadFacts() -> [CKRecord]? {
    return NSKeyedUnarchiver.unarchiveObjectWithFile(BirdFact.ArchiveURL.path!) as? [CKRecord]
}

これは、配列を保存するための私のコードです:

func saveFacts() {
    let isSuccessfulSave = NSKeyedArchiver.archiveRootObject(birdFacts, toFile: BirdFact.ArchiveURL.path!)
    if !isSuccessfulSave {
        print("Failed to save bird facts")
    }
}

これは、私のカスタム クラス定義ファイル内にあります。

import UIKit
import CloudKit

class BirdFact: NSObject, NSCoding {
//MARK: PROPERTIES
var birdName: String

var photo: CKAsset

var birdFact: String

var date: NSDate

var sortingDate: Int

//MARK: TYPES
struct PropertyKey {
    static let namekey = "name"
    static let photokey = "photo"
    static let factkey = "fact"
    static let datekey = "date"
    static let sortingDatekey = "sortingDate"
}

//MARK: INITIALIZATION

init?(birdName: String, photo: CKAsset, birdFact: String, date: NSDate, sortingDate: Int){
    //init stored props
    self.birdName = birdName
    self.photo = photo
    self.birdFact = birdFact
    self.date = date
    self.sortingDate = sortingDate

    super.init()

    if birdName.isEmpty || birdFact.isEmpty {
        return nil
    }
}

//MARK: NSCODING
func encodeWithCoder(aCoder: NSCoder) {
    aCoder.encodeObject(birdName, forKey: PropertyKey.namekey)
    aCoder.encodeObject(photo, forKey: PropertyKey.photokey)
    aCoder.encodeObject(birdFact, forKey: PropertyKey.factkey)
    aCoder.encodeObject(date, forKey: PropertyKey.datekey)
    aCoder.encodeObject(sortingDate, forKey: PropertyKey.sortingDatekey)
}

required convenience init?(coder aDecoder: NSCoder) {
    let birdName = aDecoder.decodeObjectForKey(PropertyKey.namekey) as! String
    let photo = aDecoder.decodeObjectForKey(PropertyKey.photokey) as! CKAsset
    let birdFact = aDecoder.decodeObjectForKey(PropertyKey.factkey) as! String
    let date = aDecoder.decodeObjectForKey(PropertyKey.datekey) as! NSDate
    let sortingDate = aDecoder.decodeObjectForKey(PropertyKey.sortingDatekey) as! Int

    self.init(birdName: birdName, photo: photo, birdFact: birdFact, date: date, sortingDate: sortingDate)
}

//MARK: ARCHIVING PATHS
static let DocumentsDirectory = NSFileManager().URLsForDirectory(.DocumentDirectory, inDomains: .UserDomainMask).first!
static let ArchiveURL = DocumentsDirectory.URLByAppendingPathComponent("BirdFacts")

}

レコードのダウンロードとソートが完了するたびに保存しています。何がうまくいかないのですか?

編集: CloudKit クエリが含まれています。iCloud には何も保存せず、既存のレコードのみをダウンロードすることに注意してください。

func allprevFacts(date: String, olddate: Int){
    act.startAnimating()
    let container = CKContainer.defaultContainer()
    let publicDB = container.publicCloudDatabase
    //let factPredicate = NSPredicate(format: "recordID = %@", CKRecordID(recordName: date))
    let factPredicate = NSPredicate(format: "date <= %@", NSDate())
    let query = CKQuery(recordType: "BirdFacts", predicate: factPredicate)
    publicDB.performQuery(query, inZoneWithID: nil) { (results, error) -> Void in
        if error != nil {
            print(error)
        }
        else {
            dispatch_async(dispatch_get_main_queue()){
                //print(results)
                var count = 0
                var sortedresults = [Int]()
                for result in results! {
                    var b = result.valueForKey("sortingDate") as! Int
                    sortedresults.append(b)
                }
                print(sortedresults)
                while count < sortedresults.count {
                    if sortedresults[count] <= olddate {
                        sortedresults.removeAtIndex(count)
                    }
                    else {
                        count = count + 1
                    }
                }
                print(sortedresults)
                while sortedresults.count > 0 {
                    var d: Int = 0
                    let a = sortedresults.maxElement()
                    print(a)
                    while d < sortedresults.count{
                        if sortedresults[d] == a {
                            sortedresults.removeAtIndex(d)
                            self.birdFacts.append(results![d])
                            self.tableFacts.reloadData()
                            self.tableFacts.hidden = false
                        }
                        d = d + 1
                        print(d)
                    }
                }
                self.saveFacts()
                print("saving bird facts")
                self.tableFacts.hidden = false
            }
        }
    }
    act.stopAnimating()
4

0 に答える 0