Datenattribution

Jedem Datenpunkt in Google Fit ist eine Datenquelle zugeordnet. Datenquellen enthalten Informationen zur Identifizierung der App oder des Geräts, das die Daten erfasst oder umwandelt. Der Paketname der App ist für Datenquellen verfügbar, die keinen physischen Sensor darstellen.

Mit Google Fit können Sie Folgendes tun:

Herausfinden, von welcher App ein Datenpunkt eingefügt wurde

Rufen Sie zum Abrufen des Paketnamens der Anwendung, die einen Datenpunkt eingefügt hat, zuerst DataPoint.getOriginalDataSource auf, um die Datenquelle zu erhalten. Rufen Sie dann die Methode DataSource.getAppPackageName auf:

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

Damit Ihre App Intents von anderen Gesundheits- und Wellness-Apps erhalten soll, müssen Sie in Ihrem Manifest einen Intent-Filter angeben, 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 Ihre App von Google Fit erhält, hat nur einen Typ. Sie können aber in einem einzigen Intent-Filter nach mehreren MIME-Typen filtern. Der Intent-Filter der App muss alle Datentypen enthalten, die von der 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 aus diesen Extras wie folgt abrufen:

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 Konstante MIME_TYPE_PREFIX, 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 aufrufen, um Daten anzusehen

Verwenden Sie die Klasse HistoryApi.ViewIntentBuilder, um einen Intent zum Ansehen von Daten mit einer anderen Anwendung aufzurufen:

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 zum Verwenden von Intents und Intent-Filtern