Flutter Layouts - Part 1
data:image/s3,"s3://crabby-images/3cc74/3cc744f73b4c40c09bfc60ee87ed624ff9d7c434" alt="Flutter Layouts - Part 1"
Understanding Column and Row layouts: MainAxisSize, MainAxisAlignment and CrossAxisAlignment
In Flutter, the layout of widgets in a Row or Column is crucial for creating well-structured user interface. To achieve this, you need to understand the concepts of MainAxisSize, MainAxisAlignment, and CrossAxisAlignment.
- mainAxisSize.
According to the Flutter Documentation, the MainAxisSize is a property that allows us to determine how much space a Row or a Column can occupy on their main axes.
The row's main axis is the horizontal axis while the column's main axis is the vertical axis.
The 2 possible set of values that mainAxisSize allows are:
- MainAxisSize.min
With this setting, the children of the row or the column will be squeezed together, occupying enough space on their main axes.
Representation:
data:image/s3,"s3://crabby-images/bca0b/bca0b6b8d038ef76ebd4822ff8fe5357762bfdc2" alt=""
- MainAxisSize.max
When MainAxisSize is set to max, the children of the Row or Column will distribute space along their main axes, allowing them to fully utilize the available space.
data:image/s3,"s3://crabby-images/3d535/3d53501bb87ef22a54c6c665a2da9a7b87331a6e" alt=""
- mainAxisAlignment
The MainAxisAlignment determines how the row and the column positions their children on the available space after the mainAxisSize is set.
There are 6 possible properties for the MainAxisAlignment:
- mainAxisAlignment.start
This property aligns the children close to the start of the main axis.
Representation
data:image/s3,"s3://crabby-images/c19ba/c19badef524195354424616d616e75e4f6a89c52" alt=""
- mainAxisAlignment.end
This property aligns the children close to the end of the main axis.
Representation
data:image/s3,"s3://crabby-images/c3aed/c3aed4e917fd78f77dcb4f887f9f4f4d314309a0" alt=""
- mainAxisAlignment.center
This property aligns the children as close to the middle of the main axis.
Representation
data:image/s3,"s3://crabby-images/c4ca7/c4ca79141abf543c1770a20f1eb66fcf66336fda" alt=""
- mainAxisAlignment.spaceBetween
This property evenly spaces the children on their main axes.
Representation
data:image/s3,"s3://crabby-images/258e8/258e8d02f8b3a3464bcbc68c4e6cd22081324c84" alt=""
- mainAxisAlignment.spaceAround
This setting evenly spaces the children while reducing half of the space before and after the first and last widgets.
Representation
data:image/s3,"s3://crabby-images/3d024/3d0247f4a76d554b3842cabdeebf635f8e93601c" alt=""
- mainAxisAlignment.spaceEvenly
It divides the extra space evenly between the widgets and before and after the children.
Representation
data:image/s3,"s3://crabby-images/b09a1/b09a1180e2c0f9c2c3ad809d3efc3d4a80fa1d0a" alt=""
- crossAxisAlignment:
The crossAxisAlignment determines how the row and the column positions their children on their cross axes.
There are five possible values for CrossAxisAlignment:
- CrossAxisAlignment.start
This aligns the children at the start of the cross axis.
Representation
data:image/s3,"s3://crabby-images/b8f6d/b8f6da729fa3298858eabc9c148d96d07e0f0048" alt=""
- CrossAxisAlignment.end
It aligns the children at the end of the cross axis.
Representation
data:image/s3,"s3://crabby-images/13c39/13c3973b374ffbcab581488fbc687dd716721935" alt=""
- CrossAxisAlignment.center
This property centers the children along the cross axis.
Representation
data:image/s3,"s3://crabby-images/d2eaf/d2eafc1e05d6ade3b6cdd00b459410f1b01205fc" alt=""
- CrossAxisAlignment.stretch
It stretches the children across the cross axis. For example, in a Row, it stretches from top to bottom.
Representation
data:image/s3,"s3://crabby-images/e5800/e5800d5b2f2bdc7ce3c7255bb9ed047d76146ffb" alt=""
- CrossAxisAlignment.baseline
This property aligns characters according to their baselines, which is useful for text elements.
Wrapping Up
And that’s it guys! I hope you have a better understanding of Flutter layouts: MainAxisSize, MainAxisAlignment and CrossAxisAlignment!
About Me
I am Zaahra, a Google Women Techmakers Ambassador who enjoy mentoring people and writing about technical contents that might help people in their developer journey. I also enjoy building stuffs to solve real life problems.
To reach me:
LinkedIn: https://www.linkedin.com/in/faatimah-iz-zaahra-m-0670881a1/
X (previously Twitter): _fz3hra
GitHub: https://github.com/fz3hra
Cheers,
Umme Faatimah-Iz-Zaahra Mujore | Google Women TechMakers Ambassador | Software Engineer