Attribuzione dei dati

A ogni punto dati in Google Fit è associata un'origine dati. Origini dati Contenere informazioni che identificano l'app o il dispositivo che raccoglie o trasforma i dati. Il nome del pacchetto dell'app è disponibile per le origini dati che non rappresentano un sensore fisico.

Google Fit ti consente di:

  • Richiama un intent per visualizzare i 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 informazioni, consulta Utilizzare le sessioni.

Stabilire quale app ha inserito un punto dati

Per ottenere il nome del pacchetto dell'applicazione che ha inserito un punto dati, devi innanzitutto chiama DataPoint.getOriginalDataSource per ottenere l'origine dati, quindi richiama DataSource.getAppPackageName :

KotlinJava
val dataPoint : DataPoint = ...
val dataSource = dataPoint.originalDataSource
val appPkgName = dataSource.appPackageName
DataPoint dataPoint = ...
DataSource dataSource = dataPoint.getOriginalDataSource();
String appPkgName = dataSource.getAppPackageName();

Ricevi intent da altre app

Per registrare la tua app in modo da ricevere intent da altre app per la salute e il benessere, dichiarare un filtro per intent nel file manifest simile al seguente:

<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 per più tipi MIME in un singolo filtro per intent. Della tua app il filtro per intent deve includere tutti i tipi di dati supportati dall'app, inclusi i tipi di dati personalizzati.

Gli scopi 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 i dati da queste funzionalità aggiuntive nel seguente modo:

KotlinJava
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)
   
}
}
@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 MIME_TYPE_PREFIX costante:

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

Richiamare un intent per visualizzare i dati

Per richiamare un intent per visualizzare i dati con un'altra app, utilizza la classe HistoryApi.ViewIntentBuilder classe:

KotlinJava
// 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()
// 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 intenzioni filtri.