Thu thập và xử lý dữ liệu sức khoẻ bằng Thư viện thu thập dữ liệu có cấu trúc

1. Trước khi bắt đầu

Sản phẩm bạn sẽ tạo ra

Trong lớp học lập trình này, bạn sẽ tìm hiểu cách tạo một ứng dụng Android bằng Thư viện thu thập dữ liệu có cấu trúc. Ứng dụng của bạn sẽ sử dụng Thư viện thu thập dữ liệu có cấu trúc để hiển thị và xử lý Bản câu hỏi FHIR cũng như các câu trả lời.

Kiến thức bạn sẽ học được

  • Cách tích hợp Thư viện thu thập dữ liệu có cấu trúc vào ứng dụng Android
  • Cách hiển thị Bảng câu hỏi
  • Cách nhận câu trả lời dưới dạng QuestionnaireResponse
  • Cách trích xuất tài nguyên FHIR từ QuestionnaireResponse

Bạn cần có

Lớp học lập trình này tập trung vào Thư viện thu thập dữ liệu có cấu trúc. Các khái niệm và khối mã không liên quan được tinh chỉnh và cung cấp cho bạn, chỉ cần sao chép và dán. Nếu chưa từng tạo ứng dụng Android, bạn có thể bắt đầu bằng cách tạo ứng dụng đầu tiên.

2. Bắt đầu thiết lập

Tải mã nguồn xuống

Để tải mã cho lớp học lập trình này, hãy sao chép kho lưu trữ SDK Android FHIR: git clone https://github.com/google/android-fhir.git

Dự án khởi động cho lớp học lập trình này nằm trong codelabs/datacapture.

Nhập ứng dụng vào Android Studio

Hãy bắt đầu bằng cách nhập ứng dụng khởi động vào Android Studio.

Mở Android Studio, chọn Import Project (Gradle, Eclipse ADT, etc.) (Nhập dự án (Gradle, Eclipse ADT, v.v.)) rồi chọn thư mục codelabs/datacapture trong mã nguồn mà bạn đã tải xuống trước đó.

Màn hình khởi động Android Studio

Chạy ứng dụng khởi động

Giờ đây, khi đã nhập dự án vào Android Studio, bạn đã sẵn sàng chạy ứng dụng lần đầu tiên.

Kết nối thiết bị Android của bạn với máy chủ qua USB hoặc Khởi động trình mô phỏng Android Studio rồi nhấp vào biểu tượng Chạy (Nút Run (Chạy)) trong thanh công cụ Android Studio.

Ứng dụng Hello World

Như bạn có thể thấy, hiện tại chưa có nhiều nội dung ở đây. Vì vậy, hãy bắt đầu hiển thị một bản câu hỏi trong ứng dụng của bạn!

3. Thêm Thư viện thu thập dữ liệu có cấu trúc vào dự án

Thêm phần phụ thuộc cho Thư viện thu thập dữ liệu có cấu trúc

Các phần phụ thuộc Thư viện thu thập dữ liệu có cấu trúc cho phép bạn tích hợp Thư viện thu thập dữ liệu có cấu trúc vào ứng dụng. Hãy thêm các dòng sau vào cuối tệp app/build.gradle.kts của dự án:

dependencies {
    // ...

    implementation("com.google.android.fhir:data-capture:1.2.0")
    implementation("androidx.fragment:fragment-ktx:1.6.0")
}

Đồng bộ hoá dự án với các tệp Gradle

Để đảm bảo rằng ứng dụng của bạn có tất cả các phần phụ thuộc, bạn nên đồng bộ hoá dự án với các tệp gradle tại thời điểm này.

Chọn Sync Project with Gradle Files (Đồng bộ hoá dự án với tệp Gradle) (Nút đồng bộ hoá Gradle) trên thanh công cụ Android Studio. Bạn cũng có thể chạy lại ứng dụng để kiểm tra xem các phần phụ thuộc có hoạt động đúng cách hay không.

4. Hiển thị Bảng câu hỏi

Ở bước này, bạn sẽ thêm chức năng vào ứng dụng khởi động để hiển thị một bản câu hỏi trong FragmentContainerView.

Trong quá trình này, Android Studio sẽ nhắc bạn thêm các lệnh nhập cần thiết:

  • androidx.core.os.bundleOf
  • androidx.fragment.app.add
  • androidx.fragment.app.commit
  • android.util.Log
  • com.google.android.fhir.datacapture.QuestionnaireFragment

Bước 1: Thêm FragmentContainerView

Thêm FragmentContainerView vào bố cục của ứng dụng. Đây là nơi QuestionnaireFragment mà bạn sẽ tạo sau này sẽ hiển thị.

  1. Mở activity_main.xml (res > layout > activity_main.xml).
  2. Tìm các tuỳ chọn cho khung hiển thị Mã, Phân tách và Thiết kế ở phía trên bên phải của Layout Editor.
  3. Chọn chế độ xem Mã. Tuỳ chọn chế độ xem bố cục
  4. Bạn không cần đến TextView nữa nên có thể xoá thành phần hiển thị này. Hãy nhớ xoá toàn bộ nội dung từ thẻ mở <TextView đến hết thẻ đóng />.
  5. Thêm FragmentContainerView vào bên trong ConstraintLayout. Tệp activity_main.xml của bạn sẽ có dạng như sau:
    <?xml version="1.0" encoding="utf-8" ?>
    <androidx.constraintlayout.widget.ConstraintLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MainActivity"
    >
    
    <androidx.fragment.app.FragmentContainerView
        android:id="@+id/fragment_container_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_constraintTop_toTopOf="parent" />
    
    </androidx.constraintlayout.widget.ConstraintLayout>
    

Bước 2: Định cấu hình QuestionnaireFragment

QuestionnaireFragment yêu cầu một Bản câu hỏi FHIR được mã hoá bằng JSON để hiển thị. Vì bản câu hỏi có kích thước nhỏ (<512 KB), nên bạn sẽ đưa bản câu hỏi đó vào dưới dạng String trong Bundle của các đối số sẽ được dùng để tạo mảnh. Bạn nên cung cấp các bảng câu hỏi lớn hơn dưới dạng URI vì lý do hiệu suất.

Bạn có thể xem tệp questionnaire.json nếu muốn, nhưng một trong những lợi ích của Thư viện thu thập dữ liệu có cấu trúc là bạn không cần biết cấu trúc của Bản câu hỏi FHIR (hoặc bất kỳ thông tin nào về FHIR) để hiển thị bản câu hỏi đó! Bạn sẽ tìm hiểu kỹ hơn về tệp này ở phần sau của lớp học lập trình.

Tạo QuestionnaireFragment bằng trình tạo tương ứng và đặt bản khảo sát bằng hàm setter. Để hiển thị QuestionnaireFragment trong vùng chứa bố cục, hãy sử dụng FragmentManager để tạo FragmentTransaction.

Mở MainActivity.kt rồi thêm mã sau vào lớp MainActivity:

// Step 2: Configure a QuestionnaireFragment
questionnaireJsonString = getStringFromAssets("questionnaire.json")

val questionnaireFragment =
  QuestionnaireFragment.builder().setQuestionnaire(questionnaireJsonString!!).build()

Bước 3: Thêm QuestionnaireFragment vào FragmentContainerView

Để hiển thị QuestionnaireFragment trong vùng chứa bố cục, hãy sử dụng FragmentManager để tạo FragmentTransaction. FragmentManager xử lý việc tạo thực thể bằng questionnaireParams đã tạo trước đó.

Thêm mã sau vào lớp MainActivity:

