באמצעות Sensors API אפשר לקרוא נתוני חיישנים גולמיים באפליקציה בזמן אמת. אפשר להשתמש ב-API הזה כדי:
- הצגת רשימה של מקורות נתונים שזמינים במכשיר ובמכשירים נלווים.
- רישום מאזינים לקבלת נתוני חיישנים גולמיים.
- יש לבטל את רישום המאזינים כדי שכבר לא יקבלו נתונים גולמיים מחיישנים.
הצגת רשימה של מקורות הנתונים הזמינים
כדי לקבל רשימה של כל מקורות הנתונים הזמינים במכשיר ובמצב Companion
מכשירים, השתמשו
SensorsClient.findDataSources
method:
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()));
}
הסרת מאזינים
כדי להסיר מאזין מעדכוני נתונים גולמיים, משתמשים ב-method 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."));