रॉ सेंसर का डेटा ऐक्सेस करें

सेंसर एपीआई की मदद से, ऐप्लिकेशन में रॉ सेंसर का रीयल-टाइम डेटा पढ़ा जा सकता है. इस काम के लिए इस एपीआई का इस्तेमाल करें:

  • ऐसे डेटा सोर्स की सूची दें जो डिवाइस और कंपैनियन डिवाइस पर उपलब्ध हैं.
  • सेंसर का रॉ डेटा पाने के लिए, लिसनर को रजिस्टर करें.
  • लिसनर का रजिस्ट्रेशन रद्द करें, ताकि उन्हें रॉ सेंसर का डेटा न मिले.

उपलब्ध डेटा सोर्स की सूची बनाना

डिवाइस और सहयोगी डिवाइस पर उपलब्ध सभी डेटा स्रोतों की सूची पाने के लिए, SensorsClient.findDataSources तरीके का इस्तेमाल करें:

Kotlin

private val fitnessOptions = FitnessOptions.builder().addDataType(DataType.TYPE_STEP_COUNT_DELTA).build()

// Note: Fitness.SensorsApi.findDataSources() requires the
// ACCESS_FINE_LOCATION permission.
Fitness.getSensorsClient(requireContext(), GoogleSignIn.getAccountForExtension(requireContext(), fitnessOptions))
    .findDataSources(
        DataSourcesRequest.Builder()
            .setDataTypes(DataType.TYPE_STEP_COUNT_DELTA)
            .setDataSourceTypes(DataSource.TYPE_RAW)
            .build())
    .addOnSuccessListener { dataSources ->
        dataSources.forEach {
            Log.i(TAG, "Data source found: ${it.streamIdentifier}")
            Log.i(TAG, "Data Source type: ${it.dataType.name}")

            if (it.dataType == DataType.TYPE_STEP_COUNT_DELTA) {
                Log.i(TAG, "Data source for STEP_COUNT_DELTA found!")

                ...
            }
        }
    }
    .addOnFailureListener { e ->
        Log.e(TAG, "Find data sources request failed", e)
    }

Java

FitnessOptions fitnessOptions = FitnessOptions.builder().addDataType(DataType.TYPE_STEP_COUNT_DELTA).build();

// Note: Fitness.SensorsApi.findDataSources() requires the
// ACCESS_FINE_LOCATION permission.
Fitness.getSensorsClient(getApplicationContext(), GoogleSignIn.getAccountForExtension(getApplicationContext(), fitnessOptions))
        .findDataSources(
                new DataSourcesRequest.Builder()
                        .setDataTypes(DataType.TYPE_STEP_COUNT_DELTA)
                        .setDataSourceTypes(DataSource.TYPE_RAW)
                        .build())
        .addOnSuccessListener(dataSources -> {
            dataSources.forEach(dataSource -> {
                Log.i(TAG, "Data source found: ${it.streamIdentifier}");
                Log.i(TAG, "Data Source type: ${it.dataType.name}");

                if (dataSource.getDataType() == DataType.TYPE_STEP_COUNT_DELTA) {
                    Log.i(TAG, "Data source for STEP_COUNT_DELTA found!");
                    ...
                }
            })})
        .addOnFailureListener(e ->
            Log.e(TAG, "Find data sources request failed", e));

डेटा सोर्स के लिए, डिवाइस के बारे में जानकारी पाने के लिए, DataSource.getDevice मैथड का इस्तेमाल करें. डिवाइस की जानकारी अलग-अलग डिवाइस पर मिलती-जुलती सेंसर से अलग होने में मदद करती है. साथ ही, डिवाइस की जानकारी को सेंसर से किसी उपयोगकर्ता को दिखाने या डिवाइस के मुताबिक डेटा को अलग-अलग तरीके से प्रोसेस करने के लिए भी काम की होती है. उदाहरण के लिए, हो सकता है कि आप किसी पहने जाने वाले डिवाइस पर खास तौर पर सेंसर से डेटा पढ़ने में दिलचस्पी दिखाएं, लेकिन फ़ोन पर उसी तरह के सेंसर से डेटा नहीं पढ़ना चाहें.

आपकी गतिविधि को दिखाने वाले डिवाइस का Device इंस्टेंस पाने के लिए, Device.getLocalDevice मैथड का इस्तेमाल करें. यह तब मददगार होता है, जब आप यह जांचना चाहते हैं कि डेटा स्रोत उसी डिवाइस पर है या नहीं जिस पर आपका ऐप्लिकेशन चल रहा है.

कोई लिसनर जोड़ें

किसी खास फ़िटनेस डेटा टाइप या किसी खास डेटा सोर्स से रॉ डेटा पाने के लिए सुनने वाला जोड़ने के लिए, SensorsClient.add तरीके का इस्तेमाल करें:

Kotlin

val listener = OnDataPointListener { dataPoint ->
        for (field in dataPoint.dataType.fields) {
            val value = dataPoint.getValue(field)
            Log.i(TAG, "Detected DataPoint field: ${field.name}")
            Log.i(TAG, "Detected DataPoint value: $value")
        }
    }

Fitness.getSensorsClient(this, GoogleSignIn.getAccountForExtension(this, fitnessOptions))
    .add(
        SensorRequest.Builder()
            .setDataSource(dataSource) // Optional but recommended for custom
            // data sets.
            .setDataType(dataType) // Can't be omitted.
            .setSamplingRate(10, TimeUnit.SECONDS)
            .build(),
        listener
    )
    .addOnSuccessListener {
    	Log.i(TAG, "Listener registered!")
    }
    .addOnFailureListener {
    	Log.e(TAG, "Listener not registered.", task.exception)
    }

Java

OnDataPointListener listener = dataPoint -> {
    for (Field field : dataPoint.getDataType().getFields()) {
        Value value = dataPoint.getValue(field);
        Log.i(TAG, "Detected DataPoint field: ${field.getName()}");
        Log.i(TAG, "Detected DataPoint value: $value");
    }
};
Fitness.getSensorsClient(this, GoogleSignIn.getAccountForExtension(this, fitnessOptions))
        .add(
                new SensorRequest.Builder()
                        .setDataSource(dataSource) // Optional but recommended
                        // for custom data sets.
                        .setDataType(dataType) // Can't be omitted.
                        .setSamplingRate(10, TimeUnit.SECONDS)
                        .build(),
                listener
        )
        .addOnSuccessListener(unused ->
                Log.i(TAG, "Listener registered!"))
        .addOnFailureListener(task ->
    Log.e(TAG, "Listener not registered.", task.getCause()));
}

किसी लिसनर को हटाएं

रॉ डेटा अपडेट की मदद से किसी सुनने वाले को हटाने के लिए, SensorsClient.remove तरीका इस्तेमाल करें:

Kotlin

Fitness.getSensorsClient(this, GoogleSignIn.getAccountForExtension(this, fitnessOptions))
    .remove(listener)
    .addOnSuccessListener {
    	Log.i(TAG, "Listener was removed!")
    }
    .addOnFailureListener {
    	Log.i(TAG, "Listener was not removed.")
    }

Java

Fitness.getSensorsClient(this, GoogleSignIn.getAccountForExtension(this, fitnessOptions))
        .remove(listener)
        .addOnSuccessListener(unused ->
                Log.i(TAG, "Listener was removed!"))
        .addOnFailureListener(e ->
                Log.i(TAG, "Listener was not removed."));