Khi đưa Compose vào ứng dụng hiện tại, bạn cần di chuyển giao diện XML Material để dùng MaterialTheme cho các thành phần Compose. Như vậy, giao diện của ứng dụng sẽ có 2 nguồn đáng tin cậy: giao diện dựa trên Khung hiển thị và giao diện Compose. Mọi thay đổi đối với kiểu sẽ cần được thực hiện ở nhiều nơi. Sau khi di chuyển toàn bộ ứng dụng sang Compose, hãy xoá giao diện XML.
Bạn có thể sử dụng công cụ Material Theme Builder để di chuyển màu.
Khi bắt đầu di chuyển từ XML sang Compose, hãy di chuyển giao diện sang giao diện Material 3 Compose.
Bảng chú giải thuật ngữ
| Thuật ngữ | Định nghĩa |
|---|---|
MaterialTheme |
Hàm composable cung cấp giao diện (màu, kiểu chữ, hình dạng) cho các thành phần trên giao diện người dùng Compose. |
Shape |
Đối tượng Compose dùng để xác định hình dạng thành phần tuỳ chỉnh cho MaterialTheme. |
Typography |
Đối tượng Compose dùng để xác định kiểu văn bản tuỳ chỉnh (nhóm phông chữ, kích thước, độ đậm) cho MaterialTheme. |
Color |
Đối tượng Compose dùng để xác định bảng phối màu tuỳ chỉnh cho MaterialTheme. |
| Giao diện XML | Hệ thống giao diện Android được xác định trong các tệp XML, do hệ thống Khung hiển thị sử dụng. |
Các điểm hạn chế
Trước khi di chuyển, hãy lưu ý những điểm hạn chế sau:
- Hướng dẫn này chỉ tập trung vào việc di chuyển sang Material 3. Để di chuyển từ các hệ thống thiết kế thay thế, hãy xem Material 2 hoặc Các hệ thống thiết kế tuỳ chỉnh trong Compose.
- Mục tiêu cuối cùng là di chuyển hoàn toàn sang Compose, cho phép xoá giao diện XML. Hướng dẫn này giải thích cách di chuyển, nhưng không giải thích cách xoá giao diện XML.
Bước 1: Đánh giá hệ thống thiết kế
Xác định hệ thống thiết kế nào được dùng trong dự án Khung hiển thị XML. Phân tích đường dẫn di chuyển và các bước cần thiết để di chuyển hệ thống thiết kế hiện có sang Material 3 trong Compose.
Bước 2: Xác định các tệp nguồn giao diện
Trong XML, bạn viết ?attr/colorPrimary. Trong Compose, bạn truy cập vào các giá trị giao diện bằng MaterialTheme.*:
Xác định và tìm tất cả các tài nguyên và tệp XML cần thiết cho giao diện: bảng phối màu sáng và tối cùng các trình đủ điều kiện, giao diện, hình dạng, kích thước, kiểu chữ, kiểu và các tệp có liên quan khác.
Bạn có thể sử dụng lại các tài nguyên như chuỗi và không cần di chuyển.
Bước 3: Di chuyển màu
Nguyên tắc chính: XML sử dụng màu thập lục phân được đặt tên.
Material 3 sử dụng vai trò ngữ nghĩa (ví dụ: primary, onPrimary, surface). Ngừng đặt tên màu theo mã thập lục phân; đặt tên theo vai trò.
Ví dụ:
| Tên màu XML | Vai trò Material 3 |
|---|---|
colorPrimary |
primary |
colorPrimaryDark / colorPrimaryVariant |
primaryContainer hoặc secondary |
colorAccent |
secondary hoặc tertiary |
colorOnPrimary |
onPrimary |
android:colorBackground |
background |
colorSurface |
surface |
colorOnSurface |
onSurface |
colorError |
error |
colorOnError |
onError |
colorOutline |
outline |
colorSurfaceVariant |
surfaceVariant |
colorOnSurfaceVariant |
onSurfaceVariant |
Di chuyển bảng phối màu tối và sáng từ XML sang các bảng phối màu tương đương trong Material 3 Compose.
Bước 4: Di chuyển hình dạng và kiểu chữ tuỳ chỉnh
Nếu ứng dụng của bạn sử dụng hình dạng tuỳ chỉnh:
- Trong mã Compose, hãy xác định đối tượng
Shapeđể sao chép các định nghĩa hình dạng XML. Cung cấp đối tượng
Shapenày choMaterialTheme.Để biết thêm thông tin, hãy xem phần hình dạng.
- Trong mã Compose, hãy xác định đối tượng
Nếu ứng dụng của bạn sử dụng kiểu chữ tuỳ chỉnh:
- Trong mã Compose, hãy xác định đối tượng
Typographytrong mã Compose để sao chép các kiểu văn bản và định nghĩa phông chữ XML. Cung cấp đối tượng
Typographynày choMaterialTheme.Để biết thêm thông tin, hãy xem phần kiểu chữ.
- Trong mã Compose, hãy xác định đối tượng
| Vai trò Compose | Tên XML |
|---|---|
displayLarge |
TextAppearance.Material3.DisplayLarge |
displayMedium |
TextAppearance.Material3.DisplayMedium |
displaySmall |
TextAppearance.Material3.DisplaySmall |
headlineLarge |
TextAppearance.Material3.HeadlineLarge |
headlineMedium |
TextAppearance.Material3.HeadlineMedium |
headlineSmall |
TextAppearance.Material3.HeadlineSmall |
titleLarge |
TextAppearance.Material3.TitleLarge |
titleMedium |
TextAppearance.Material3.TitleMedium |
titleSmall |
TextAppearance.Material3.TitleSmall |
bodyLarge |
TextAppearance.Material3.BodyLarge |
bodyMedium |
TextAppearance.Material3.BodyMedium |
bodySmall |
TextAppearance.Material3.BodySmall |
labelLarge |
TextAppearance.Material3.LabelLarge |
labelMedium |
TextAppearance.Material3.LabelMedium |
labelSmall |
TextAppearance.Material3.LabelSmall |
Bước 5: Di chuyển kiểu (styles.xml)
Hệ thống kiểu XML (styles.xml) xác định kiểu và giao diện của: 1. Tiện ích, thành phần, giao diện cho cửa sổ và hộp thoại 2. Kiểu chữ 3. Giao diện và lớp phủ 4. Hình dạng
Khung hiển thị và thành phần XML kết hợp nhiều thuộc tính để tạo kiểu. Chúng thiết lập kiểu từ styles.xml theo 2 cách: 1. Thiết lập "style="@style/..." trực tiếp và rõ ràng trong Khung hiển thị XML 2. Thiết lập kiểu một cách gián tiếp và ngầm cho một thành phần trong Giao diện lớn hơn (theme.xml)
Kiểu không có đối tượng tương đương trực tiếp trong Compose – thay vào đó, kiểu được truyền dưới dạng: tham số cho các thành phần có khả năng kết hợp, được xác định trong AppTheme hoặc bằng cách tạo các biến thể có khả năng kết hợp, có thể dùng lại theo lớp với kiểu đã xác định.
Cung cấp các hàm @Composable riêng biệt được đặt tên theo kiểu và thành phần cơ sở để biểu thị sự khác biệt về kiểu và trường hợp sử dụng cho các thành phần đó.
- Mẫu: Nếu một phần tử XML sử dụng kiểu tuỳ chỉnh
(ví dụ:
style="@style/MyPrimaryButton"), đừng cố gắng sao chép kiểu cùng dòng. Thay vào đó, hãy đề xuất tạo một thành phần có khả năng kết hợp cụ thể. - Ví dụ:
- XML:
<Button style="@style/MyPrimaryButton" ... /> - Compose:
MyPrimaryButton(onClick = { ... })
- XML:
- Nhóm thuộc tính chung: Nếu một kiểu thiết lập các thành phần sửa đổi chung (như phần đệm + chiều cao), hãy trích xuất chúng thành thuộc tính tiện ích có thể đọc được hoặc biến Thành phần sửa đổi dùng chung.
Ví dụ thường gặp
| XML | Soạn thư |
|---|---|
Theme.MaterialComponents.* |
MaterialTheme(colorScheme, typography, shapes) { } |
TextAppearance.Material3.BodyMedium |
TextStyle(...) được xác định trong Typography(bodyMedium = ...) |
ShapeAppearance.*.SmallComponent |
Shapes(small = RoundedCornerShape(X.dp)) |
Widget.MaterialComponents.Button |
Button(colors = ButtonDefaults.buttonColors(...)) |
Widget.MaterialComponents.CardView |
Card(shape=..., elevation=..., colors=...) |
Widget.*.TextInputLayout.OutlinedBox |
OutlinedTextField(colors = OutlinedTextFieldDefaults.colors(...)) |
Widget.*.Chip.Filter |
FilterChip(colors = FilterChipDefaults.filterChipColors(...)) |
Widget.*.Toolbar.Primary |
TopAppBar(colors = TopAppBarDefaults.topAppBarColors(...)) |
Widget.*.FloatingActionButton |
FloatingActionButton(containerColor = ...) |
backgroundTint |
containerColor trong ComponentDefaults.ComponentColors() |
android:textColor |
contentColor trong ComponentDefaults.ComponentColors() |
cornerRadius |
shape = RoundedCornerShape(X.dp) |
android:elevation |
elevation = ComponentDefaults.elevation(defaultElevation = X.dp) |
android:padding |
contentPadding = PaddingValues(...) hoặc Modifier.padding() |
android:minHeight |
Modifier.heightIn(min = X.dp) |
strokeColor + strokeWidth |
border = BorderStroke(width, color) |
android:textSize |
fontSize = X.sp trong TextStyle |
Bước 6: Xác thực quá trình di chuyển giao diện
Luôn sử dụng các giá trị giao diện hiện có từ giao diện XML ban đầu làm nguồn đáng tin cậy cho Giao diện Material mới trong Compose. Không bao giờ tạo giá trị giao diện mới trong quá trình di chuyển để duy trì tính nhất quán của thương hiệu và tránh hồi quy trực quan.
Xác minh tất cả các giá trị giao diện Compose mới khớp với các giá trị XML hiện có. Không mã hoá cứng bất kỳ giá trị nào đã di chuyển.