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ı, veri kaynakları için kullanılabilir fiziksel bir sensörü temsil etmez.
Google Fit şunları yapmanıza olanak tanır:
- Belirli bir uygulamayla ilişkilendirilmiş verileri görüntülemek için niyet ç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 amaç yalnızca tek bir türdür. ancak tek bir intent filtresinde birden çok MIME türünü filtreleyebilirsiniz. Uygulamanızın intent filtresi, uygulamanızın desteklediği tüm veri türlerini içermelidir. dahil edin.
Fitness amaçları 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 veri almak için aşağıdaki adımları uygulayın:
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:
Kotlin
val supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype"
Java
String supportedType = DataType.MIME_TYPE_PREFIX + "com.company.customdatatype";
Verileri görüntüleme niyetinde çağrı yapma
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.