Attribution des données

Chaque point de données dans Google Fit est associé à une source de données. Les sources de données contiennent des informations qui identifient l'application ou l'appareil qui collecte ou transforme les données. Le nom de package de l'application est disponible pour les sources de données qui ne représentent pas un capteur physique.

Google Fit vous permet d'effectuer les opérations suivantes:

  • Appelez un intent pour afficher les données associées à une application spécifique.
  • Recevez des intents pour afficher des données à l'aide de votre application.
  • Découvrez quelle application a inséré une session. Pour en savoir plus, consultez la page Gérer les sessions.

Déterminer quelle application a inséré un point de données

Pour obtenir le nom de package de l'application qui a inséré un point de données, appelez d'abord DataPoint.getOriginalDataSource pour obtenir la source de données, puis appelez la méthode 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();

Recevoir les intents d'autres applications

Pour enregistrer votre application afin qu'elle reçoive les intents d'autres applications de santé et de bien-être, déclarez dans votre fichier manifeste un filtre d'intent semblable à celui-ci:

<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>

Chaque intent reçu par Google Fit n'est associé qu'à un seul type, mais vous pouvez filtrer plusieurs types MIME dans un seul filtre d'intent. Le filtre d'intent de votre application doit inclure tous les types de données compatibles avec votre application, y compris les types de données personnalisés.

Les intents de remise en forme incluent les avantages suivants:

  • vnd.google.gms.fitness.start_time
  • vnd.google.gms.fitness.end_time
  • vnd.google.gms.fitness.data_source

Vous pouvez obtenir des données à partir de ces bonus comme suit:

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());
    }
}

Pour obtenir le type MIME d'un type de données personnalisé, utilisez la constante MIME_TYPE_PREFIX:

Kotlin

val supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype"

Java

String supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype";

Appeler un intent pour afficher les données

Pour appeler un intent afin d'afficher les données avec une autre application, utilisez la classe HistoryApi.ViewIntentBuilder:

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();

En savoir plus sur l'utilisation des intents et filtres d'intent