// Step 3: Add the QuestionnaireFragment to the FragmentContainerView
if (savedInstanceState == null) {
  supportFragmentManager.commit {
    setReorderingAllowed(true)
    add(R.id.fragment_container_view, questionnaireFragment)
  }
}
// Submit button callback
supportFragmentManager.setFragmentResultListener(
  QuestionnaireFragment.SUBMIT_REQUEST_KEY,
  this,
) { _, _ ->
  submitQuestionnaire()
}

Tìm hiểu thêm về cách sử dụng mảnh.

Hãy chạy lớp học lập trình này bằng cách nhấp vào biểu tượng Chạy (Nút Run (Chạy)) trong thanh công cụ của Android Studio. Bạn sẽ thấy nội dung tương tự như sau:

Bảng câu hỏi được hiển thị trong trình mô phỏng

Xem qua bản câu hỏi và thử nhập một số câu trả lời. Có một số tiện ích câu trả lời khác nhau được sử dụng, bao gồm cả boolean, văn bản và ngày tháng. Các tiện ích này được tự động hiển thị dựa trên loại cơ bản trong bản câu hỏi FHIR ban đầu.

Về mặt kỹ thuật, đó là tất cả những gì bạn cần làm để hiển thị một bảng câu hỏi! Xin chúc mừng!

Bản câu hỏi sẽ không hữu ích nếu bạn không thể xem câu trả lời mà người dùng nhập. Hãy chuyển sang bước tiếp theo để nhận Phản hồi về bảng câu hỏi!

5. Nhận câu trả lời cho bảng câu hỏi

Ở các bước trước, bạn đã hiển thị một bảng câu hỏi FHIR trong ứng dụng.

Trong phần này, bạn sẽ nhận được câu trả lời từ bản câu hỏi dưới dạng QuestionnaireResponse.

Tìm phương thức submitQuestionnaire() rồi thêm mã sau:

// Get a questionnaire response
val fragment = supportFragmentManager.findFragmentById(R.id.fragment_container_view)
        as QuestionnaireFragment
val questionnaireResponse = fragment.getQuestionnaireResponse()

// Print the response to the log
val jsonParser = FhirContext.forCached(FhirVersionEnum.R4).newJsonParser()
val questionnaireResponseString =
    jsonParser.encodeResourceToString(questionnaireResponse)
Log.d("response", questionnaireResponseString)

Để nhận câu trả lời cho bảng câu hỏi, bạn truy xuất mảnh bảng câu hỏi đã tạo trước đó rồi sử dụng phương thức getQuestionnaireResponse(). Thao tác này sẽ trả về một QuestionnaireResponse HAPI FHIR mà bạn có thể sử dụng trực tiếp hoặc với các phần khác của SDK FHIR Android. Lớp học lập trình này sử dụng các thư viện HAPI FHIR khác để chuyển đổi thành chuỗi JSON để xem trong nhật ký.

Chạy lại ứng dụng để tạo lại ứng dụng bằng các thay đổi mới nhất. Sau khi ứng dụng chạy, hãy nhập một số thông tin vào bản khảo sát rồi nhấn vào Gửi. Trong nhật ký, bạn sẽ thấy một thông báo chứa QuestionnaireResponse dưới dạng JSON.

D/response: {"resourceType":"QuestionnaireResponse","item":[{"linkId":"PR","text":"Patient information","item":[{"linkId":"PR-name","text":"Name","item":[{"linkId":"PR-name-given","text":"First Name","answer":[{"valueString":"Dani"}]},{"linkId":"PR-name-family","text":"Family Name","answer":[{"valueString":"Lee"}]}]},{"linkId":"PR-birthdate","text":"Date of Birth","answer":[{"valueDate":"1990-02-14"}]},{"linkId":"PR-id","text":"Identifying information","item":[{"linkId":"PR-name-id-url"},{"linkId":"PR-name-id","text":"Patient Id","answer":[{"valueString":"12345"}]}]}]}]}

6. Trích xuất Tài nguyên FHIR từ một QuestionnaireResponse

