Atrybucja danych

Z każdym punktem danych w Google Fit powiązane jest źródło danych. Źródła danych zawierają informacje identyfikujące aplikację lub urządzenie, które zbiera lub przekształca dane. Nazwa pakietu aplikacji jest dostępna dla źródeł danych które nie reprezentują fizycznego czujnika.

Google Fit pozwala:

  • Wywołaj zamiar wyświetlenia danych powiązanych z konkretną aplikacją.
  • Otrzymuj intencje wyświetlania danych za pomocą aplikacji.
  • Dowiedz się, która aplikacja dodała sesję. Więcej Więcej informacji znajdziesz w artykule Praca z sesjami.

Określ, która aplikacja wstawiono punkt danych

Aby uzyskać nazwę pakietu aplikacji, która wstawiono punkt danych, zadzwoń do: DataPoint.getOriginalDataSource , aby uzyskać źródło danych, a następnie wywołaj funkcję 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();

Otrzymywanie intencji z innych aplikacji

Aby zarejestrować aplikację, aby otrzymywać intencje z innych aplikacji związanych ze zdrowiem i samopoczuciem: zadeklaruj w pliku manifestu filtr intencji podobny do tego:

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

Każda intencja, którą aplikacja otrzymuje z Google Fit, ma tylko 1 typ: ale w jednym filtrze intencji możesz filtrować wiele typów MIME. W przypadku Twojej aplikacji filtr intencji musi uwzględniać wszystkie typy danych obsługiwane przez aplikację, m.in. niestandardowe typy danych.

Cele związane z fitnessem obejmują te dodatki:

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

Dane z tych dodatków można uzyskać w ten sposób:

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

Aby uzyskać typ MIME dla niestandardowego typu danych, skorzystaj z funkcji MIME_TYPE_PREFIX stała:

Kotlin

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

Java

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

Wywołaj zamiar wyświetlenia danych

Aby wywołać intencję wyświetlenia danych w innej aplikacji, użyj funkcji HistoryApi.ViewIntentBuilder zajęcia:

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

Dowiedz się więcej o tym, jak używać zamiarów i zamiarów filtrów.