Health Connect का इस्तेमाल शुरू करना

इस गाइड में, अपने ऐप्लिकेशन पर Health Connect का इस्तेमाल शुरू करने का तरीका बताया गया है.

पहला चरण: Health Connect ऐप्लिकेशन तैयार करना

Health Connect ऐप्लिकेशन, आपके उन सभी अनुरोधों को मैनेज करने की ज़िम्मेदारी लेता है जो ऐप्लिकेशन, Health Connect SDK टूल की मदद से भेजता है. इन अनुरोधों में डेटा को सेव करना और उसे पढ़ने और उसमें बदलाव करने का ऐक्सेस मैनेज करना शामिल है.

Health Connect को ऐक्सेस करने की सुविधा, फ़ोन पर इंस्टॉल किए गए Android वर्शन पर निर्भर करती है. नीचे दिए सेक्शन में, Android के हाल ही के कई वर्शन को मैनेज करने का तरीका बताया गया है.

Android 14

Android 14 (एपीआई लेवल 34) से, Health Connect, Android फ़्रेमवर्क का हिस्सा है. Health Connect का यह वर्शन, फ़्रेमवर्क मॉड्यूल है. के साथ इसके लिए, किसी सेटअप की ज़रूरत नहीं है.

Android 13 और उससे पहले के वर्शन

Android 13 (एपीआई लेवल 33) और इससे पहले के वर्शन वाले डिवाइसों पर, Health Connect इसका हिस्सा नहीं है Android फ़्रेमवर्क के बारे में ज़्यादा जानें. इसके बाद, आपको Google Play Store से Health Connect ऐप्लिकेशन इंस्टॉल करना होगा.

अगर आपने Android 13 और उससे पहले के वर्शन पर, अपने ऐप्लिकेशन को Health Connect के साथ इंटिग्रेट किया है और आपको इसे Android 14 पर माइग्रेट करना है, तो Android 13 से 14 पर माइग्रेट करना लेख पढ़ें.

Health Connect ऐप्लिकेशन खोलना

Health Connect अब डिफ़ॉल्ट रूप से होम स्क्रीन पर नहीं दिखता. Health Connect खोलने के लिए, सेटिंग > ऐप्लिकेशन > Health Connect पर जाएं या Health Connect को क्विक सेटिंग मेन्यू में जोड़ें.

इसके अलावा, Health Connect का इस्तेमाल करने के लिए ज़रूरी है कि उपयोगकर्ता ने डिवाइस को पिन, पैटर्न या पासवर्ड से लॉक किया हो. इससे, डिवाइस के लॉक होने पर, Health Connect में सेव किए जा रहे स्वास्थ्य से जुड़े डेटा को नुकसान पहुंचाने वाले लोगों या ग्रुप से सुरक्षित रखा जा सकता है. स्क्रीन लॉक सेट करने के लिए, सेटिंग > सुरक्षा > स्क्रीन लॉक पर जाएं.

दूसरा चरण: अपने ऐप्लिकेशन में Health Connect SDK टूल जोड़ना

Health Connect API, Health Connect API का इस्तेमाल इन कामों के लिए करता है Health ऐप्लिकेशन में डेटा स्टोर के लिए कार्रवाई करने के लिए अनुरोध भेजें ऐप्लिकेशन को कनेक्ट करें.

मॉड्यूल लेवल की build.gradle फ़ाइल में, Health Connect SDK टूल की डिपेंडेंसी जोड़ें:

dependencies {
  ...
  implementation "androidx.health.connect:connect-client:1.1.0-alpha02"
  ...
}

नए वर्शन के लिए, Health Connect की रिलीज़ देखें.

तीसरा चरण: अपने ऐप्लिकेशन को कॉन्फ़िगर करना

इन सेक्शन में, Health Connect के साथ इंटिग्रेट करने के लिए, अपने ऐप्लिकेशन को कॉन्फ़िगर करने का तरीका बताया गया है.

अनुमतियों का एलान करना

