Thành phần kết hợp được xác định bởi một hàm và được chú thích bằng @Composable
:
@Composable fun SimpleComposable() { Text("Hello World") }
Để bật bản xem trước của thành phần kết hợp này, hãy tạo một thành phần kết hợp khác, có chú thích
cùng với @Composable
và @Preview
. Thành phần kết hợp mới, được chú thích này hiện chứa
thành phần kết hợp mà bạn tạo ban đầu, SimpleComposable
:
@Preview @Composable fun SimpleComposablePreview() { SimpleComposable() }
Chú giải @Preview
cho Android Studio biết rằng
thành phần kết hợp sẽ được hiển thị trong khung hiển thị thiết kế của tệp này. Bạn có thể xem trực tiếp
bản cập nhật cho bản xem trước thành phần kết hợp khi bạn chỉnh sửa.
Bạn có thể thêm tham số vào mã theo cách thủ công để tuỳ chỉnh cách Android Studio kết xuất @Preview
. Bạn thậm chí có thể thêm chú thích @Preview
vào cùng một
hàm nhiều lần để xem trước một thành phần kết hợp với các thuộc tính khác nhau.
Một trong những lợi ích chính khi sử dụng thành phần kết hợp @Preview
là tránh sự phụ thuộc
trên trình mô phỏng trong Android Studio. Bạn có thể lưu quá trình khởi động tốn bộ nhớ của
trình mô phỏng để có thêm nhiều thay đổi về giao diện và cảm nhận cũng như khả năng của @Preview
và dễ dàng kiểm thử các thay đổi nhỏ về mã.
Để tận dụng chú giải @Preview
hiệu quả nhất, hãy nhớ xác định
màn hình theo trạng thái mà nó nhận được dưới dạng đầu vào và các sự kiện mà nó nhận được dưới dạng đầu vào.
đầu ra.
Xác định @Preview
của bạn
Android Studio cung cấp một số tính năng để mở rộng bản xem trước thành phần kết hợp. Bạn có thể thay đổi thiết kế vùng chứa, tương tác với chúng hoặc triển khai trực tiếp ở một trình mô phỏng hoặc thiết bị.
Kích thước
Theo mặc định, các kích thước @Preview
tự động được chọn để bao phủ nội dung tương ứng.
Để đặt phương diện theo cách thủ công, hãy thêm thông số heightDp
và widthDp
. Những
các giá trị đã được hiểu là dp
, nên bạn không cần thêm .dp
cho họ:
@Preview(widthDp = 50, heightDp = 50) @Composable fun SquareComposablePreview() { Box(Modifier.background(Color.Yellow)) { Text("Hello World") } }
Bản xem trước màu động
Nếu bạn đã bật tính năng động
màu trong ứng dụng của bạn,
dùng thuộc tính wallpaper
để chuyển đổi hình nền và xem giao diện người dùng phản ứng như thế nào với
của những người dùng khác nhau đã chọn hình nền. Chọn trong số nhiều giao diện hình nền
do
Wallpaper
. Tính năng này yêu cầu phiên bản Compose 1.4.0 trở lên.
Sử dụng với các thiết bị khác
Trong Android Studio Flamingo, bạn có thể chỉnh sửa tham số device
của Bản xem trước
để xác định cấu hình cho các thành phần kết hợp trên các thiết bị khác nhau.
Khi thông số thiết bị có một chuỗi trống (@Preview(device = "")
), bạn có thể
gọi tính năng tự động hoàn thành bằng cách nhấn Ctrl
+ Space
. Sau đó, bạn có thể đặt các giá trị
của từng thông số.
Từ tính năng tự động hoàn thành, bạn có thể chọn bất kỳ tuỳ chọn thiết bị nào trong danh sách – ví dụ:
@Preview(device = "id:pixel_4")
. Ngoài ra, bạn có thể nhập
một thiết bị tuỳ chỉnh
bằng cách chọn spec:width=px,height=px,dpi=int…
để đặt các giá trị riêng lẻ của
từng thông số.
Để áp dụng, hãy nhấn phím Enter
hoặc huỷ bằng Esc
.
Nếu bạn đặt một giá trị không hợp lệ, nội dung khai báo sẽ được gạch chân màu đỏ và bạn có thể khắc phục
be available (Alt
+ Enter
(⌥ + ⏎ for macOS) > Thay thế bằng .... Các
Quy trình kiểm tra sẽ cố gắng đưa ra cách khắc phục gần giống với thông tin mà bạn nhập nhất.
Ngôn ngữ
Để kiểm thử nhiều ngôn ngữ của người dùng, hãy thêm tham số locale
:
@Preview(locale = "fr-rFR") @Composable fun DifferentLocaleComposablePreview() { Text(text = stringResource(R.string.greeting)) }
Đặt màu nền
Theo mặc định, thành phần kết hợp sẽ xuất hiện với nền trong suốt. Để thêm một
nền, hãy thêm các tham số showBackground
và backgroundColor
. Giữ lại
xin lưu ý rằng backgroundColor
là một ARGB Long
, không phải là một Color
giá trị:
@Preview(showBackground = true, backgroundColor = 0xFF00FF00) @Composable fun WithGreenBackground() { Text("Hello World") }
Giao diện người dùng hệ thống
Nếu bạn cần hiện các thanh trạng thái và hành động bên trong bản xem trước, hãy thêm tham số showSystemUi
:
@Preview(showSystemUi = true) @Composable fun DecoratedComposablePreview() { Text("Hello World") }
Chế độ giao diện người dùng
Tham số uiMode
có thể lấy bất kỳ Configuration.UI_*
nào
hằng số và cho phép bạn thay đổi hành vi của bản xem trước cho phù hợp. Ví dụ: bạn có thể đặt bản xem trước thành Chế độ đêm (Night Mode) để xem giao diện sẽ phản ứng như thế nào.
LocalInspectionMode
Bạn có thể đọc từ LocalInspectionMode
CompositionLocal
để xem thành phần kết hợp có được hiển thị trong bản xem trước hay không (bên trong
thành phần có thể kiểm tra). Nếu cấu trúc được hiển thị
trong bản xem trước, LocalInspectionMode.current
cho kết quả là true
. Chiến dịch này
cho phép bạn tuỳ chỉnh bản xem trước; Ví dụ: bạn có thể hiển thị một
hình ảnh phần giữ chỗ trong cửa sổ xem trước thay vì hiển thị dữ liệu thực.
Bằng cách này, bạn cũng có thể khắc phục các hạn chế. Để ví dụ: hiển thị dữ liệu mẫu thay vì gọi yêu cầu mạng.
@Composable fun GreetingScreen(name: String) { if (LocalInspectionMode.current) { // Show this text in a preview window: Text("Hello preview user!") } else { // Show this text in the app: Text("Hello $name!") } }
Tương tác với @Preview
Android Studio cung cấp các tính năng cho phép bạn tương tác với bản xem trước. Hoạt động tương tác này giúp bạn hiểu rõ về bản xem trước hành vi trong thời gian chạy và cho phép bạn điều hướng tốt hơn giao diện người dùng nhờ các bản xem trước.
Chế độ tương tác
Chế độ tương tác cho phép bạn tương tác với bản xem trước tương tự như cách bạn sẽ làm trên thiết bị chạy chương trình của bạn, chẳng hạn như điện thoại hoặc máy tính bảng. Chế độ tương tác tách biệt trong môi trường hộp cát (có nghĩa là tách biệt với các bản xem trước khác), nơi bạn có thể nhấp vào các phần tử và nhập hoạt động đầu vào của người dùng vào bản xem trước. Đó là một cách nhanh chóng để kiểm thử các trạng thái, cử chỉ và thậm chí cả ảnh động của thành phần kết hợp.
Thao tác đối với mã và bản phác thảo thành phần kết hợp
Bạn có thể di chuột qua bản xem trước để xem bản phác thảo của các thành phần kết hợp có trong đó. Khi bạn nhấp vào một bố cục có thể kết hợp, chế độ trình chỉnh sửa của bạn sẽ chuyển đến phần định nghĩa tương ứng.
Chạy bản xem trước
Bạn có thể chạy một @Preview
cụ thể trên trình mô phỏng hoặc thiết bị thực. Chiến lược phát hành đĩa đơn
bản xem trước được triển khai trong cùng một ứng dụng dự án như Activity
mới, vì vậy
có cùng bối cảnh và quyền truy cập. Không yêu cầu bạn phải viết
mã nguyên mẫu yêu cầu quyền nếu đã được cấp quyền.
Nhấp vào biểu tượng Chạy bản xem trước
bên cạnh chú thích @Preview
hoặc ở đầu bản xem trước và Android
Studio sẽ triển khai @Preview
đó trên trình mô phỏng hoặc thiết bị đã kết nối.
Sao chép kết xuất @Preview
Mọi bản xem trước được kết xuất có thể được sao chép dưới dạng hình ảnh bằng cách nhấp chuột phải vào hình ảnh đó.
Nhiều bản xem trước của cùng một chú thích @Preview
Bạn có thể giới thiệu nhiều phiên bản của cùng một thành phần kết hợp @Preview
với
các thông số kỹ thuật khác nhau hoặc các tham số khác nhau được truyền đến thành phần kết hợp. Chiến dịch này
bạn có thể giảm bớt mã nguyên mẫu mà bạn cần phải viết nếu không có.
Mẫu Multipreview
androidx.compose.ui:ui-tooling-preview
1.6.0-alpha01+ ra mắt chế độ Nhiều bản xem trước
Các mẫu API: @PreviewScreenSizes
, @PreviewFontScales
, @PreviewLightDark
,
và @PreviewDynamicColors
, để với một chú thích, bạn có thể
xem trước giao diện người dùng Compose của bạn trong các trường hợp phổ biến.
Tạo chú thích multipreview tuỳ chỉnh
Với tính năng multipreview (xem trước nhiều lần), bạn có thể xác định một lớp chú thích mà bản thân có nhiều chú thích @Preview
với cấu hình khác nhau. Thêm chú thích này vào
một hàm có khả năng kết hợp sẽ tự động hiển thị tất cả bản xem trước khác nhau tại
một lần. Ví dụ: bạn có thể sử dụng chú thích này để xem trước nhiều thiết bị, kích thước phông chữ hoặc giao diện cùng một lúc mà không cần phải xác định lại mọi thành phần kết hợp.
Bắt đầu bằng cách tạo lớp chú thích tuỳ chỉnh của riêng bạn:
@Preview( name = "small font", group = "font scales", fontScale = 0.5f ) @Preview( name = "large font", group = "font scales", fontScale = 1.5f ) annotation class FontScalePreviews
Bạn có thể sử dụng chú thích tuỳ chỉnh này cho các tài liệu xem trước của mình:
@FontScalePreviews @Composable fun HelloWorldPreview() { Text("Hello World") }
Bạn có thể kết hợp nhiều chú thích nhiều bản xem trước và chú thích xem trước thông thường để tạo một bộ bản xem trước hoàn chỉnh hơn. Kết hợp các chú thích nhiều bản xem trước không có nghĩa là tất cả các tổ hợp khác nhau đều được hiển thị. Thay vào đó, mỗi chú thích nhiều bản xem trước hoạt động độc lập và chỉ hiển thị các biến thể riêng.
@Preview( name = "Spanish", group = "locale", locale = "es" ) @FontScalePreviews annotation class CombinedPreviews @CombinedPreviews @Composable fun HelloWorldPreview2() { MaterialTheme { Surface { Text(stringResource(R.string.hello_world)) } } }
Bản chất kết hợp của chế độ nhiều bản xem trước và bản xem trước thông thường!-- cho phép bạn thử nghiệm toàn diện nhiều thuộc tính của các dự án có quy mô lớn hơn.
@Preview
và các tập dữ liệu lớn
Thông thường, bạn sẽ gặp phải trường hợp phải truyền một tập dữ liệu lớn đến thành phần kết hợp
bản xem trước. Để thực hiện việc này, bạn chỉ cần truyền dữ liệu mẫu đến hàm Xem trước thành phần kết hợp bằng cách
thêm một thông số bằng @PreviewParameter
của bạn.
@Preview @Composable fun UserProfilePreview( @PreviewParameter(UserPreviewParameterProvider::class) user: User ) { UserProfile(user) }
Để cung cấp dữ liệu mẫu, hãy tạo một lớp triển khai
PreviewParameterProvider
rồi trả về
dữ liệu mẫu dưới dạng trình tự.
class UserPreviewParameterProvider : PreviewParameterProvider<User> { override val values = sequenceOf( User("Elise"), User("Frank"), User("Julia") ) }
Thao tác này sẽ hiển thị một bản xem trước cho mỗi phần tử dữ liệu trong trình tự:
Bạn có thể sử dụng cùng một lớp nhà cung cấp (provider class) cho nhiều bản xem trước. Nếu cần, hãy giới hạn số lượt xem trước bằng cách đặt tham số giới hạn.
@Preview @Composable fun UserProfilePreview2( @PreviewParameter(UserPreviewParameterProvider::class, limit = 2) user: User ) { UserProfile(user) }
Hạn chế và các phương pháp hay nhất
Android Studio trực tiếp thực thi mã xem trước trong vùng xem trước. Không
yêu cầu chạy trình mô phỏng hoặc thiết bị thực vì trình mô phỏng này sử dụng
của khung Android có tên là Layoutlib
. Layoutlib
là một tuỳ chỉnh
phiên bản khung Android được thiết kế để chạy bên ngoài thiết bị Android. Chiến lược phát hành đĩa đơn
mục tiêu của thư viện này là cung cấp bản xem trước bố cục trong Android Studio
rất giống với kết xuất hình ảnh trên thiết bị.
Giới hạn đối với bản xem trước
Do cách kết xuất bản xem trước trong Android Studio, các bản xem trước này gọn nhẹ và không yêu cầu toàn bộ khung Android kết xuất chúng. Tuy nhiên, việc này đi kèm với các hạn chế sau:
- Không có quyền truy cập mạng
- Không có quyền truy cập vào tệp
- Một số API
Context
có thể không dùng được đầy đủ
Bản xem trước và ViewModels
Bản xem trước bị giới hạn khi sử dụng ViewModel
trong một
thành phần kết hợp. Hệ thống xem trước không thể tạo tất cả
các tham số được truyền đến ViewModel
, chẳng hạn như kho lưu trữ, trường hợp sử dụng, trình quản lý
hoặc tương tự. Ngoài ra, nếu ViewModel
của bạn tham gia vào việc chèn phần phụ thuộc (chẳng hạn như
giống như với Hilt), hệ thống xem trước không thể tạo toàn bộ phần phụ thuộc
biểu đồ để tạo ViewModel
.
Khi bạn cố gắng xem trước một thành phần kết hợp bằng ViewModel
, Android Studio sẽ hiển thị một
khi kết xuất thành phần kết hợp cụ thể:
Nếu muốn xem trước một thành phần kết hợp sử dụng ViewModel
, bạn nên tạo
một thành phần kết hợp khác có các tham số từ ViewModel
được truyền dưới dạng đối số của
thành phần kết hợp. Theo đó, bạn không cần xem trước thành phần kết hợp sử dụng
ViewModel
.
@Composable
fun AuthorColumn(viewModel: AuthorViewModel = viewModel()) {
AuthorColumn(
name = viewModel.authorName,
// ViewModel sends the network requests and makes posts available as a state
posts = viewModel.posts
)
}
@Preview
@Composable
fun AuthorScreenPreview(
// You can use some sample data to preview your composable without the need to construct the ViewModel
name: String = sampleAuthor.name,
posts: List<Post> = samplePosts[sampleAuthor]
) {
AuthorColumn(...) {
name = NameLabel(name),
posts = PostsList(posts)
}
}
Lớp chú giải @Preview
Bạn luôn có thể "ctrl hoặc ⌘ + nhấp" chú thích @Preview
trong Android
Studio để xem danh sách đầy đủ các thông số có thể được điều chỉnh khi tuỳ chỉnh
bản xem trước.
annotation class Preview( val name: String = "", val group: String = "", @IntRange(from = 1) val apiLevel: Int = -1, val widthDp: Int = -1, val heightDp: Int = -1, val locale: String = "", @FloatRange(from = 0.01) val fontScale: Float = 1f, val showSystemUi: Boolean = false, val showBackground: Boolean = false, val backgroundColor: Long = 0, @UiMode val uiMode: Int = 0, @Device val device: String = Devices.DEFAULT, @Wallpaper val wallpaper: Int = Wallpapers.NONE, )
Tài nguyên khác
Để đọc thêm về cách Android Studio giúp @Preview
dễ sử dụng và tìm hiểu
các mẹo khác về công cụ, hãy xem blog Compose
Công cụ.
Đề xuất cho bạn
- Lưu ý: văn bản có đường liên kết sẽ hiện khi JavaScript tắt
- Dữ liệu trong phạm vi cục bộ với CompositionLocal
- Material Design 2 trong Compose
- Sử dụng Thành phần hiển thị trong Compose