Row와 Column으로 레이아웃 구성하기
웹 레이아웃의 기본은 요소들을 가로 또는 세로로 배치하는 것입니다. Flitter에서는 Row와 Column 위젯을 사용해 이러한 레이아웃을 쉽게 구성할 수 있습니다.
🎯 학습 목표
이 튜토리얼을 완료하면 다음을 할 수 있게 됩니다:
- Row로 위젯을 가로로 배치하기
- Column으로 위젯을 세로로 배치하기
- MainAxisAlignment로 주축 정렬 제어하기
- CrossAxisAlignment로 교차축 정렬 제어하기
- 실용적인 네비게이션 바 만들기
📚 Row 위젯 이해하기
Row는 자식 위젯들을 가로 방향으로 배치합니다. HTML의 flexbox에서 flex-direction: row와 비슷합니다.
Row의 기본 구조
Row({
  mainAxisAlignment: MainAxisAlignment.start,  // 가로 정렬
  crossAxisAlignment: CrossAxisAlignment.center, // 세로 정렬
  children: [
    // 자식 위젯들
  ]
})
MainAxisAlignment (주축 정렬)
Row에서 주축은 가로 방향입니다:
- MainAxisAlignment.start- 왼쪽 정렬 (기본값)
- MainAxisAlignment.center- 중앙 정렬
- MainAxisAlignment.end- 오른쪽 정렬
- MainAxisAlignment.spaceBetween- 양 끝에 배치하고 사이 공간 균등 분배
- MainAxisAlignment.spaceAround- 각 위젯 주위에 균등한 공간
- MainAxisAlignment.spaceEvenly- 모든 공간을 균등하게 분배
📐 Column 위젯 이해하기
Column은 자식 위젯들을 세로 방향으로 배치합니다. HTML의 flexbox에서 flex-direction: column과 비슷합니다.
Column의 기본 구조
Column({
  mainAxisAlignment: MainAxisAlignment.start,  // 세로 정렬
  crossAxisAlignment: CrossAxisAlignment.center, // 가로 정렬
  children: [
    // 자식 위젯들
  ]
})
Column에서의 축 방향
Column에서는 축 방향이 Row와 반대입니다:
- 주축(MainAxis): 세로 방향
- 교차축(CrossAxis): 가로 방향
🚀 실습 1: 기본 Row 레이아웃
Row({
  mainAxisAlignment: MainAxisAlignment.spaceEvenly,
  children: [
    Container({
      width: 80,
      height: 80,
      color: '#e74c3c',
      child: Center({ child: Text("A") })
    }),
    Container({
      width: 80,
      height: 80,
      color: '#3498db',
      child: Center({ child: Text("B") })
    }),
    Container({
      width: 80,
      height: 80,
      color: '#2ecc71',
      child: Center({ child: Text("C") })
    })
  ]
})
🚀 실습 2: 중첩된 Row와 Column
Row와 Column을 중첩하여 복잡한 레이아웃을 만들 수 있습니다:
Column({
  children: [
    Text("상단 제목"),
    Row({
      mainAxisAlignment: MainAxisAlignment.center,
      children: [
        Text("왼쪽"),
        SizedBox({ width: 20 }),
        Text("중앙"),
        SizedBox({ width: 20 }),
        Text("오른쪽")
      ]
    }),
    Text("하단 설명")
  ]
})
💡 실용적인 예제: 네비게이션 바
Container({
  height: 60,
  decoration: new BoxDecoration({
    color: '#34495e',
    boxShadow: [
      new BoxShadow({
        color: 'rgba(0,0,0,0.1)',
        offset: { x: 0, y: 2 },
        blurRadius: 4
      })
    ]
  }),
  child: Row({
    mainAxisAlignment: MainAxisAlignment.spaceAround,
    crossAxisAlignment: CrossAxisAlignment.center,
    children: [
      Text("홈", { style: new TextStyle({ color: 'white', fontSize: 16 }) }),
      Text("제품", { style: new TextStyle({ color: 'white', fontSize: 16 }) }),
      Text("서비스", { style: new TextStyle({ color: 'white', fontSize: 16 }) }),
      Text("문의", { style: new TextStyle({ color: 'white', fontSize: 16 }) })
    ]
  })
})
🎨 연습 과제
- 3x3 그리드 만들기: Column 안에 3개의 Row를 넣어 3x3 그리드를 만들어보세요
- 카드 레이아웃: Row를 사용해 카드 3개를 가로로 배치해보세요
- 사이드바 레이아웃: Row 안에 사이드바(Column)와 메인 콘텐츠를 배치해보세요
🚨 주의사항
- Overflow 방지: Row나 Column의 자식들이 화면을 벗어나지 않도록 주의
- Expanded 사용: 남은 공간을 채우려면 Expanded 위젯 활용
- 성능: 깊게 중첩된 Row/Column은 성능에 영향을 줄 수 있음
🔗 다음 단계
- Stack과 위치 지정 - 위젯을 겹쳐서 배치하기
- Expanded와 Flexible - 공간 분배하기