सेहत और फ़िटनेस से जुड़ा डेटा संवेदनशील होता है. Health Connect, डेटा को पढ़ने और उसमें बदलाव करने के लिए, सुरक्षा की एक लेयर लागू करता है. इससे उपयोगकर्ता का भरोसा बना रहता है.

ज़रूरी डेटा टाइप के आधार पर, AndroidManifest.xml फ़ाइल पर डेटा को पढ़ने और उसमें बदलाव करने की अनुमतियां दें. पक्का करें कि [form]{:.external} भरने के बाद, आपने उन अनुमतियों का इस्तेमाल किया हो जिनके लिए आपने ऐक्सेस का अनुरोध किया था.

Health Connect, Android की अनुमति के एलान के स्टैंडर्ड फ़ॉर्मैट का इस्तेमाल करता है. <uses-permission> टैग की मदद से अनुमतियां असाइन करें. इन्हें <manifest> टैग में नेस्ट करें.

<manifest>
  <uses-permission android:name="android.permission.health.READ_HEART_RATE"/>
  <uses-permission android:name="android.permission.health.WRITE_HEART_RATE"/>
  <uses-permission android:name="android.permission.health.READ_STEPS"/>
  <uses-permission android:name="android.permission.health.WRITE_STEPS"/>

  <application>
  ...
  </application>
</manifest>

अनुमतियों और उनके डेटा टाइप की पूरी सूची देखने के लिए, डेटा टाइप की सूची देखें.

अपने ऐप्लिकेशन की निजता नीति का डायलॉग दिखाना

आपके Android मेनिफ़ेस्ट में एक ऐसी गतिविधि होनी चाहिए जो आपके ऐप्लिकेशन के निजता नीति, जो अनुरोध की गई अनुमतियों के लिए आपके ऐप्लिकेशन की वजह है, जिसमें बताया गया है कि उपयोगकर्ता के डेटा को कैसे इस्तेमाल और मैनेज किया जाता है.

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

...
<application>
  ...
  <!-- For supported versions through Android 13, create an activity to show the rationale
       of Health Connect permissions once users click the privacy policy link. -->
  <activity
      android:name=".PermissionsRationaleActivity"
      android:exported="true">
    <intent-filter>
      <action android:name="androidx.health.ACTION_SHOW_PERMISSIONS_RATIONALE" />
    </intent-filter>
  </activity>

  <!-- For versions starting Android 14, create an activity alias to show the rationale
       of Health Connect permissions once users click the privacy policy link. -->
  <activity-alias
      android:name="ViewPermissionUsageActivity"
      android:exported="true"
      android:targetActivity=".PermissionsRationaleActivity"
      android:permission="android.permission.START_VIEW_PERMISSION_USAGE">
    <intent-filter>
      <action android:name="android.intent.action.VIEW_PERMISSION_USAGE" />
      <category android:name="android.intent.category.HEALTH_PERMISSIONS" />
    </intent-filter>
  </activity-alias>
  ...
</application>
...

Health Connect का कोई क्लाइंट चुनें

HealthConnectClient, Health Connect API का एंट्री पॉइंट है. इसकी मदद से, ऐप्लिकेशन को Health Connect ऐप्लिकेशन में डेटास्टोर का इस्तेमाल करने की अनुमति मिलती है. यह, डेटा स्टोर करने वाली लेयर से अपने कनेक्शन को अपने-आप मैनेज करता है. साथ ही, सभी आईपीसी और आउटगोइंग अनुरोधों और इनकमिंग रिस्पॉन्स को सीरियलाइज़ करता है.

क्लाइंट इंस्टेंस पाने के लिए, पहले अपने Android मेनिफ़ेस्ट में Health Connect पैकेज का नाम बताएं.

<application> ... </application>
...
<!-- Check if Health Connect is installed -->
<queries>
    <package android:name="com.google.android.apps.healthdata" />
</queries>

इसके बाद, getSdkStatus का इस्तेमाल करके अपनी गतिविधि में जाकर देखें कि Health Connect इंस्टॉल है या नहीं. अगर ऐसा है, तो HealthConnectClient इंस्टेंस.

