Sử dụng Modifier.flex để kiểm soát cách một mục thay đổi kích thước, thứ tự và được căn chỉnh bên trong FlexBox.
Kích thước mục
Sử dụng các hàm basis, grow và shrink để kiểm soát kích thước của một mục.
FlexBox { RedRoundedBox( modifier = Modifier.flex { basis(FlexBasis.Auto) grow(1.0f) shrink(0.5f) } ) }
Đặt kích thước ban đầu
Sử dụng basis để chỉ định kích thước ban đầu của mục trước khi phân bổ thêm không gian. Bạn có thể coi đây là kích thước ưu tiên của mục.
Loại giá trị |
Hành vi |
Đoạn mã Lưu ý: Các hộp có kích thước nội tại tối đa là |
Ví dụ sử dụng chiều rộng vùng chứa |
(mặc định) |
Sử dụng kích thước nội tại tối đa của mục. Ví dụ: chiều rộng nội tại tối đa của thành phần kết hợp |
FlexBox { RedRoundedBox( Modifier.flex { basis(FlexBasis.Auto) } ) BlueRoundedBox( Modifier.flex { basis(FlexBasis.Auto) } ) } |
|
|
Kích thước cố định tính bằng Dp. |
FlexBox { RedRoundedBox( Modifier.flex { basis(200.dp) } ) BlueRoundedBox( Modifier.flex { basis(100.dp) } ) } |
|
Tỷ lệ phần trăm |
Tỷ lệ phần trăm kích thước vùng chứa. |
FlexBox { RedRoundedBox( Modifier.flex { basis(0.7f) } ) BlueRoundedBox( Modifier.flex { basis(0.3f) } ) } |
|
Nếu giá trị cơ sở nhỏ hơn kích thước tối thiểu nội tại của mục, thì kích thước tối thiểu nội tại sẽ được sử dụng. Ví dụ: nếu một mục Text chứa một từ yêu cầu 50dp để hiển thị, nhưng cũng có basis = 10.dp, thì giá trị 50dp sẽ được sử dụng.
Mở rộng các mục khi có không gian
Sử dụng grow để chỉ định mức độ mở rộng của một mục khi có thêm không gian. Đây là không gian còn lại trong vùng chứa FlexBox sau khi cộng tất cả các giá trị basis của các mục. Giá trị grow cho biết mức độ không gian bổ sung mà một thành phần con nhất định sẽ nhận được, so với các thành phần cùng cấp. Theo mặc định, các mục sẽ không mở rộng.
Ví dụ sau đây cho thấy một FlexBox có 3 mục con. Mỗi mục có giá trị cơ sở là 100dp. Thành phần con đầu tiên có giá trị grow dương. Vì chỉ có một thành phần con có giá trị grow, nên giá trị thực tế không liên quan – miễn là giá trị đó là dương, thành phần con sẽ nhận được tất cả không gian bổ sung.
Hình ảnh cho thấy hành vi FlexBox khi kích thước vùng chứa là 600dp.
FlexBox { RedRoundedBox( title = "400dp", modifier = Modifier.flex { grow(1f) } ) BlueRoundedBox(title = "100dp") GreenRoundedBox(title = "100dp") } |
Mỗi thành phần con có giá trị cơ sở là
Thành phần con 1 mở rộng thêm
|
Trong ví dụ sau đây, kích thước vùng chứa và kích thước basis là giống nhau. Điểm khác biệt là mỗi thành phần con có một giá trị grow khác nhau.
FlexBox { RedRoundedBox( title = "150dp", modifier = Modifier.flex { grow(1f) } ) BlueRoundedBox( title = "200dp", modifier = Modifier.flex { grow(2f) } ) GreenRoundedBox( title = "250dp", modifier = Modifier.flex { grow(3f) } ) } |
Mỗi thành phần con có giá trị cơ sở là
Tổng giá trị grow là 6. Thành phần con 1 mở rộng thêm (1 / 6) * 300 = Thành phần con 2 mở rộng thêm (2 / 6) * 300 = Thành phần con 3 mở rộng thêm (3 / 6) * 300 =
|
Thu hẹp các mục khi không có đủ không gian
Sử dụng shrink để chỉ định mức độ thu hẹp của một mục khi vùng chứa FlexBox không có đủ không gian cho tất cả các mục. shrink hoạt động giống như grow, ngoại trừ việc thay vì phân bổ không gian bổ sung cho các mục, thì thiếu hụt không gian sẽ được phân bổ cho các mục. Giá trị shrink chỉ định mức độ thiếu hụt không gian mà mục nhận được, hay nói cách khác là mức độ thu hẹp của mục. Theo mặc định, các mục có giá trị shrink là 1f, nghĩa là chúng thu hẹp bằng nhau.
Ví dụ sau đây cho thấy 2 thành phần kết hợp Text có cùng văn bản. Thành phần con đầu tiên có giá trị shrink là 1f, nghĩa là thành phần này thu hẹp để hấp thụ tất cả sự thiếu hụt không gian.
FlexBox { Text( "The quick brown fox", fontSize = 36.sp, modifier = Modifier .background(PastelRed) .flex { shrink(1f) } ) Text( "The quick brown fox", fontSize = 36.sp, modifier = Modifier .background(PastelBlue) .flex { shrink(0f) } ) }
Khi kích thước vùng chứa thu hẹp, Thành phần con 1 sẽ thu hẹp.
Kích thước vùng chứa |
Giao diện người dùng FlexBox |
|
|
|
|
|
|
Căn chỉnh mục
Sử dụng alignSelf để kiểm soát cách một mục được căn chỉnh theo trục ngang. Điều này
sẽ ghi đè thuộc tính alignItemscủa vùng chứa cho mục này. Thuộc tính này có tất cả các giá trị có thể giống nhau, cùng với việc bổ sung Auto kế thừa hành vi của vùng chứa FlexBox.
Ví dụ: FlexBox này đặt alignItems thành Start và 5 thành phần con ghi đè việc căn chỉnh trục ngang.
FlexBox( config = { alignItems(FlexAlignItems.Start) } ) { RedRoundedBox() BlueRoundedBox(modifier = Modifier.flex { alignSelf(FlexAlignSelf.Center) }) GreenRoundedBox(modifier = Modifier.flex { alignSelf(FlexAlignSelf.End) }) PinkRoundedBox(modifier = Modifier.flex { alignSelf(FlexAlignSelf.Stretch) }) OrangeRoundedBox(modifier = Modifier.flex { alignSelf(FlexAlignSelf.Baseline) }) }

Thứ tự mục
Theo mặc định, FlexBox bố trí các mục theo thứ tự khai báo trong mã. Ghi đè hành vi này bằng cách sử dụng order.
Giá trị mặc định của order là 0 và FlexBox sắp xếp các mục dựa trên giá trị này theo thứ tự tăng dần. Mọi mục có cùng giá trị order đều được bố trí theo đúng thứ tự khai báo. Sử dụng giá trị order âm và dương để di chuyển các mục đến đầu hoặc cuối bố cục mà không thay đổi vị trí khai báo.
Ví dụ sau đây cho thấy 2 mục con. Mục đầu tiên có order mặc định là 0 và mục thứ hai có thứ tự là -1. Sau khi sắp xếp, Thành phần con 1 xuất hiện sau Thành phần con 2.
FlexBox { // Declared first, but will be placed after visually RedRoundedBox( title = "World" ) // Declared second, but will be placed first visually BlueRoundedBox( title = "Hello", modifier = Modifier.flex { order(-1) } ) }
