data:image/s3,"s3://crabby-images/cc088/cc088feffdb58d6bfd1fd58b154009dfb184f723" alt="Row - 가로 정렬"
1. Row
- 가장 많이 사용하는 위젯 중 하나
- 위젯들을 가로로 배치시키고 싶을 때 사용
- Column 위젯과 형태가 흡사하지만 기준 축이 가로라는 것이 다름
data:image/s3,"s3://crabby-images/0a071/0a071fdcfaed37cb4679e4831f0c90a782dece25" alt="notion image"
ㅤ | 인라인 | 블락 | MainAxisAlignment | CrossAxisAlignment |
Colum | 가로 | 세로 | 세로 | 가로 |
Row | 세로 | 가로 | 가로 | 세로 |
2. MainAxisAlignment
MainAxisAlignment는 가로 축으로 자식 위젯들을 어떻게 배치할지를 결정합니다. MainAxisAlignment에는 6가지 타입이 있습니다. 각 타입별로 자식 위젯들이 어떻게 배치되는지 그림으로 표현해 뒀습니다.
Row( mainAxisAlignment: MainAxisAlignment.start, children: [ Container( width: 100, height: 100, color: Colors.red, ), Container( width: 100, height: 100, color: Colors.blue, ), Container( width: 100, height: 100, color: Colors.green, ), ], );
data:image/s3,"s3://crabby-images/79941/79941b426e66382322ffe97bef9250deb1009a10" alt="notion image"
data:image/s3,"s3://crabby-images/e152d/e152d9c1fb66821fc44fad09fd40d894d4187da2" alt="notion image"
data:image/s3,"s3://crabby-images/5e4b9/5e4b91ec716c2a36a12e4241ea6b2adce0195b22" alt="notion image"
data:image/s3,"s3://crabby-images/9db8f/9db8fb070a2b58df828e1311c1dea803a6a688cc" alt="notion image"
data:image/s3,"s3://crabby-images/b7ce9/b7ce9c59fd22a732ca650c0efc5684975a52603d" alt="notion image"
data:image/s3,"s3://crabby-images/97a40/97a408bb5ec960d549edf5cbd755eba0705791df" alt="notion image"
3. CrossAxisAlignment세로축을 의미
- 부모 위젯 내에서 세로축으로 위젯을 어떻게 배치할지를 결정
- stretch는 가능한 최대 영역까지 확장
- CrossAxisAlignment.baseline : textBaseline 특성 추가
Row위젯에 있는 Text 위젯들의 baseline을 맞출 수 있음
data:image/s3,"s3://crabby-images/0d039/0d03942995f7cfecab3e7972d08350ce112b0863" alt="notion image"
data:image/s3,"s3://crabby-images/7b98e/7b98e485d96ffc50dd1a287d5c8fae1d51d25996" alt="notion image"
data:image/s3,"s3://crabby-images/2857a/2857a08cc7477608879550455f25fef6345f7c36" alt="notion image"
data:image/s3,"s3://crabby-images/9e0b6/9e0b6260c87fe2d7de5d484054e492b612ce9249" alt="notion image"
data:image/s3,"s3://crabby-images/69bb6/69bb66b545e5829861a519c51d114e1b06442b46" alt="notion image"
Container( height: 300, color: Colors.grey.shade300, child: Row( crossAxisAlignment: CrossAxisAlignment.baseline, textBaseline: TextBaseline.alphabetic, children: const [ Text( "English", style: TextStyle(fontSize: 30), ), Text( " 123 ", style: TextStyle(fontSize: 20), ), Text( "한글", style: TextStyle(fontSize: 15), ), ], ), );
4. mainAxisSize : 가로축의 사이즈
- min : Row의 자식 위젯들의 사이즈만큼 Row위젯을 최소화
- max : Row의 부모 위젯 내에서 커질 수 있는 한 Row 위젯을 최대화
data:image/s3,"s3://crabby-images/72f2a/72f2a4f89da40098b21ba2b288677295eaaf8685" alt="notion image"
data:image/s3,"s3://crabby-images/5c292/5c292be620765a1f57d0401323fa5e96f20cf30b" alt="notion image"
Share article