val availabilityStatus = HealthConnectClient.getSdkStatus(context, providerPackageName)
if (availabilityStatus == HealthConnectClient.SDK_UNAVAILABLE) {
  return // early return as there is no viable integration
}
if (availabilityStatus == HealthConnectClient.SDK_UNAVAILABLE_PROVIDER_UPDATE_REQUIRED) {
  // Optionally redirect to package installer to find a provider, for example:
  val uriString = "market://details?id=$providerPackageName&url=healthconnect%3A%2F%2Fonboarding"
  context.startActivity(
    Intent(Intent.ACTION_VIEW).apply {
      setPackage("com.android.vending")
      data = Uri.parse(uriString)
      putExtra("overlay", true)
      putExtra("callerId", context.packageName)
    }
  )
  return
}
val healthConnectClient = HealthConnectClient.getOrCreate(context)
// Issue operations with healthConnectClient

चौथा चरण: उपयोगकर्ता से अनुमतियों का अनुरोध करना

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

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

// Create a set of permissions for required data types
val PERMISSIONS =
setOf(
  HealthPermission.getReadPermission(HeartRateRecord::class),
  HealthPermission.getWritePermission(HeartRateRecord::class),
  HealthPermission.getReadPermission(StepsRecord::class),
  HealthPermission.getWritePermission(StepsRecord::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 में उपलब्ध डेटा टाइप की सूची देखें.

val stepsRecord = StepsRecord(
    count = 120,
    startTime = START_TIME,
    endTime = END_TIME,
    startZoneOffset = START_ZONE_OFFSET,
    endZoneOffset = END_ZONE_OFFSET,
)

इसके बाद, insertRecords का इस्तेमाल करके अपना रिकॉर्ड लिखें.

suspend fun insertSteps(healthConnectClient: HealthConnectClient) {
    try {
        val stepsRecord = StepsRecord(
            count = 120,
            startTime = START_TIME,
            endTime = END_TIME,
            startZoneOffset = START_ZONE_OFFSET,
            endZoneOffset = END_ZONE_OFFSET,
        )
        healthConnectClient.insertRecords(listOf(stepsRecord))
    } catch (e: Exception) {
        // Run error handling here
    }
}

डेटा पढ़ने की अनुमति दें

readRecords का इस्तेमाल करके, अपने डेटा को अलग-अलग पढ़ा जा सकता है.

suspend fun readStepsByTimeRange(
    healthConnectClient: HealthConnectClient,
    startTime: Instant,
    endTime: Instant
) {
    try {
        val response =
            healthConnectClient.readRecords(
                ReadRecordsRequest(
                    StepsRecord::class,
                    timeRangeFilter = TimeRangeFilter.between(startTime, endTime)
                )
            )
        for (stepRecord in response.records) {
            // Process each step record
        }
    } catch (e: Exception) {
        // Run error handling here.
    }
}

aggregate का इस्तेमाल करके, अपने डेटा को एग्रीगेट तरीके से भी पढ़ा जा सकता है.

suspend fun aggregateSteps(
    healthConnectClient: HealthConnectClient,
    startTime: Instant,
    endTime: Instant
) {
    try {
        val response = healthConnectClient.aggregate(
            AggregateRequest(
                metrics = setOf(StepsRecord.COUNT_TOTAL),
                timeRangeFilter = TimeRangeFilter.between(startTime, endTime)
            )
        )
        // The result may be null if no data is available in the time range
        val stepCount = response[StepsRecord.COUNT_TOTAL]
    } catch (e: Exception) {
        // Run error handling here
    }
}

वीडियो ट्यूटोरियल

Health Connect की सुविधाओं के बारे में ज़्यादा जानने के लिए, ये वीडियो देखें. साथ ही, इंटिग्रेशन को आसानी से पूरा करने के लिए, सबसे सही तरीकों के दिशा-निर्देश भी देखें:

संसाधन

इन संसाधनों को देखें. इनसे मदद मिलेगी जो बाद में डेवलप किए गए हैं.

अगले चरण

इनमें कार्रवाइयां करने का तरीका जानने के लिए, सामान्य वर्कफ़्लो देखें Health Connect में ये शामिल हैं: