Yêu cầu về siêu dữ liệu

Hướng dẫn này tương thích với Health Connect phiên bản 1.1.0-alpha12.

Có những thay đổi đối với siêu dữ liệu trong Health Connect dành cho những nhà phát triển chọn nâng cấp lên phiên bản 1.1.0-alpha12.

Thông tin về thư viện

Mã nhận dạng cấu phần phần mềm Trình bổ trợ Gradle Android của Google Maven xác định thư viện Health Connect mà bạn sẽ cần nâng cấp. Thêm phần phụ thuộc SDK Health Connect này vào tệp build.gradle ở cấp mô-đun:

dependencies {
  implementation "androidx.health.connect:connect-client:1.1.0-alpha12"
}

Thay đổi về siêu dữ liệu

Hai thay đổi về siêu dữ liệu đã được đưa vào Health Connect Jetpack SDK kể từ phiên bản 1.1.0-alpha12 để đảm bảo rằng hệ sinh thái có thêm siêu dữ liệu hữu ích.

Chỉ định phương thức ghi

Bạn phải chỉ định thông tin chi tiết về siêu dữ liệu bất cứ khi nào một đối tượng thuộc loại Record() được tạo thực thể.

Bạn phải chỉ định một trong 4 phương thức ghi khi ghi dữ liệu vào Health Connect:

Phương pháp ghi Mô tả
RECORDING_METHOD_UNKNOWN Không xác minh được phương thức ghi hình.
RECORDING_METHOD_MANUAL_ENTRY Người dùng đã nhập dữ liệu.
RECORDING_METHOD_AUTOMATICALLY_RECORDED Một thiết bị hoặc cảm biến đã ghi lại dữ liệu.
RECORDING_METHOD_ACTIVELY_RECORDED Người dùng đã bắt đầu hoặc kết thúc phiên ghi hình trên một thiết bị.

Ví dụ:

StepsRecord(
    startTime \= Instant.ofEpochMilli(1234L),
    startZoneOffset \= null,
    endTime \= Instant.ofEpochMilli(1236L),
    endZoneOffset \= null,
    metadata \= Metadata.manualEntry(),
    Count \= 10,
)

Loại thiết bị

Bạn phải chỉ định một loại thiết bị cho tất cả dữ liệu được ghi lại tự động và chủ động. Các loại thiết bị hiện tại bao gồm:

Loại thiết bị Mô tả
TYPE_UNKNOWN Không xác định được loại thiết bị.
TYPE_WATCH Loại thiết bị là đồng hồ.
TYPE_PHONE Loại thiết bị là điện thoại.
TYPE_SCALE Loại thiết bị là cân.
TYPE_RING Loại thiết bị là chuông.
TYPE_HEAD_MOUNTED Loại thiết bị là thiết bị gắn trên đầu.
TYPE_FITNESS_BAND Loại thiết bị là vòng đeo tay theo dõi sức khoẻ.
TYPE_CHEST_STRAP Loại thiết bị là dây đeo ngực.
TYPE_SMART_DISPLAY Loại thiết bị là màn hình thông minh.

Một số giá trị Device.type chỉ có trong các phiên bản Health Connect mới hơn. Khi tính năng loại thiết bị mở rộng không dùng được, các loại này sẽ được coi là Device.TYPE_UNKNOWN.

Các loại thiết bị mở rộng Mô tả
TYPE_CONSUMER_MEDICAL_DEVICE Loại thiết bị là thiết bị y tế.
TYPE_GLASSES Loại thiết bị là kính thông minh hoặc kính đeo.
TYPE_HEARABLE Loại thiết bị là thiết bị trợ thính.
TYPE_FITNESS_MACHINE Loại thiết bị là máy cố định.
TYPE_FITNESS_EQUIPMENT Loại thiết bị là thiết bị tập thể dục.
TYPE_PORTABLE_COMPUTER Loại thiết bị là máy tính xách tay.
TYPE_METER Loại thiết bị là đồng hồ đo.
Để xác định xem thiết bị của người dùng có hỗ trợ Extended Device Types trên Health Connect hay không, hãy kiểm tra trạng thái cung cấp của FEATURE_EXTENDED_DEVICE_TYPES trên ứng dụng:

