Google Fit'teki her veri noktasının ilişkili bir veri kaynağı vardır. Veri kaynakları bu verileri toplayan veya kullanan uygulamayı ya da cihazı tanımlayan bilgiler verileri dönüştürür. Uygulamanın paket adı, fiziksel bir sensörü temsil etmeyen veri kaynakları için kullanılabilir.
Google Fit ile şunları yapabilirsiniz:
- Belirli bir uygulamayla ilişkili verileri görüntülemek için bir intent çağırın.
- Uygulamanızı kullanarak veri göstermek için niyet alın.
- Hangi uygulamanın oturum eklediğini öğrenin. Daha fazla Oturumlarla çalışma başlıklı makaleyi inceleyin.
Hangi uygulamanın veri noktası eklediğini belirleme
Veri noktası ekleyen uygulamanın paket adını almak için önce
DataPoint.getOriginalDataSource
numaralı telefonu ara
çağırın ve ardından veri kaynağını çağırın.
DataSource.getAppPackageName
yöntem:
Kotlin
val dataPoint : DataPoint = ... val dataSource = dataPoint.originalDataSource val appPkgName = dataSource.appPackageName
Java
DataPoint dataPoint = ... DataSource dataSource = dataPoint.getOriginalDataSource(); String appPkgName = dataSource.getAppPackageName();
Diğer uygulamalardan intent alma
Uygulamanızı diğer sağlık ve sağlıklı yaşam uygulamalarından niyet almak üzere kaydetmek için: manifestinizde aşağıdakine benzer bir intent filtresi bildirin:
<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>
Uygulamanızın Google Fit'ten aldığı her intent tek bir türdedir ancak tek bir intent filtresinde birden fazla MIME türüne göre filtreleme yapabilirsiniz. Uygulamanızın intent filtresi, özel veri türleri dahil olmak üzere uygulamanızın desteklediği tüm veri türlerini içermelidir.
Fitness intent'leri aşağıdaki ekstraları içerir:
vnd.google.gms.fitness.start_time
vnd.google.gms.fitness.end_time
vnd.google.gms.fitness.data_source
Bu ekstralardan aşağıdaki şekilde veri alabilirsiniz:
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()); } }
Özel bir veri türünün MIME türünü almak için MIME_TYPE_PREFIX
sabit değerini kullanın:
Kotlin
val supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype"
Java
String supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype";
Verileri görüntülemek için intent çağırma
Başka bir uygulamayla veri görüntüleme niyeti çağırmak için
HistoryApi.ViewIntentBuilder
sınıf:
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();
Amaç ve amaçların nasıl kullanılacağı hakkında daha fazla bilgi edinin. filtreleri hakkında daha fazla bilgi edinin.