最近在项目中遇到HealthKit的数据获取相关的问题,对此作了一些简单的封装,以便于以后相似需求时便于调用。
相关类库的准备HealthKit
首先你需要了解对象的结构
-
HKObjectType用于处理项目中需要的项目类。
HKObjectType大概分成以上几类,构建需求请求的时候需要严格按照类型来存储的 -
HKTypeIdentifiers用于处理项目中你所需要获取的数据的类型。
一般来说我们所获取的数值是count,distance之类的,全局搜索可以便于找到你需要的值。 -
HKUnit获取完类别以后呢,我们需要查询这个类别对应的单位(Unit)。这个分类下的值的单位(米,千米之类的)
- HKSampleQuery用来 查询数据对象。
- HKSample查询出来的结果。
代码实践
//查看healthKit在设备上是否可用,ipad不支持HealthKit
if(![HKHealthStore isHealthDataAvailable]) {
NSLog(@"设备不支持healthKit");
return;
}
//创建healthStore实例对象
self.healthStore = [[HKHealthStore alloc] init];
NSMutableSet *healthSet = [NSMutableSet set];HKQuantityType
HKObjectType *stepCount = [HKObjectType quantityTypeForIdentifier:HKQuantityTypeIdentifierStepCount];
[healthSet addObject:stepCount];HKCategoryType
HKObjectType *standHour = [HKObjectType categoryTypeForIdentifier:HKCategoryTypeIdentifierAppleStandHour];
[healthSet addObject:standHour];HKWorkoutType
HKObjectType *workout = [HKObjectType workoutType]
[healthSet addObject:workout];
//从健康应用中获取权限
[self.healthStore requestAuthorizationToShareTypes:nil readTypes:healthSet completion:^(BOOL success, NSError * _Nullable error) {
if (success) {
NSLog(@"获取步数权限成功");
//在这里去获取数据
} else {
NSLog(@"获取权限失败");
}
}];获取数据类型,注意不同数据类型的数据获取方式是不一样的
HKSampleType *sampleType;
要注意获取的数据是分段的,比如你一天走10000步,可能有几百条数据,在获取每天的站立时间时发现,每一个小时是一个数据,锻炼分钟数是每一个分钟,在实际用这个数据时,应该合理控制数据
NSInteger limitNumber = 1000;
NSSortDescriptor *start = [NSSortDescriptor >sortDescriptorWithKey:HKSampleSortIdentifierStartDate ascending:NO];
NSSortDescriptor *end = [NSSortDescriptor sortDescriptorWithKey:HKSampleSortIdentifierEndDate ascending:NO];
__weak typeof(self) weakSelf = self;
HKSampleQuery *sampleQuery = [[HKSampleQuery alloc] initWithSampleType:sampleType predicate:nil limit:limitNumber sortDescriptors:@[start,end] resultsHandler:^(HKSampleQuery * _Nonnull query, NSArray<__kindof HKSample *> * _Nullable results, NSError * _Nullable error) {
@autoreleasepool {
for (HKSample *result in results){
针对不同子类的result进行处理数据
在判断结果的开始时间和结束时间,是否是自己需要的那天的数据
}
}
//回到主线程
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
//数据刷新
}];
}];
//执行查询
[self.healthStore executeQuery:sampleQuery];
注意点
不同HKSample实例的数据的获取方式方法是不一样的
//HKQuantitySample的子类数据,获取result.quantity,根据quantity获取数值
//HKCategorySample的子类数据,获取的是result.value的值,在获取站立小时数时发现,当value值是1的时候,反而是静歇时的数据,这里需要注意
//HKWorkout的子类数据,锻炼时间数,大概有duration,totalEnergyBurned,totalDistance,totalSwimmingStrokeCount这些值来处理
不同数据来源的数据是不一样的
HKSample 的父类 HKObject有source(8.0以上)和device(9.0以上)俩个字段来判断来源。这边需要注意的是多个数据来源的数据。不要一味的全部相加。