با MeasureClient
API، برنامه شما برای دریافت دادهها برای مدت زمان کوتاهی تماسهای برگشتی را ثبت میکند. این برای شرایطی است که برنامه شما در حال استفاده است و به بهروزرسانی سریع داده نیاز دارد. در صورت امکان، این را با یک رابط کاربری پیش زمینه ایجاد کنید تا کاربر آگاه باشد.
وابستگی ها را اضافه کنید
برای افزودن وابستگی به خدمات سلامت، باید مخزن Google Maven را به پروژه خود اضافه کنید. برای اطلاعات بیشتر، به مخزن Maven Google مراجعه کنید.
سپس، در فایل build.gradle
در سطح ماژول، وابستگی زیر را اضافه کنید:
Groovy
dependencies { implementation "androidx.health:health-services-client:1.1.0-alpha05" }
Kotlin
dependencies { implementation("androidx.health:health-services-client:1.1.0-alpha05") }
بررسی قابلیت ها
قبل از ثبت نام برای بهروزرسانی داده، بررسی کنید که دستگاه میتواند نوع دادههای مورد نیاز برنامه شما را ارائه دهد. ابتدا با بررسی قابلیتها، میتوانید ویژگیهای خاصی را فعال یا غیرفعال کنید یا رابط کاربری برنامه خود را برای جبران قابلیتهایی که در دسترس نیستند تغییر دهید.
مثال زیر نحوه بررسی اینکه آیا دستگاهی میتواند نوع داده HEART_RATE_BPM
را ارائه دهد نشان میدهد:
val healthClient = HealthServices.getClient(this /*context*/)
val measureClient = healthClient.measureClient
lifecycleScope.launch {
val capabilities = measureClient.getCapabilitiesAsync().await()
supportsHeartRate = DataType.HEART_RATE_BPM in capabilities.supportedDataTypesMeasure
}
برای داده ثبت نام کنید
هر تماس برگشتی که ثبت می کنید برای یک نوع داده واحد است. توجه داشته باشید که برخی از انواع دادهها ممکن است حالتهای مختلف در دسترس بودن داشته باشند. برای مثال، زمانی که دستگاه به درستی به مچ دست وصل نشده باشد، ممکن است دادههای ضربان قلب در دسترس نباشد.
مهم است که مدت زمان ثبت تماس شما را به حداقل برسانید، زیرا تماسهای برگشتی باعث افزایش نرخ نمونهگیری حسگر میشوند که به نوبه خود مصرف انرژی را افزایش میدهد.
مثال زیر نحوه ثبت و لغو ثبت تماس برای دریافت داده های HEART_RATE_BPM
را نشان می دهد:
val heartRateCallback = object : MeasureCallback {
override fun onAvailabilityChanged(dataType: DeltaDataType<*, *>, availability: Availability) {
if (availability is DataTypeAvailability) {
// Handle availability change.
}
}
override fun onDataReceived(data: DataPointContainer) {
// Inspect data points.
}
}
val healthClient = HealthServices.getClient(this /*context*/)
val measureClient = healthClient.measureClient
// Register the callback.
measureClient.registerMeasureCallback(DataType.Companion.HEART_RATE_BPM, heartRateCallback)
// Unregister the callback.
awaitClose {
runBlocking {
measureClient.unregisterMeasureCallbackAsync(DataType.Companion.HEART_RATE_BPM, heartRateCallback)
}
}