1. Column 은 세로는 Block 가로는 Inline 속성
2. Row 는 가로는 Block 세로는 Inline 속성
어떤 디자인을 할 때 Column은 미리 크기를 키워놔야 한다. Row는 괜찮음 (휴대폰은 대부분 세로이기 때문)
3. 컨테이너는 자식이 없으면 Block, 자식이 있으면 Inline 이다.
4. ListView 는 가로는 Block 세로는 Inline
ㅤ | Block | Inline |
Column | 세로 | 가로 |
Row | 가로 | 세로 |
Container | 자식x | 자식o |
ListView | 가로 | 세로 |
Column은 SizedBox로 가로를 끝까지 늘려준다.(나중에 배치하기 편하게)
data:image/s3,"s3://crabby-images/96c42/96c42d349caca0e7a221ce2afd80498dfa08be6b" alt="notion image"
Row는 가로가 어차피 끝까지 이기 때문에 가만히 둔다.
data:image/s3,"s3://crabby-images/31790/31790fc59b2954cb3ab4d0c67b1de2ff7a40102c" alt="notion image"
한개 짜리는 Align으로 배치해준다.
data:image/s3,"s3://crabby-images/dc054/dc054e0adabfd3928e662d657e1c56bf467643e1" alt="notion image"
배치의 핵심은 Block을 다 만드는 것
import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; class RecipePage extends StatelessWidget { const RecipePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( appBar: _appbar(), body: Column( children: [ _top(), _center(), _bottom(), ], ), ); } Widget _bottom() { return Align( alignment: Alignment.centerRight, child: Container( color: Colors.red, width: 50, height: 50, ), ); } Widget _center() { return Row( crossAxisAlignment: CrossAxisAlignment.start, children: [ Container( color: Colors.red, width: 50, height: 50, ), Container( color: Colors.green, width: 50, height: 50, ), Container( color: Colors.blue, width: 50, height: 50, ), ], ); } Widget _top() { return SizedBox( width: double.infinity, child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ Container( color: Colors.red, width: 50, height: 50, ), Container( color: Colors.green, width: 50, height: 50, ), Container( color: Colors.blue, width: 50, height: 50, ), ], ), ); } AppBar _appbar() { return AppBar( actions: [ Icon(CupertinoIcons.search), SizedBox(width: 15), Icon( CupertinoIcons.heart, color: Colors.redAccent, ), SizedBox(width: 15), ], ); } }
data:image/s3,"s3://crabby-images/6d6c4/6d6c4de6e607f1e815d8ffef282eda1a9ecb5628" alt="notion image"
data:image/s3,"s3://crabby-images/4547c/4547cbb4e9a941316fe6e3214a3f6ca0820be602" alt="notion image"
data:image/s3,"s3://crabby-images/99c72/99c729999b4d2d54f27c074ca430e8ec4e620a01" alt="notion image"
data:image/s3,"s3://crabby-images/53240/53240ecb9323cdb2a3da7cee5cf03cb3e8fa8dcb" alt="notion image"
data:image/s3,"s3://crabby-images/70727/70727c18036cdef5732b7951fa187b81382aeefd" alt="notion image"
data:image/s3,"s3://crabby-images/a9dab/a9dab8c77e8937e20cde2a34e8911e0df8d97bf2" alt="notion image"
data:image/s3,"s3://crabby-images/46969/46969cde9d53b50de5a1cb21a4d5e6bc39bf5461" alt="notion image"
data:image/s3,"s3://crabby-images/27e5f/27e5fd9507f8c58c65e2f9347dcbcc97b04f9dad" alt="notion image"
data:image/s3,"s3://crabby-images/6c70e/6c70ea36206cc4e68253fe809a1095bc52e6f1ec" alt="notion image"
data:image/s3,"s3://crabby-images/84674/846740ecdaeade1e01eea38144863474fe3015c1" alt="notion image"
import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; class RecipePage extends StatelessWidget { const RecipePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( appBar: _appbar(), body: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ Container( color: Colors.red, width: 50, height: 50, ), Container( color: Colors.green, width: 50, height: 50, ), Container( color: Colors.blue, width: 50, height: 50, ), Row( children: [ Container( color: Colors.red, width: 50, height: 50, ), Container( color: Colors.green, width: 50, height: 50, ), Container( color: Colors.blue, width: 50, height: 50, ), ], ), Row( mainAxisAlignment: MainAxisAlignment.center, children: [ Container( color: Colors.yellow, width: 50, height: 50, ), ], ), ], ), ); } AppBar _appbar() { return AppBar( actions: [ Icon(CupertinoIcons.search), SizedBox(width: 15), Icon( CupertinoIcons.heart, color: Colors.redAccent, ), SizedBox(width: 15), ], ); } }
Share article