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.