Google Fit'teki her veri noktasının ilişkili bir veri kaynağı vardır. Veri kaynakları, uygulamayı veya verileri toplayan ya da dönüştüren cihazı tanımlayan bilgiler içerir. Uygulamanın paket adı, fiziksel sensörü temsil etmeyen veri kaynakları için kullanılabilir.
Google Fit aşağıdakileri yapmanıza olanak sağlar:
- Belirli bir uygulamayla ilişkili verileri görüntülemek için bir intent çağırın.
- Uygulamanızı kullanarak veri gösterme amaçları alın.
- Hangi uygulamanın oturum eklediğini öğrenin. Daha fazla bilgi edinmek için Oturumlarla çalışma bölümünü inceleyin.
Veri noktası ekleyen uygulamayı belirleme
Veri noktası ekleyen uygulamanın paket adını elde etmek için DataPoint.getOriginalDataSource
yöntemini ve ardından veri kaynağını almak üzere DataSource.getAppPackageName
yöntemini çağırın:
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 amaçlar almak üzere kaydetmek için manifest dosyanızda aşağıdakine benzer bir intent filtresi tanımlayın:
<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 fazla MIME türünü filtreleyebilirsiniz. Uygulamanızın amaç filtresinin özel veri türleri de dahil olmak üzere uygulamanızın desteklediği tüm veri türlerini içermesi gerekir.
Fitness amaçları şu 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 elde edebilirsiniz:
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()); } }
Bir özel veri türü için MIME türünü elde etmek üzere MIME_TYPE_PREFIX
sabitini 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 bir intent çağırma
Başka bir uygulamayla veri görüntüleme niyeti çağırmak için HistoryApi.ViewIntentBuilder
sınıfını kullanın:
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çlar ve amaç filtrelerini nasıl kullanacağınız hakkında daha fazla bilgi edinin.