داده های جمع شده را بخوانید

تجمیع داده‌ها در Health Connect شامل تجمیع‌های اولیه یا تجمیع داده‌ها در سطل‌ها می‌شود. گردش کار زیر به شما نشان می دهد که چگونه هر دو را انجام دهید.

تجمیع اساسی

برای استفاده از تجمیع اولیه در داده های خود، از تابع aggregate در شی HealthConnectClient خود استفاده کنید. شیء AggregateRequest را می پذیرد که در آن انواع متریک و محدوده زمانی را به عنوان پارامترهای آن اضافه می کنید. نحوه فراخوانی مصالح پایه به انواع متریک مورد استفاده بستگی دارد.

تجمع تجمعی

تجمع تجمعی مقدار کل را محاسبه می کند.

مثال زیر به شما نشان می دهد که چگونه داده ها را برای یک نوع داده جمع آوری کنید:

suspend fun aggregateDistance(
    healthConnectClient: HealthConnectClient,
    startTime: Instant,
    endTime: Instant
) {
    try {
        val response = healthConnectClient.aggregate(
            AggregateRequest(
                metrics = setOf(DistanceRecord.DISTANCE_TOTAL),
                timeRangeFilter = TimeRangeFilter.between(startTime, endTime)
            )
        )
        // The result may be null if no data is available in the time range
        val distanceTotalInMeters = response[DistanceRecord.DISTANCE_TOTAL]?.inMeters ?: 0L
    } catch (e: Exception) {
        // Run error handling here
    }
}

تجمیع آماری

تجمیع آماری مقادیر حداقل، حداکثر یا میانگین رکوردها را با نمونه ها محاسبه می کند.

مثال زیر نحوه استفاده از تجمیع آماری را نشان می دهد:

suspend fun aggregateHeartRate(
    healthConnectClient: HealthConnectClient,
    startTime: Instant,
    endTime: Instant
) {
    try {
        val response =
            healthConnectClient.aggregate(
                AggregateRequest(
                    setOf(HeartRateRecord.BPM_MAX, HeartRateRecord.BPM_MIN),
                    timeRangeFilter = TimeRangeFilter.between(startTime, endTime)
                )
            )
        // The result may be null if no data is available in the time range
        val minimumHeartRate = response[HeartRateRecord.BPM_MIN]
        val maximumHeartRate = response[HeartRateRecord.BPM_MAX]
    } catch (e: Exception) {
        // Run error handling here
    }
}

سطل

Health Connect همچنین می تواند به شما امکان دهد داده ها را در سطل ها جمع آوری کنید. دو نوع سطل که می توانید استفاده کنید شامل مدت زمان و دوره است.

پس از تماس، آنها لیستی از سطل ها را برمی گردانند. توجه داشته باشید که فهرست می‌تواند پراکنده باشد، بنابراین اگر سطل حاوی داده‌ای نباشد، در لیست قرار نمی‌گیرد.

مدت

در این حالت، داده‌های جمع‌آوری شده در مدت زمان مشخصی مانند یک دقیقه یا یک ساعت به سطل‌هایی تقسیم می‌شوند. برای جمع آوری داده ها در سطل ها، از aggregateGroupByDuration استفاده کنید. یک شی AggregateGroupByDurationRequest را می پذیرد که در آن انواع متریک، محدوده زمانی و Duration به عنوان پارامتر اضافه می کنید.

در زیر نمونه ای از تجمیع مراحل در سطل های دقیقه ای را نشان می دهد:

suspend fun aggregateStepsIntoMinutes(
    healthConnectClient: HealthConnectClient,
    startTime: LocalDateTime,
    endTime: LocalDateTime
) {
    try {
        val response =
            healthConnectClient.aggregateGroupByDuration(
                AggregateGroupByDurationRequest(
                    metrics = setOf(StepsRecord.COUNT_TOTAL),
                    timeRangeFilter = TimeRangeFilter.between(startTime, endTime),
                    timeRangeSlicer = Duration.ofMinutes(1L)
                )
            )
        for (durationResult in response) {
            // The result may be null if no data is available in the time range
            val totalSteps = durationResult.result[StepsRecord.COUNT_TOTAL]
        }
    } catch (e: Exception) {
        // Run error handling here
    }
}

دوره

در این مورد، داده‌های جمع‌آوری شده در مدت زمان مبتنی بر تاریخ، مانند یک هفته یا یک ماه، به سطل‌هایی تقسیم می‌شوند. برای جمع آوری داده ها در سطل ها، از aggregateGroupByPeriod استفاده کنید. یک شی AggregateGroupByPeriodRequest را می پذیرد که در آن انواع متریک، محدوده زمانی و Period را به عنوان پارامتر اضافه می کنید.

در زیر نمونه ای از تجمیع مراحل در سطل های ماهانه را نشان می دهد:

suspend fun aggregateStepsIntoMonths(
    healthConnectClient: HealthConnectClient,
    startTime: LocalDateTime,
    endTime: LocalDateTime
) {
    try {
        val response =
            healthConnectClient.aggregateGroupByPeriod(
                AggregateGroupByPeriodRequest(
                    metrics = setOf(StepsRecord.COUNT_TOTAL),
                    timeRangeFilter = TimeRangeFilter.between(startTime, endTime),
                    timeRangeSlicer = Period.ofMonths(1)
                )
            )
        for (monthlyResult in response) {
            // The result may be null if no data is available in the time range
            val totalSteps = monthlyResult.result[StepsRecord.COUNT_TOTAL]
        }
    } catch (e: Exception) {
        // Run error handling here
    }
}

محدودیت ها را بخوانید

به‌طور پیش‌فرض، برنامه شما می‌تواند داده‌ها را تا 30 روز با هر گونه مجوزی بخواند. با مجوز PERMISSION_READ_HEALTH_DATA_HISTORY ، برنامه شما می‌تواند داده‌های قدیمی‌تر از 30 روز را بخواند.

محدودیت 30 روزه

برنامه ها می توانند داده ها را از Health Connect تا 30 روز قبل از اولین بار اعطای مجوز بخوانند.

با این حال، اگر کاربری برنامه شما را حذف کند، تاریخچه مجوز از بین می رود. اگر کاربر برنامه شما را مجدداً نصب کند و دوباره مجوز بدهد، برنامه شما می‌تواند تا 30 روز قبل از تاریخ جدید داده‌ها را از Health Connect بخواند.

مثال 30 روزه

اگر کاربر برای اولین بار در 30 مارس 2023 مجوز خواندن را به برنامه شما اعطا کرد، اولین اطلاعاتی که برنامه شما می تواند بازخوانی کند از 28 فوریه 2023 به بعد خواهد بود.

سپس کاربر برنامه شما را در 10 مه 2023 حذف می کند. کاربر تصمیم می گیرد آن را در 15 مه 2023 مجدداً نصب کند و اجازه خواندن را اعطا کند. اولین تاریخی که برنامه شما اکنون می تواند داده ها را بخواند ، 15 آوریل 2023 است.

خواندن داده های قدیمی تر از 30 روز

اگر می‌خواهید داده‌های قدیمی‌تر از 30 روز را بخوانید، باید از مجوز PERMISSION_READ_HEALTH_DATA_HISTORY استفاده کنید. بدون این مجوز، تلاش برای خواندن یک رکورد قدیمی‌تر از 30 روز منجر به خطا می‌شود. همچنین نمی‌توانید با استفاده از یکی از درخواست‌های محدوده زمانی، داده‌های قدیمی‌تر از 30 روز را بخوانید.