HKSampleQuery for HKWorkout

时间:2014-10-06 02:30:04

标签: swift health-kit hksamplequery

我在查询HKWorkout时遇到问题。

以下是我用来保存HKWorkoutHKQuantitySample的代码。

func workout(#distance:Double, start: NSTimeInterval, paused:NSTimeInterval, resume:NSTimeInterval, end:NSTimeInterval, calory:Double) -> HKWorkout {

    var event1_     = HKWorkoutEvent(type: HKWorkoutEventType.Pause, date: self.minutesBeforeNow(paused))
    var event2_     = HKWorkoutEvent(type: HKWorkoutEventType.Resume, date: self.minutesBeforeNow(resume))
    var calories_   = HKQuantity(unit: HKUnit.calorieUnit(), doubleValue: calory)
    var distance_   = HKQuantity(unit: HKUnit.meterUnit(), doubleValue: distance)
    var meta_ = [
        "TITLE":"WORKOUT_TEST",
        "TEAM":"TEAM WAG",
        "ID":"\(arc4random()%999)"
    ]

    var workout_ = HKWorkout(
        activityType: HKWorkoutActivityType.Cycling,
        startDate: self.minutesBeforeNow(start),
        endDate: self.minutesBeforeNow(end),
        workoutEvents: [event1_, event2_],
        totalEnergyBurned: calories_,
        totalDistance: distance_,
        metadata: meta_)

    return workout_
}

func quantity(#distance:Double, start:NSTimeInterval, end:NSTimeInterval) -> HKQuantitySample {

    var meta_ = [
        "TITLE":"QUANTITY_SAMPLE_TEST",
        "ID":"\(arc4random()%99)"]
    var sample_ = HKQuantitySample(
        type: HKObjectType.quantityTypeForIdentifier(HKQuantityTypeIdentifierDistanceCycling),
        quantity: HKQuantity(unit: HKUnit.meterUnit(), doubleValue: distance),
        startDate: self.minutesBeforeNow(start),
        endDate: self.minutesBeforeNow(end),
        metadata:meta_)

    return sample_
}

func minutesBeforeNow(min:NSTimeInterval) -> NSDate {
    return NSDate().dateByAddingTimeInterval(-60 * min)
}

我保存代码并且工作正常。即使我可以使用HKSampleQuery查询

var predicate_ = HKQuery.predicateForSamplesWithStartDate(self.minutesBeforeNow(120), endDate: self.minutesBeforeNow(10), options: HKQueryOptions.None)
var query_ = HKSampleQuery(sampleType: HKSampleType.quantityTypeForIdentifier(HKQuantityTypeIdentifierDistanceCycling),
        predicate: predicate_,
        limit: 10,
        sortDescriptors: nil) { (let sampleQuery, let samples, let error) -> Void in

            BKLog("")
            for sample in samples as [HKQuantitySample]
            {
                var meter_  = sample.quantity.doubleValueForUnit(HKUnit.meterUnit())
                var km_     = meter_ / 1000
                BKLog("\(sample.metadata?.description), \(km_))")
            }
    };

但是,当我尝试使用HKWorkoutType进行查询时,我无法得到任何结果。

var query_ = HKSampleQuery(
        sampleType: HKSampleType.workoutType(),
        predicate: nil,
        limit: 10,
        sortDescriptors: nil) { (let query, let objects, let error) -> Void in

            BKLog("")  // 1

            if(error != nil)
            {
                BKLog("ERROR : \(error.localizedDescription)")  // 2
                return
            }
            else
            {
                BKLog("WORKOUST : \(objects.count)")  // 3
            }


            for workout in objects {
            }
        }

这里奇怪的是我没有完成块的日志。没有记录来自1,2,3的注释日志。

当我使用class func predicateForObjectsFromWorkout(workout: HKWorkout!) -> NSPredicate!时,它按预期工作。

为什么我无法通过HKWorkoutType()查询获得任何内容?

BKLog只是一个形成的日志功能

1 个答案:

答案 0 :(得分:1)

这似乎是iOS8.1中修复的HealthKit错误。我在8.1之前遇到了完全相同的问题但是相同的代码在8.1中完美地运行。我使用以下方法检查使用8.1:

    NSOperatingSystemVersion iOSVersionInWhichHealthKitActuallyWorks;
    iOSVersionInWhichHealthKitActuallyWorks.majorVersion = 8;
    iOSVersionInWhichHealthKitActuallyWorks.minorVersion = 1;
    iOSVersionInWhichHealthKitActuallyWorks.patchVersion = 0;

    if (![[NSProcessInfo processInfo]isOperatingSystemAtLeastVersion:iOSVersionInWhichHealthKitActuallyWorks]) {
    }