Search code examples
androidkotlinandroid-jetpack-composeandroid-jetpack-compose-layout

Create Vertical Divider Jetpack Compose


How to create vertical dividers with Jetpack Compose? I try to use Spacer and Box to do it, but it doesn't show up at all. Here is what i tried:

Box(
    modifier = Modifier
        .fillMaxHeight()
        .width(2.dp)
        .background(color = Color.Black)
)

But that doesn't work at all. So how to do vertical divider in Jetpack Compose?


Solution

  • You can use the Divider composable with the width(xx.dp) modifier applying an intrinsic measurements to its parent container.

    Something like:

    Row(Modifier
        .height(IntrinsicSize.Min) //intrinsic measurements
        .fillMaxWidth()
        .background(Color.Yellow)
    ) {
            Text("First Text")
    
            Divider(
                color = Color.Red,
                modifier = Modifier
                    .fillMaxHeight()  //fill the max height
                    .width(1.dp)
            )
    
            Text("Second text")
    }
    

    enter image description here

    As explained in the doc:

    The Row composable's minIntrinsicHeight will be the maximum minIntrinsicHeight of its children. The Divider element's minIntrinsicHeight is 0 as it doesn't occupy space if no constraints are given; the TextField minIntrinsicHeight will be that of the content given a specific width. Therefore, the Row element's height constraint will be the max minIntrinsicHeight of the TextFields content. The Divider will then expand its height to the height constraint given by the Row.