رویدادهای ورزشی را مدیریت کنید

Health Services از ExerciseEvents پشتیبانی می‌کند که در صورت وقوع رویدادی در حین تمرین به برنامه شما اطلاع می‌دهد و ابرداده‌های مرتبط را عرضه می‌کند.

وابستگی ها را اضافه کنید

استفاده از رویدادهای ورزشی به آخرین نسخه SDK خدمات سلامت نیاز دارد.

برای افزودن وابستگی به خدمات سلامت، باید مخزن Google Maven را به پروژه خود اضافه کنید. برای اطلاعات بیشتر، به مخزن Maven Google مراجعه کنید.

سپس، در فایل build.gradle در سطح ماژول، وابستگی زیر را اضافه کنید:

dependencies {
    implementation "androidx.health:health-services-client:1.1.0-alpha03"
}
dependencies {
    implementation("androidx.health:health-services-client:1.1.0-alpha03")
}

بررسی قابلیت ها

مانند تمام تمرین‌ها و انواع داده‌ها در خدمات بهداشتی، قابلیت‌ها را هنگام راه‌اندازی بررسی کنید . مخصوصاً برای ExerciseEvents ، علاوه بر درخواست ExerciseCapabilities ، از ExerciseTypeCapabilities.supportedExerciseEvents استفاده کنید تا بررسی کنید کدام رویدادهای ورزشی برای تمرین داده شده پشتیبانی می شوند. پس از تأیید پشتیبانی از ExerciseEvent خاص، باید قابلیت‌های رویداد تمرین را نیز با استفاده از getExerciseEventCapabilityDetails جستجو کنید.

مثال زیر نشان می‌دهد که چگونه می‌توان قابلیت‌ها را برای تأیید پشتیبانی از GOLF_SHOT_EVENT پرس و جو کرد و سپس تأیید کرد که GOLF_SHOT_EVENT از طبقه‌بندی نوع نوسان پشتیبانی می‌کند.

fun handleCapabilities(capabilities: ExerciseCapabilities) {
  val golfCapabilities = capabilities.typeToCapabilities[ExerciseType.GOLF]
  val golfShotEventSupported =
    golfCapabilities
      ?.supportedExerciseEvents
      ?.contains(ExerciseEventType.GOLF_SHOT_EVENT)
  val golfSwingTypeClassificationSupported =
    golfCapabilities
      ?.getExerciseEventCapabilityDetails(ExerciseEventType.GOLF_SHOT_EVENT)
      ?.isSwingTypeClassificationSupported ?: false
}

درخواست رویدادهای ورزشی در یک تمرین

برای شروع تمرین و درخواست یک رویداد تمرینی به عنوان بخشی از تمرین، ExerciseConfig برای تمرین اعلام کنید و یک فیلد برای exerciseEventType اضافه کنید.

مثال زیر GOLF_SHOT_EVENT به عنوان بخشی از تمرین GOLF درخواست می‌کند:

val config = ExerciseConfig(
  exerciseType = ExerciseType.GOLF,
  dataTypes = setOf(....),
  // ...
  exerciseEventTypes = setOf(ExerciseEventType.GOLF_SHOT_EVENT),
)

برای به روز رسانی رویدادهای ورزشی ثبت نام کنید

می‌توانید به‌روزرسانی‌های ExerciseEvent به عنوان بخشی از زیرساخت موجود برنامه‌تان برای دریافت به‌روزرسانی‌های تمرین دریافت کنید. مثال زیر نشان می‌دهد که چگونه می‌توانید از به‌روزرسانی‌های GolfShotEvent پشتیبانی کنید:

val callback = object : ExerciseUpdateCallback {
  override fun onExerciseUpdateReceived(update: ExerciseUpdate) {
      ...
  }
  // [ExerciseEvent] intended to come through with low latency and out of
  // band of onExerciseUpdateReceived()
  override fun onExerciseEventReceived(event: ExerciseEvent) {
    when (event) {
      is GolfShotEvent -> {
        if (it.swingType == GolfShotSwingType.PUTT) {
          println("Putt detected!")
        }
      }
    }
  }
}