Post

Replies

Boosts

Views

Activity

SwiftUI how to get total Sleep hours from Healthkit
I have issue to request Authorization and get the total sleep hours from HealthKit func requestAuthorization(completion: @escaping (Bool) -> Void) {           let stepType = HKQuantityType.quantityType(forIdentifier: HKQuantityTypeIdentifier.stepCount)!     let heartRate = HKQuantityType.quantityType(forIdentifier: HKQuantityTypeIdentifier.heartRate)!     let spo2 = HKQuantityType.quantityType(forIdentifier: HKQuantityTypeIdentifier.respiratoryRate)!     let sleepHours = HKObjectType.categoryType(forIdentifier: .sleepAnalysis)     let setType = Set(arrayLiteral: sleep_type_t) //error cannot find 'sleepType' in scope ****           guard let healthStore = self.healthStore else { return completion(false) }           healthStore.requestAuthorization(toShare: [], read: [stepType,heartRate,spo2,sleepHours]) { (success, error) in       completion(success)     }         }    func getSleepHours(completion: @escaping (_ sleepHours: String?) -> Void) {     let sampleType = HKObjectType.categoryType(forIdentifier: HKCategoryTypeIdentifier.sleepAnalysis)!           // Get all samples from the last 24 hours     let endDate = Date()     let startDate = endDate.addingTimeInterval(-1.0 * 60.0 * 60.0 * 24.0)     let predicate = HKQuery.predicateForSamples(withStart: startDate, end: endDate, options: [])     let sortDescriptor = NSSortDescriptor(key: HKSampleSortIdentifierEndDate, ascending: false)     // Sleep query     let sleepQuery = HKSampleQuery(sampleType: sampleType,predicate: predicate,limit: 0,sortDescriptors: [sortDescriptor]) { (query, results, error) -> Void in             if error != nil {return}             // Sum the sleep time             var minutesSleepAggr = 0.0             if let result = results {               for item in result {                 if let sample = item as? HKCategorySample {                   if sample.value == HKCategoryValueSleepAnalysis.asleep.rawValue && sample.startDate >= startDate {                       let sleepTime = sample.endDate.timeIntervalSince(sample.startDate)                       let minutesInAnHour = 60.0                       let minutesBetweenDates = sleepTime / minutesInAnHour                       minutesSleepAggr += minutesBetweenDates                   }                 }               }               let sleepHours = Double(String(format: "%.1f", minutesSleepAggr / 60))!               let sleepHours2 = "(sleepHours)"               completion(sleepHours2)               print("*** SLEEP HOURS: (String(describing: sleepHours))")             }       }               healthStore?.execute(sleepQuery)   }
0
0
698
May ’22
Unexpected non-void return value in void function
//MARK : HealthStore   func getData() -> Double {     //Get Authorization     let stepType = HKQuantityType.quantityType(forIdentifier: HKQuantityTypeIdentifier.stepCount)!     let heartRate = HKQuantityType.quantityType(forIdentifier: HKQuantityTypeIdentifier.heartRate)!     let spo2 = HKQuantityType.quantityType(forIdentifier: HKQuantityTypeIdentifier.respiratoryRate)!     healthStore.requestAuthorization(toShare: [], read: [stepType,heartRate,spo2]) { (chk, error) in       if (chk){         print("Permission Granted")                   var dumm = 0.0         //currentHeartRate(completion: nil)         self.getSteps(currentDate: Date()) { result in           globalString.todayStepsCount = result           dumm = result           print(result)         }         return dumm       }                    }         } //getData             func getSteps(currentDate: Date, completion: @escaping (Double) -> Void) {     guard let sampleType = HKCategoryType.quantityType(forIdentifier: .stepCount) else {       print("Get Steps not executed as is null")       return     }     let now = currentDate //Date()     let startDate = Calendar.current.startOfDay(for: now)     let predicate = HKQuery.predicateForSamples(withStart: startDate, end: now, options: .strictEndDate)     let query = HKStatisticsQuery(quantityType: sampleType, quantitySamplePredicate: predicate, options: .cumulativeSum)     { _, result, _ in         guard let result = result, let sum = result.sumQuantity() else {           completion(0.0)           return         }         completion(sum.doubleValue(for: HKUnit.count()))       }     healthStore.execute(query)   }
1
0
698
May ’22