if (healthConnectClient
     .features
     .getFeatureStatus(
       HealthConnectFeatures.FEATURE_EXTENDED_DEVICE_TYPES
     ) == HealthConnectFeatures.FEATURE_STATUS_AVAILABLE) {

  // Feature is available
} else {
  // Feature isn't available
}
Hãy xem phần Kiểm tra phạm vi cung cấp tính năng để tìm hiểu thêm.

Nếu có thể, hãy cung cấp nhà sản xuất và kiểu máy của thiết bị, ngoài loại thiết bị. Ví dụ:

private val TEST_DEVICE = Device(
    manufacturer = "Google",
    model = "Pixel Watch",
    type = Device.TYPE_WATCH
)

Đã cập nhật đoạn trích

Chúng tôi đã cập nhật các hướng dẫn về Health Connect ở những nơi cần có đoạn mã mới để tuân thủ các yêu cầu mới về siêu dữ liệu. Để xem một số ví dụ, hãy tham khảo trang Ghi dữ liệu.

Phương thức siêu dữ liệu mới

Bạn không thể trực tiếp tạo thực thể siêu dữ liệu nữa, vì vậy, hãy dùng một trong các phương thức của nhà máy để lấy một thực thể siêu dữ liệu mới. Mỗi hàm có 3 biến thể chữ ký:

  • activelyRecorded

    • fun activelyRecorded(device: Device): Metadata.
    • fun activelyRecorded(clientRecordId: String, clientRecordVersion: Long = 0, device: Device): Metadata
    • fun activelyRecordedWithId(id: String, device: Device): Metadata
  • autoRecorded

    • fun autoRecorded(device: Device): Metadata
    • fun autoRecorded(clientRecordId: String, clientRecordVersion: Long = 0, device: Device): Metadata
    • fun autoRecordedWithId(id: String, device: Device): Metadata
  • manualEntry

    • fun manualEntry(device: Device? = null): Metadata
    • fun manualEntry(clientRecordId: String, clientRecordVersion: Long = 0, device: Device? = null): Metadata
    • fun manualEntryWithId(id: String, device: Device? = null): Metadata
  • unknownRecordingMethod

    • fun unknownRecordingMethod(device: Device? = null): Metadata
    • fun unknownRecordingMethod(clientRecordId: String, clientRecordVersion: Long = 0, device: Device? = null): Metadata
    • fun unknownRecordingMethodWithId(id: String, device: Device? = null): Metadata

Để biết thêm thông tin, hãy xem Dự án nguồn mở Android.

Dữ liệu kiểm thử

Sử dụng Thư viện kiểm thử để mô phỏng các giá trị siêu dữ liệu dự kiến:

private val TEST_METADATA =
    Metadata.unknownRecordingMethod(
        clientRecordId = "clientId",
        clientRecordVersion = 1L,
        device = Device(type = Device.TYPE_UNKNOWN),
    ).populatedWithTestValues(id = "test")

Điều này mô phỏng hành vi của việc triển khai Health Connect, tự động điền các giá trị này trong quá trình chèn bản ghi.

Đối với thư viện kiểm thử, bạn cần thêm phần phụ thuộc SDK Health Connect này vào tệp build.gradle ở cấp mô-đun:

dependencies {
  testImplementation "androidx.health.connect:connect-testing:1.0.0-alpha02"
}

Nâng cấp thư viện

Các bước chính bạn cần thực hiện là:

  1. Nâng cấp thư viện lên phiên bản 1.1.0-alpha12.

  2. Khi tạo thư viện, lỗi biên dịch sẽ xảy ra khi cần siêu dữ liệu mới, vì vậy, hãy nhớ triển khai các thay đổi cần thiết về siêu dữ liệu bất cứ khi nào một đối tượng thuộc loại Record() được khởi tạo. Thao tác này sẽ hoàn tất quá trình di chuyển.

  3. Nếu ứng dụng của bạn ghi các loại thiết bị mở rộng, hãy đặt chúng sau FEATURE_EXTENTED_DEVICE_TYPES để tránh TYPE_UNKNOWN không mong muốn trên những thiết bị không có tính năng này.