The basics for controlling how elements are showing in Compose consists in the use of Row and Column. Here is the main idea of both:
- Row will show the elements in a single row from left to right.
- Column will show the elements in a single column from top to bottom.
Lets see the common cases. We will use this composable for the examples:
@Composable
fun Element(text: String) {
Column(modifier = Modifier.background(MaterialTheme.colorScheme.primary)
.border(border = BorderStroke(2.dp, MaterialTheme.colorScheme.onPrimary))
.width(50.dp)
.height(50.dp),
verticalArrangement = Arrangement.Center,
horizontalAlignment = Alignment.CenterHorizontally) {
Text(
text = text,
color = MaterialTheme.colorScheme.onPrimary,
fontWeight = FontWeight.Bold
)
}
}
One row x Nth elements
data:image/s3,"s3://crabby-images/856ba/856baad3cf7eb0ea3b7413f5d136f2db8c95214a" alt=""
Row() {
Element(text = "1")
Element(text = "2")
Element(text = ".")
Element(text = ".")
Element(text = "N")
}
One column x Nth elements
data:image/s3,"s3://crabby-images/12814/1281468a6fc7ad76fc3628534d37451071764e12" alt=""
Column() {
Element(text = "1")
Element(text = "2")
Element(text = ".")
Element(text = ".")
Element(text = "N")
}
Nth Elements x Nth Elements
data:image/s3,"s3://crabby-images/6f27c/6f27c47d88ab1691ac040b879475b2eb3f8a3de8" alt=""
Column() {
Row() {
Element(text = "1")
Element(text = "2")
Element(text = "3")
}
Row() {
Element(text = "1")
Element(text = "2")
Element(text = "3")
}
Row() {
Element(text = "1")
Element(text = "2")
Element(text = "3")
}
}
Nth Elements in a Column Centered
Vertically
data:image/s3,"s3://crabby-images/ea80c/ea80ced54fc5db49b84ec0caa1623c4cd66aa44e" alt=""
Horizontally
data:image/s3,"s3://crabby-images/744f1/744f1923a1aec3300d36db8f284ae451cb9bb02f" alt=""
Full centered
Column(
modifier = Modifier.fillMaxSize(),
verticalArrangement = Arrangement.Center,
horizontalAlignment = Alignment.CenterHorizontally
) {
Element(text = "1")
Element(text = "2")
Element(text = ".")
Element(text = "N")
}
Nth Elements in a Row Centered
data:image/s3,"s3://crabby-images/42f69/42f69538f8b4ba09a41718054e4e206a0ea613fa" alt=""
Vertically
data:image/s3,"s3://crabby-images/182c2/182c297631b92b93b46b8361ba62b5ca709d4cf7" alt=""
Horizontally
data:image/s3,"s3://crabby-images/066dc/066dc8e7c4ce4402ce3849047e97a56a571113b9" alt=""
Full centered
Row(
modifier = Modifier.fillMaxSize(),
horizontalArrangement = Arrangement.Center,
verticalAlignment = Alignment.CenterVertically
) {
Element(text = "1")
Element(text = "2")
Element(text = ".")
Element(text = "N")
}
Other alignments in a Column (or Row)
data:image/s3,"s3://crabby-images/006d0/006d007a2bb4a290f027cc05703754ca01824e4d" alt=""
Start
data:image/s3,"s3://crabby-images/62e14/62e140f1aa3f1a624552d35e3429a5105094a2ae" alt=""
Center
data:image/s3,"s3://crabby-images/38461/3846137df27120626f8e6b2da727fc80d5ae13cd" alt=""
End
Column(
modifier = Modifier.fillMaxSize(),
// Uncomment the one you need
//horizontalAlignment = Alignment.Start,
//horizontalAlignment = Alignment.CenterHorizontally,
horizontalAlignment = Alignment.End,
) {
Element(text = "1")
Element(text = "2")
}
Other arragements in a Row (or Column)
data:image/s3,"s3://crabby-images/3e9e0/3e9e061074220d8c93068be6e4a016508719bcb6" alt=""
Space between
data:image/s3,"s3://crabby-images/930f7/930f73896b6c8849f976f7e37f752d66aaf67ae3" alt=""
Space around (space after and before are the same)
data:image/s3,"s3://crabby-images/4c36b/4c36b34a5350f5c21b0119bc45b0503918ae21f9" alt=""
Space evenly (all spaces are the same)
Row(
modifier = Modifier.fillMaxSize(),
// Uncomment the one that you needs
//horizontalArrangement = Arrangement.SpaceBetween,
//horizontalArrangement = Arrangement.SpaceAround,
horizontalArrangement = Arrangement.SpaceEvenly,
) {
Element(text = "1")
Element(text = "2")
}
Nested rows in columns
data:image/s3,"s3://crabby-images/e9d27/e9d27308a94e7a1e9fbc8c2d7003d428df6a352a" alt=""
Column() {
Column {
Element("C1")
Element("C2")
}
Row() {
Element("R1")
Element("R2")
Element("R3")
}
Row() {
Element("R1")
Element("R2")
Element("R3")
}
Column {
Element("C1")
Element("C2")
Element("C3")
}
}
Nested columns in rows
data:image/s3,"s3://crabby-images/d5b0d/d5b0d06cb53e0055ce0cb0c03b7d71a514519c0f" alt=""
Row() {
Row {
Element("R1")
Element("R2")
}
Column() {
Element("C1")
Element("C2")
Element("C3")
}
Column() {
Element("C1")
Element("C2")
Element("C3")
}
Row {
Element("R1")
Element("R2")
}
}
Modifiers Width and Height
You can set height and width with this methods of the Modifier class:
- To set fixed height use Modifier.height method
- To set fixed width use Modifier.width method
- To set max width use Modifier.fillMaxWidth
- To set max height use Modifier.fillMaxHeight
- To set max width and height use Modifier.fillMaxSize
- To set the width/height size relative to parent use Modifier.fillMaxWidth/Modifier.fillMaxHeight using the fraction parameter.
Lets see some examples
Rows width
data:image/s3,"s3://crabby-images/45d91/45d91d50dc55ebc5cdf1e7578ec705a3865b450d" alt=""
Column() {
Row(modifier = Modifier.fillMaxWidth()) {
ElementFillSize(text = "Max width")
}
Row(modifier = Modifier.width(200.dp)) {
ElementFillSize(text = "200dp")
}
Row(modifier = Modifier.fillMaxWidth(0.5f)) {
ElementFillSize(text = "50%")
}
}
Columns Height
data:image/s3,"s3://crabby-images/bc384/bc3843c4815f0181f5d324e289b77d9d18464758" alt=""
Row() {
Column(modifier = Modifier.fillMaxHeight()) {
ElementFillSize(text = "Max width")
}
Column(modifier = Modifier.height(200.dp)) {
ElementFillSize(text = "200dp")
}
Column(modifier = Modifier.fillMaxHeight(0.5f)) {
ElementFillSize(text = "50%")
}
}