لكل نقطة بيانات في 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-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 متعددة في فلتر أهداف واحد. يجب أن يتضمّن فلتر الأهداف في تطبيقك جميع أنواع البيانات التي يتيحها تطبيقك، بما في ذلك أنواع البيانات المخصّصة.
تتضمن أغراض اللياقة البدنية العناصر الإضافية التالية:
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();
مزيد من المعلومات حول كيفية استخدام الأهداف والنية والفلاتر.