कसरत के रूट जोड़ें

यह गाइड, Health Connect के 1.1.0-alpha12 वर्शन के साथ काम करती है.

कसरत के रूट की मदद से, उपयोगकर्ता कसरत से जुड़ी गतिविधियों के लिए जीपीएस रूट को ट्रैक कर सकते हैं. साथ ही, अपने वर्कआउट के मैप को अन्य ऐप्लिकेशन के साथ शेयर कर सकते हैं.

सुविधा की उपलब्धता

यह पता लगाने के लिए कि उपयोगकर्ता के डिवाइस पर Health Connect में कसरत के रूट की सुविधा काम करती है या नहीं, क्लाइंट पर FEATURE_PLANNED_EXERCISE की उपलब्धता देखें:

if (healthConnectClient
     .features
     .getFeatureStatus(
       HealthConnectFeatures.FEATURE_PLANNED_EXERCISE
     ) == HealthConnectFeatures.FEATURE_STATUS_AVAILABLE) {

  // Feature is available
} else {
  // Feature isn't available
}

ज़्यादा जानने के लिए, सुविधा की उपलब्धता की जांच करना लेख पढ़ें.

इस गाइड में, उपयोगकर्ता से अनुमतियां मांगने का तरीका बताया गया है. इसमें यह भी बताया गया है कि कसरत के सेशन के दौरान, ऐप्लिकेशन को रास्ते का डेटा लिखने की अनुमति कैसे मिलती है.

कसरत के रूट से जुड़ा डेटा पढ़ने और लिखने की सुविधा में ये शामिल हैं:

  1. ऐप्लिकेशन, कसरत के रास्तों के लिए नई अनुमति बनाते हैं.
  2. रूट को फ़ील्ड के तौर पर इस्तेमाल करके, कसरत के सेशन की जानकारी डाली जाती है.
  3. पढ़ना:
    1. सेशन के मालिक के लिए, सेशन रीड का इस्तेमाल करके डेटा ऐक्सेस किया जाता है.
    2. किसी तीसरे पक्ष के ऐप्लिकेशन से, ऐसे डायलॉग के ज़रिए जिससे उपयोगकर्ता को किसी रूट को एक बार पढ़ने की अनुमति देने का विकल्प मिलता है.

अगर उपयोगकर्ता के पास लिखने की अनुमतियां नहीं हैं और रास्ता सेट नहीं है, तो रास्ता अपडेट नहीं होता.

अगर आपके ऐप्लिकेशन के पास रूट की जानकारी लिखने की अनुमति है और वह रूट की जानकारी के बिना सेशन ऑब्जेक्ट पास करके किसी सेशन को अपडेट करने की कोशिश करता है, तो मौजूदा रूट की जानकारी मिटा दी जाती है.

ज़रूरी अनुमतियां

कसरत के रूट को ऐक्सेस करने की सुविधा, इन अनुमतियों के तहत सुरक्षित है:

  • android.permission.health.READ_EXERCISE_ROUTE
  • android.permission.health.WRITE_EXERCISE_ROUTE

अपने ऐप्लिकेशन में कसरत के रूट की जानकारी दिखाने की सुविधा जोड़ने के लिए, ExerciseSession डेटा टाइप के लिए लिखने की अनुमतियों का अनुरोध करें.

कसरत के रूट की जानकारी लिखने के लिए, आपको इस अनुमति का एलान करना होगा:

<application>
  <uses-permission
android:name="android.permission.health.WRITE_EXERCISE_ROUTE" />
...
</application>

कसरत के रूट की जानकारी पढ़ने के लिए, आपको ये अनुमतियां मांगनी होंगी:

<application>
  <uses-permission
android:name="android.permission.health.READ_EXERCISE_ROUTE" />
...
</application>

आपको कसरत की अनुमति का एलान भी करना होगा, क्योंकि हर रास्ते को कसरत के सेशन से जोड़ा जाता है (एक सेशन = एक कसरत).