Bản câu hỏi đi kèm với dự án khởi động là dành cho quy trình đăng ký bệnh nhân đơn giản. Do đó, cuối cùng, bạn có thể muốn sử dụng các câu trả lời trong bản câu hỏi để tạo tài nguyên Bệnh nhân FHIR dựa trên các câu trả lời đó. Quá trình chuyển đổi từ câu trả lời bảng câu hỏi sang tài nguyên FHIR được gọi là trích xuất dữ liệu. Chúng ta có thể thực hiện việc này bằng lớp ResourceMapper của Thư viện thu thập dữ liệu có cấu trúc.

Để trích xuất dữ liệu, bạn phải tạo bảng câu hỏi có thông tin về cách trích xuất dữ liệu. May mắn là bản câu hỏi mẫu đã được thiết lập để Trích xuất dựa trên định nghĩa.

Tìm phương thức submitQuestionnaire() rồi thêm mã sau:

lifecycleScope.launch {
  val questionnaire =
    jsonParser.parseResource(questionnaireJsonString) as Questionnaire
  val bundle = ResourceMapper.extract(questionnaire, questionnaireResponse)
  Log.d("extraction result", jsonParser.encodeResourceToString(bundle))
}

ResourceMapper.extract() yêu cầu một Bản câu hỏi HAPI FHIR. Bạn có thể tạo bản câu hỏi này bằng cách phân tích cú pháp chuỗi JSON của bản câu hỏi trước đó và QuestionnaireResponse mà chúng ta đã có trước đó. Phương thức này trả về một Gói giao dịch HAPI FHIR chứa một hoặc nhiều tài nguyên đã trích xuất – trong trường hợp này là một tài nguyên Bệnh nhân.

Chạy lại ứng dụng để tạo lại ứng dụng bằng các thay đổi mới nhất. Sau khi ứng dụng chạy, hãy nhập một số thông tin rồi nhấn vào Gửi. Trong nhật ký, bạn sẽ thấy thông báo extraction result chứa nội dung đại diện JSON của Gói FHIR đã trích xuất.

D/extraction result: {"resourceType":"Bundle","type":"transaction","entry":[{"resource":{"resourceType":"Patient","identifier":[{"value":"12345"}],"name":[{"family":"Lee","given":["Dani"]}],"birthDate":"1990-02-14"}}]}

7. Xin chúc mừng!

Bạn đã sử dụng Thư viện thu thập dữ liệu có cấu trúc để xử lý các câu trả lời và câu hỏi của FHIR trong ứng dụng:

  • Hiển thị Bảng câu hỏi
  • Nhận câu trả lời cho bảng câu hỏi
  • Trích xuất Tài nguyên FHIR từ QuestionnaireResponse

Đó là tất cả những gì bạn cần để thiết lập và chạy ứng dụng!

Khi tiếp tục, bạn có thể muốn làm việc với các tài nguyên FHIR theo nhiều cách hơn trong suốt ứng dụng. Hãy xem Thư viện công cụ FHIR của SDK Android FHIR để tìm hiểu cách lưu trữ và quản lý tài nguyên FHIR cục bộ trong ứng dụng của bạn, đồng thời đồng bộ hoá dữ liệu với máy chủ FHIR từ xa.

Nội dung đã đề cập

  • Cách thêm Thư viện thu thập dữ liệu có cấu trúc vào ứng dụng Android
  • Cách sử dụng QuestionnaireFragmentResourceMapper để xử lý các bảng câu hỏi FHIR

Các bước tiếp theo

  • Khám phá tài liệu về Thư viện thu thập dữ liệu có cấu trúc
  • Tuỳ chỉnh giao diện của bảng câu hỏi đã hiển thị
  • Áp dụng Thư viện thu thập dữ liệu có cấu trúc trong ứng dụng Android của riêng bạn

Tìm hiểu thêm