Dans Google Fit, chaque point de données est associé à une source de données. Sources de données contenir des informations permettant d'identifier 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 actions suivantes:
- Appelez un intent pour afficher les données associées à une application spécifique.
- Recevoir des intents pour afficher des données à l'aide de votre application.
- Identifiez l'application qui a inséré une session. Pour plus d'informations, consultez la section Utiliser des sessions.
Déterminer quelle application a inséré un point de données
Pour obtenir le nom du package de l'application qui a inséré un point de données, commencez par
appeler DataPoint.getOriginalDataSource
pour obtenir la source de données, puis appelez
DataSource.getAppPackageName
méthode:
Kotlin
val dataPoint : DataPoint = ... val dataSource = dataPoint.originalDataSource val appPkgName = dataSource.appPackageName
Java
DataPoint dataPoint = ... DataSource dataSource = dataPoint.getOriginalDataSource(); String appPkgName = dataSource.getAppPackageName();
Recevoir des intents provenant d'autres applications
Pour enregistrer votre application afin de recevoir des 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 envoyé par Google Fit à votre appli est d'un seul type, mais vous pouvez filtrer plusieurs types MIME dans un seul filtre d'intent. Votre application le filtre d'intent doit inclure tous les types de données compatibles avec votre application, y compris les types de données personnalisés.
Les intents de fitness incluent les extras 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 extras 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 méthode
MIME_TYPE_PREFIX
constante:
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 des données avec une autre application, utilisez la méthode
HistoryApi.ViewIntentBuilder
classe:
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();
Découvrez comment utiliser les intents et les intents filtres.