A ogni punto dati di Google Fit è associata un'origine dati. Le origini dati contengono informazioni che identificano l'app o il dispositivo che raccoglie o trasforma i dati. Il nome di pacchetto dell'app è disponibile per le origini dati che non rappresentano un sensore fisico.
Google Fit ti consente di:
- Richiamare un intento di visualizzare dati associati a un'app specifica.
- Ricevi intent per mostrare i dati utilizzando la tua app.
- Scopri quale app ha inserito una sessione. Per ulteriori informazioni, consulta Utilizzo delle sessioni.
Stabilire quale app ha inserito un punto dati
Per ottenere il nome del pacchetto dell'applicazione che ha inserito un punto dati, chiama innanzitutto DataPoint.getOriginalDataSource
per ottenere l'origine dati, quindi chiama il metodo 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();
Ricevere intent da altre app
Per registrare la tua app in modo da ricevere intent da altre app per salute e benessere, dichiara nel file manifest un filtro per intent simile a quello che segue:
<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>
Ogni intent che la tua app riceve da Google Fit è di un solo tipo, ma puoi filtrare in base a più tipi MIME in un singolo filtro per intent. Il filtro per intent dell'app deve includere tutti i tipi di dati supportati dall'app, inclusi i tipi di dati personalizzati.
Gli intent di fitness includono i seguenti extra:
vnd.google.gms.fitness.start_time
vnd.google.gms.fitness.end_time
vnd.google.gms.fitness.data_source
Puoi ottenere dati da questi extra nel seguente modo:
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()); } }
Per ottenere il tipo MIME per un tipo di dati personalizzato, utilizza la costante MIME_TYPE_PREFIX
:
Kotlin
val supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype"
Java
String supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype";
Richiamare l'intenzione di visualizzare i dati
Per richiamare un intento di visualizzare i dati con un'altra app, utilizza 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();
Scopri di più su come utilizzare intent e filtri per intent.