Datenzuordnung

Jedem Datenpunkt in Google Fit ist eine Datenquelle zugeordnet. Datenquellen Informationen enthalten, durch die die App oder das Gerät identifiziert werden können, die bzw. das Daten erhebt oder transformiert die Daten. Der Paketname der App ist für Datenquellen verfügbar die keinen physischen Sensor darstellen.

Mit Google Fit haben Sie folgende Möglichkeiten:

  • Rufen Sie einen Intent auf, um Daten aufzurufen, die mit einer bestimmten App verknüpft sind.
  • Intents empfangen, um Daten mithilfe deiner App anzuzeigen.
  • Finden Sie heraus, welche App eine Sitzung eingefügt hat. Weitere Informationen Weitere Informationen finden Sie unter Mit Sitzungen arbeiten.

Bestimmen, von welcher App ein Datenpunkt eingefügt wurde

Um den Paketnamen der Anwendung zu erhalten, die einen Datenpunkt eingefügt hat, DataPoint.getOriginalDataSource anrufen um die Datenquelle abzurufen, und rufen Sie 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

So registrierst du deine App für den Empfang von Intents von anderen Gesundheits- und Wellness-Apps: 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>

Jede Absicht, die 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 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

So können Sie Daten aus diesen Extras 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());
    }
}

Um den MIME-Typ für einen benutzerdefinierten Datentyp abzurufen, verwenden Sie den MIME_TYPE_PREFIX Konstante:

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

Um einen Intent zum Ansehen von Daten mit einer anderen Anwendung aufzurufen, verwenden Sie den HistoryApi.ViewIntentBuilder Klasse:

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 Intents Filter.