Sensors API به شما امکان می دهد داده های خام حسگر را در برنامه خود در زمان واقعی بخوانید. از این API برای انجام کارهای زیر استفاده کنید:
- فهرست منابع داده موجود در دستگاه و دستگاه های همراه.
- شنوندگان را برای دریافت داده های حسگر خام ثبت کنید.
- شنوندگان را لغو ثبت کنید تا دیگر داده های حسگر خام را دریافت نکنند.
فهرست منابع داده موجود
برای به دست آوردن فهرستی از تمام منابع داده موجود در دستگاه و دستگاه های همراه، از روش SensorsClient.findDataSources
استفاده کنید:
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) }
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
استفاده کنید:
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) }
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
استفاده کنید:
Fitness.getSensorsClient(this, GoogleSignIn.getAccountForExtension(this, fitnessOptions)) .remove(listener) .addOnSuccessListener { Log.i(TAG, "Listener was removed!") } .addOnFailureListener { Log.i(TAG, "Listener was not removed.") }
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."));