Jeder Datenpunkt in Google Fit ist mit einer Datenquelle verknüpft. Datenquellen enthalten Informationen zur Identifizierung der App oder des Geräts, das die Daten erfasst oder transformiert. Der Paketname der App ist für Datenquellen verfügbar, die keinen physischen Sensor darstellen.
Mit Google Fit können Sie Folgendes tun:
- Rufen Sie einen Intent auf, um Daten anzusehen, die mit einer bestimmten App verknüpft sind.
- Intents zum Anzeigen von Daten mit deiner App erhalten.
- Sehen Sie nach, von welcher App eine Sitzung eingefügt wurde. Weitere Informationen finden Sie unter Mit Sitzungen arbeiten.
Bestimmen, durch welche App ein Datenpunkt eingefügt wurde
Sie erhalten den Paketnamen der Anwendung, mit der ein Datenpunkt eingefügt wurde. Dazu rufen Sie zuerst DataPoint.getOriginalDataSource
auf, um die Datenquelle abzurufen, und dann die Methode DataSource.getAppPackageName
:
Kotlin
val dataPoint : DataPoint = ... val dataSource = dataPoint.originalDataSource val appPkgName = dataSource.appPackageName
Java
DataPoint dataPoint = ... DataSource dataSource = dataPoint.getOriginalDataSource(); String appPkgName = dataSource.getAppPackageName();
Intents von anderen Apps empfangen
Wenn Sie Ihre App für den Empfang von Intents von anderen Gesundheits- und Wellness-Apps registrieren möchten, deklarieren Sie in Ihrem Manifest einen Intent-Filter, der in etwa so aussieht:
<intent-filter> <action android:name="vnd.google.fitness.VIEW" /> <data android:mimeType="vnd.google.fitness.data_type/com.google.step_count.cumulative" /> <data android:mimeType="vnd.google.fitness.data_type/com.google.step_count.delta" /> </intent-filter>
Jeder Intent, den deine App von Google Fit erhält, hat nur einen Typ. Du kannst jedoch in einem einzelnen Intent-Filter nach mehreren MIME-Typen filtern. Der Intent-Filter Ihrer App muss alle Datentypen enthalten, die von Ihrer App unterstützt werden, einschließlich benutzerdefinierter Datentypen.
Die Fitness-Intents umfassen die folgenden Extras:
vnd.google.gms.fitness.start_time
vnd.google.gms.fitness.end_time
vnd.google.gms.fitness.data_source
Sie können Daten von diesen Extras wie folgt erhalten:
Kotlin
override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) ... val supportedType = DataType.getMimeType(DataType.TYPE_STEP_COUNT_DELTA) if (Intent.ACTION_VIEW == intent.action && supportedType == intent.type) { // Get the intent extras val startTime = Fitness.getStartTime(intent, TimeUnit.MILLISECONDS); val endTime = Fitness.getEndTime(intent, TimeUnit.MILLISECONDS) val dataSource = DataSource.extract(intent) } }
Java
@Override public void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); ... String supportedType = DataType.getMimeType(DataType.TYPE_STEP_COUNT_DELTA); if (Intent.ACTION_VIEW.equals(getIntent().getAction()) && supportedType.equals(getIntent().getType()) { // Get the intent extras long startTime = Fitness.getStartTime(getIntent(), TimeUnit.MILLISECONDS); long endTime = Fitness.getEndTime(getIntent(), TimeUnit.MILLISECONDS); DataSource dataSource = DataSource.extract(getIntent()); } }
Verwenden Sie die MIME_TYPE_PREFIX
-Konstante, um den MIME-Typ für einen benutzerdefinierten Datentyp abzurufen:
Kotlin
val supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype"
Java
String supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype";
Intent zum Ansehen von Daten aufrufen
Verwenden Sie die Klasse HistoryApi.ViewIntentBuilder
, um einen Intent aufzurufen, um Daten mit einer anderen Anwendung anzusehen:
Kotlin
// Inside your activity val startTime = ... val endTime = ... val dataSource = ... val dataType = ... val fitIntent = HistoryApi.ViewIntentBuilder(this, dataType) .setTimeInterval(startTime, endTime, TimeUnit.MILLISECONDS) .setDataSource(dataSource) // Optional if a specific data source is desired .setPreferredApplication("com.example.app") // Optional if you'd like a // specific app to handle the intent if that app is installed on the device .build()
Java
// Inside your activity long startTime = ... long endTime = ... DataSource dataSource = ... DataType dataType = ... Intent fitIntent = new HistoryApi.ViewIntentBuilder(this, dataType) .setTimeInterval(startTime, endTime, TimeUnit.MILLISECONDS) .setDataSource(dataSource) // Optional if a specific data source is desired .setPreferredApplication("com.example.app") // Optional if you'd like a // specific app to handle the intent if that app is installed on the device .build();
Weitere Informationen zur Verwendung von Intents und Intent-Filtern