A floating action button (FAB) provides a quick and prominent way to trigger a primary action. While Jetpack Compose offers a standard FloatingActionButton
, in this blog, we’ll explore how to create an extended version of the FAB using built-in ExtendedFloatingActionButton
function.
Extended FABs are the most visually important button. It can have both icon and text at the same time or a single icon or single text as well. These can be more effective when an icon alone looks ambiguous.
Extended FABs have the same height as simple FABs. Let’s take examples:
Extended FAB
ExtendedFloatingActionButton
function takes many parameters but only two are compulsory: onClick
and content
.
ExtendedFloatingActionButton(onClick = { /*TODO*/ },) {
IconButton(onClick = { /*TODO*/ }) {
Icon(imageVector = Icons.Outlined.Edit,
contentDescription = null)
}
}
data:image/s3,"s3://crabby-images/4a65b/4a65b3507d8d4bfe2c7f1c5155d6c69c804c99f6" alt="image showing extended floating action button (FAB)"
ExtendedFloatingActionButton(onClick = { /*TODO*/ }) {
IconButton(onClick = { /*TODO*/ }) {
Icon(
imageVector = Icons.Outlined.Edit,
contentDescription = null
)
}
Text(text = "Compose")
}
data:image/s3,"s3://crabby-images/751c8/751c898ee1fbcf452806c8445708c39cd17772e1" alt="extended floating action button with text and icon"
ExtendedFloatingActionButton(onClick = { /*TODO*/ }) {
Text(text = "Compose")
}
data:image/s3,"s3://crabby-images/f955b/f955b2a16ae5ee1ab157e6489021062550a75d44" alt="extended floating action button with only text"
Customize Extended FAB
It has many parameters to style the extended FAB. Let’s see them one by one:
1. Shape
It defines the shape of FAB’s container
ExtendedFloatingActionButton(
onClick = { /*TODO*/ },
shape = CircleShape
){...}
ExtendedFloatingActionButton(
onClick = { /*TODO*/ },
shape = RectangleShape
){...}
data:image/s3,"s3://crabby-images/359ac/359ac58378a768d3f9096ea8e3776a407ca9605d" alt="circle shape extended FAB"
data:image/s3,"s3://crabby-images/da796/da796ee92d8d62e02d8547a47e665bcea27635f7" alt="rectangle shape extended FAB"
2. Container Color
This color is used for the background of the floating action button.
ExtendedFloatingActionButton(
onClick = { /*TODO*/ },
containerColor = Color.Yellow
)
data:image/s3,"s3://crabby-images/53876/5387632870fa2f39b09625599a115b87bfb2f82c" alt="extended fab with container color as yellow"
3. Content Color
This colour defines the color of the content inside the extended FAB.
ExtendedFloatingActionButton(
onClick = { /*TODO*/ },
containerColor = Color.Yellow,
contentColor = Color.Magenta
)
data:image/s3,"s3://crabby-images/dbf65/dbf65874fcb4c7ed8b407f0b5a5768fb3425b208" alt="image showing extended fab with content color as magenta and container color as yellow"
4. Elevation
It is used to resolve the elevation for this FAB in different states. This controls the size of the shadow below the FAB.
ExtendedFloatingActionButton(
onClick = { /*TODO*/ },
elevation = FloatingActionButtonDefaults.elevation(16.dp)
)
data:image/s3,"s3://crabby-images/751c8/751c898ee1fbcf452806c8445708c39cd17772e1" alt="extended fab with text and icon"
data:image/s3,"s3://crabby-images/0ec19/0ec192751aecb6af56e447b1ac0d2c4f13b17cd3" alt="extended fab with an elevation of 16 dp"
data:image/s3,"s3://crabby-images/8bd54/8bd547f71f1d65fa27c3428ad9e1d0a747542001" alt="extended fab with an elevation of 64 dp"
Note: There are two ExtendedFloatingActionButton
function in the jetpack compose. You can see both functions on the Android developer website. Links are given below:
- Link for the function that we have discussed above
- Link for the function that we are going to discuss below
Let’s take an example of extended FAB with our second function:
It has three compulsory parameters:
- text – It is of type composable that describes FAB with text.
- icon – This is of type composable as well and gives an icon to FAB.
- onClick -This parameter is a lambda that triggers when extended FAB is clicked.
ExtendedFloatingActionButton(
text = { Text(text = "Compose") },
icon = {
Icon(
imageVector = Icons.Outlined.Edit,
contentDescription = null
)
},
onClick = { /*TODO*/ }
)
data:image/s3,"s3://crabby-images/bc756/bc75697d75f6bc0ecf6e88b163f9e93db4868db7" alt="extended floating action button"
The second ExtendedFloatingActionButton
function has a new parameter named expanded
of type boolean
and it also has a default value set to true
. This expanded
parameter controls the expansion state of extended FAB. In an expanded state, the FAB will show both the icon and text. In a collapsed state, the FAB will show only the icon.
Let’s take an example:
var myFABState by remember {
mutableStateOf(false)
}
ExtendedFloatingActionButton(
text = { Text(text = "Compose") },
icon = {
Icon(
imageVector = Icons.Outlined.Edit,
contentDescription = null
)
},
onClick = { myFABState = !myFABState },
expanded = myFABState
)
data:image/s3,"s3://crabby-images/25871/258714b2df8d34a36f78977fc03ca3f68f5cf3c8" alt="gif showing animated extended floating action button"
In the example above, firstly, we create a variable named myFABState
of type boolean
and set its value to false
. Then we set this variable as a value to the expanded
parameter of ExtendedFloatingActionButton
and in the onClick
lambda we reverse the value of myFABState
so that when the user clicks the button it changes the value of myFABState
to the opposite of itself. (If it is true then the value will be false or vice-versa.)
Some Useful links
Happy Coding 🙂