ייחוס נתונים

לכל נקודה על הגרף ב-Google Fit משויך מקור נתונים. מקורות נתונים מכילים מידע שמזהה את האפליקציה או את המכשיר שאוסף או משנה את הנתונים. שם החבילה של האפליקציה זמין למקורות נתונים שאינם מייצגים חיישן פיזי.

ב-Google Fit יש לך אפשרות:

  • עידוד משתמשים לצפות בנתונים שמשויכים לאפליקציה ספציפית.
  • קבלת כוונות להצגת נתונים באמצעות האפליקציה.
  • בודקים איזו אפליקציה הוסיפה סשן. אפשר לקרוא מידע נוסף במאמר עבודה עם סשנים.

קביעת האפליקציה שהוסיפה נקודת נתונים

כדי להשיג את שם החבילה של האפליקציה שהוסיפה נקודת נתונים, תחילה צריך להתקשר למספר DataPoint.getOriginalDataSource כדי לקבל את מקור הנתונים, ואז להתקשר לשיטה 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();

קבלת כוונות מאפליקציות אחרות

כדי לרשום את האפליקציה לקבלת כוונות מאפליקציות אחרות לבריאות ואיכות חיים, יש להצהיר מסנן Intent במניפסט שדומה להצהרות הבאות:

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

כל כוונה שהאפליקציה מקבלת מ-Google Fit היא מסוג אחד, אבל אפשר לסנן לפי סוגי MIME רבים במסנן Intent יחיד. מסנן הכוונה של האפליקציה שלך צריך לכלול את כל סוגי הנתונים שהאפליקציה שלך תומכת בהם, כולל סוגי נתונים מותאמים אישית.

כוונות הכושר כוללות את התוספות הבאות:

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

אתה יכול לקבל נתונים מהתוספות האלה:

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

כדי לקבל את סוג ה-MIME עבור סוג נתונים מותאם אישית, השתמשו בקבוע הבא: MIME_TYPE_PREFIX:

Kotlin

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

Java

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

הפעלת כוונה להציג נתונים

כדי להקפיץ כוונות להצגת נתונים באמצעות אפליקציה אחרת, צריך להשתמש בכיתה 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();

מידע נוסף על השימוש במסנני כוונות וכוונות