Veri ilişkilendirmesi

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.