अनुमतियों का अनुरोध करने के लिए, अपने ऐप्लिकेशन को पहली बार Health Connect से कनेक्ट करते समय, PermissionController.createRequestPermissionResultContract() तरीके का इस्तेमाल करें. यहां कुछ अनुमतियां दी गई हैं जिनके लिए अनुरोध किया जा सकता है:

  • सेहत की जानकारी से जुड़ा डेटा पढ़ने की अनुमति दें. इसमें रास्ते की जानकारी भी शामिल है: HealthPermission.getReadPermission(ExerciseSessionRecord::class)
  • सेहत से जुड़ा डेटा लिखने की अनुमति दें. इसमें रास्ते का डेटा भी शामिल है: HealthPermission.getWritePermission(ExerciseSessionRecord::class)
  • कसरत के रूट का डेटा सेव करने की अनुमति दें: HealthPermission.PERMISSION_WRITE_EXERCISE_ROUTE

उपयोगकर्ता से अनुमतियों का अनुरोध करना

क्लाइंट इंस्टेंस बनाने के बाद, आपके ऐप्लिकेशन को उपयोगकर्ता से अनुमतियों का अनुरोध करना होगा. उपयोगकर्ताओं को किसी भी समय अनुमतियां देने या अस्वीकार करने की अनुमति होनी चाहिए.

इसके लिए, ज़रूरी डेटा टाइप के लिए अनुमतियों का सेट बनाएं. पक्का करें कि सेट में मौजूद अनुमतियों का एलान, सबसे पहले आपके Android मेनिफ़ेस्ट में किया गया हो.

// Create a set of permissions for required data types
val PERMISSIONS =
    setOf(
  HealthPermission.getReadPermission(ExerciseSessionRecord::class),
  HealthPermission.getWritePermission(ExerciseSessionRecord::class)
)

getGrantedPermissions का इस्तेमाल करके देखें कि आपके ऐप्लिकेशन को ज़रूरी अनुमतियां पहले से मिली हुई हैं या नहीं. अगर ऐसा नहीं है, तो उन अनुमतियों का अनुरोध करने के लिए createRequestPermissionResultContract का इस्तेमाल करें. इससे Health Connect की अनुमतियों वाली स्क्रीन दिखती है.

// Create the permissions launcher
val requestPermissionActivityContract = PermissionController.createRequestPermissionResultContract()

val requestPermissions = registerForActivityResult(requestPermissionActivityContract) { granted ->
  if (granted.containsAll(PERMISSIONS)) {
    // Permissions successfully granted
  } else {
    // Lack of required permissions
  }
}

suspend fun checkPermissionsAndRun(healthConnectClient: HealthConnectClient) {
  val granted = healthConnectClient.permissionController.getGrantedPermissions()
  if (granted.containsAll(PERMISSIONS)) {
    // Permissions already granted; proceed with inserting or reading data
  } else {
    requestPermissions.launch(PERMISSIONS)
  }
}

उपयोगकर्ता किसी भी समय अनुमतियां दे सकते हैं या उन्हें रद्द कर सकते हैं. इसलिए, आपके ऐप्लिकेशन को समय-समय पर यह जांच करनी चाहिए कि कौनसी अनुमतियां दी गई हैं. साथ ही, उन स्थितियों को मैनेज करना चाहिए जिनमें अनुमति नहीं दी गई है.

एक्सरसाइज़ सेशन के रिकॉर्ड में शामिल जानकारी

एक्सरसाइज़ के हर सेशन के रिकॉर्ड में यह जानकारी शामिल होती है:

  • कसरत का टाइप, जैसे कि साइकल चलाना.
  • कसरत का रास्ता. इसमें अक्षांश, देशांतर, और ऊंचाई जैसी जानकारी शामिल होती है.

इस्तेमाल किए जा सकने वाले एग्रीगेशन

इस डेटा टाइप के लिए, एग्रीगेशन की सुविधा काम नहीं करती.

इस्तेमाल का उदाहरण

किसी सेशन से कोई रास्ता ढूंढने का अनुरोध करें या कोई रास्ता लिखें.

किसी सेशन से रूट का अनुरोध करना

Health Connect में किसी सेशन को पढ़ने और उससे रूट का अनुरोध करने का तरीका यहां बताया गया है:

suspend fun readExerciseSessionAndRoute() {
    val endTime = Instant.now()
    val startTime = endTime.minus(Duration.ofHours(1))

    val grantedPermissions =
        healthConnectClient.permissionController.getGrantedPermissions()
    if (!grantedPermissions.contains(
          HealthPermission.getReadPermission(ExerciseSessionRecord::class))) {
        // The user doesn't allow the app to read exercise session data.
        return
    }

    val readResponse =
      healthConnectClient.readRecords(
        ReadRecordsRequest(
          ExerciseSessionRecord::class,
          TimeRangeFilter.between(startTime, endTime)
        )
      )
    val exerciseRecord = readResponse.records.first()
    val recordId = exerciseRecord.metadata.id

    // See https://developer.android.com/training/basics/intents/result#launch
    // for appropriately handling ActivityResultContract.
    val requestExerciseRouteLauncher = fragment.registerForActivityResul
    (ExerciseRouteRequestContract()) { exerciseRoute: ExerciseRoute? ->
            if (exerciseRoute != null) {
                displayExerciseRoute(exerciseRoute)
            } else {
                // Consent was denied
            }
        }

    val exerciseSessionRecord =
      healthConnectClient.readRecord(ExerciseSessionRecord::class, recordId).record

    when (val exerciseRouteResult = exerciseSessionRecord.exerciseRouteResult) {
        is ExerciseRouteResult.Data ->
            displayExerciseRoute(exerciseRouteResult.exerciseRoute)
        is ExerciseRouteResult.ConsentRequired ->
            requestExerciseRouteLauncher.launch(recordId)
        is ExerciseRouteResult.NoData -> Unit // No exercise route to show
        else -> Unit
    }
  }

  fun displayExerciseRoute(route: ExerciseRoute?) {
    val locations = route.route.orEmpty()
    for (location in locations) {
      // Handle location.
    }
  }

किसी सेशन से रूट लिखना

नीचे दिए गए कोड में, कसरत के रूट की जानकारी देने वाले सेशन को रिकॉर्ड करने का तरीका बताया गया है:

suspend fun InsertExerciseRoute(healthConnectClient: HealthConnectClient) {
    val grantedPermissions =
        healthConnectClient.permissionController.getGrantedPermissions()
    if (!grantedPermissions.contains(
          getWritePermission(ExerciseSessionRecord::class))) {
        // The user doesn't allow the app to write exercise session data.
        return
    }

    val sessionStartTime = Instant.now()
    val sessionDuration = Duration.ofMinutes(20)
    val sessionEndTime = sessionStartTime.plus(sessionDuration)

    val exerciseRoute =
        if (grantedPermissions.contains(PERMISSION_WRITE_EXERCISE_ROUTE)) ExerciseRoute(
            listOf(
                ExerciseRoute.Location(
                    // Location times must be on or after the session start time
                    time = sessionStartTime,
                    latitude = 6.5483,
                    longitude = 0.5488,
                    horizontalAccuracy = Length.meters(2.0),
                    verticalAccuracy = Length.meters(2.0),
                    altitude = Length.meters(9.0),
                ), ExerciseRoute.Location(
                    // Location times must be before the session end time
                    time = sessionEndTime.minusSeconds(1),
                    latitude = 6.4578,
                    longitude = 0.6577,
                    horizontalAccuracy = Length.meters(2.0),
                    verticalAccuracy = Length.meters(2.0),
                    altitude = Length.meters(9.2),
                )
            )
        )
        else
        // The user doesn't allow the app to write exercise route data.
            null
    val exerciseSessionRecord = ExerciseSessionRecord(
        startTime = sessionStartTime,
        startZoneOffset = ZoneOffset.UTC,
        endTime = sessionEndTime,
        endZoneOffset = ZoneOffset.UTC,
        exerciseType = ExerciseSessionRecord.EXERCISE_TYPE_BIKING,
        title = "Morning Bike Ride",
        exerciseRoute = exerciseRoute,
        metadata = Metadata.manualEntry(
            device = Device(type = Device.TYPE_PHONE)
        ),
    )
    val response = healthConnectClient.insertRecords(listOf(exerciseSessionRecord))
}