iOS HealthKit 使用方法和注意点

最近在项目中遇到HealthKit的数据获取相关的问题,对此作了一些简单的封装,以便于以后相似需求时便于调用。

相关类库的准备HealthKit

首先你需要了解对象的结构

  • HKObjectType用于处理项目中需要的项目类。
    iOS HealthKit 使用方法和注意点_第1张图片
    462A23A7-BBFE-4000-957B-315CF124B731.png

    HKObjectType大概分成以上几类,构建需求请求的时候需要严格按照类型来存储的
  • HKTypeIdentifiers用于处理项目中你所需要获取的数据的类型。
    iOS HealthKit 使用方法和注意点_第2张图片
    325E0E84-F99A-43CF-9FFF-CFA2DB9186D1.png

    一般来说我们所获取的数值是count,distance之类的,全局搜索可以便于找到你需要的值。
  • HKUnit获取完类别以后呢,我们需要查询这个类别对应的单位(Unit)。这个分类下的值的单位(米,千米之类的)
    iOS HealthKit 使用方法和注意点_第3张图片
    3D4E36E6-CC42-418D-A027-49F50D830868.png
  • 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以上)俩个字段来判断来源。这边需要注意的是多个数据来源的数据。不要一味的全部相加。

你可能感兴趣的:(iOS HealthKit 使用方法和注意点)