본문으로 이동
주 메뉴
주 메뉴
사이드바로 이동
숨기기
둘러보기
대문
최근 바뀜
임의의 문서로
미디어위키 도움말
특수 문서 목록
학교의 모든 지식. SMwiki
검색
검색
보이기
로그인
개인 도구
로그인
로그아웃한 편집자를 위한 문서
더 알아보기
기여
토론
플러터:화면 전환(Drawer)
편집하기 (부분)
문서
토론
한국어
읽기
편집
원본 편집
역사 보기
도구
도구
사이드바로 이동
숨기기
동작
읽기
편집
원본 편집
역사 보기
일반
여기를 가리키는 문서
가리키는 글의 최근 바뀜
파일 올리기
문서 정보
보이기
사이드바로 이동
숨기기
경고:
로그인하지 않았습니다. 편집을 하면 IP 주소가 공개되게 됩니다.
로그인
하거나
계정을 생성하면
편집자가 사용자 이름으로 기록되고, 다른 장점도 있습니다.
스팸 방지 검사입니다. 이것을 입력하지
마세요
!
= Drawer 기본 구조 = <syntaxhighlight lang="dart">import 'package:flutter/material.dart'; void main() => runApp(MyApp()); class MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return MaterialApp( title: 'Drawer Demo', home: HomePage(), ); } } // ① Drawer 메뉴 항목을 구조화 // 이런 식으로 안하면 수정 시 코드의 위아래를 번갈아 오가며 수정해야 해서 불편함; class MenuItem { final String title; final IconData icon; final Widget page; MenuItem({ required this.title, required this.icon, required this.page, // 메뉴를 탭하면 넘어갈 페이지를 담는다. 요런식으로 객체화를 준비해서 관리하면 편함. }); } class HomePage extends StatefulWidget { @override State<HomePage> createState() => _HomePageState(); } class _HomePageState extends State<HomePage> { int _selectedIndex = 0; // ② 메뉴 데이터를 한 곳에서 정의 // ─────────────────────────────────────── final List<MenuItem> menuItems = [ MenuItem( title: "첫 번째 화면", icon: Icons.home, page: Center(child: Text('첫 번째 화면', style: TextStyle(fontSize: 24))), ), MenuItem( title: "두 번째 화면", icon: Icons.star, page: Center(child: Text('두 번째 화면', style: TextStyle(fontSize: 24))), ), MenuItem( title: "세 번째 화면", icon: Icons.settings, page: Center(child: Text('세 번째 화면', style: TextStyle(fontSize: 24))), ), ]; void _selectPage(int index) { setState(() { _selectedIndex = index; }); Navigator.pop(context); // 최상단이 Drawer라서, Drawer 닫기 } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text("Drawer Demo"), ), // ③ Drawer = ListView.builder로 자동 생성 // ─────────────────────────────────────── drawer: Drawer( child: ListView( // 리스트 뷰 안에서 자동생성해서 관리한다. children: [ DrawerHeader( child: Text("메뉴", style: TextStyle(fontSize: 24)), ), ...List.generate(menuItems.length, (index) { // "..."은 리스트의 원소를 풀어 넣으라는 의미. 익명함수에 정의된 대로 리스트를 만들어 풀어 넣는다. final item = menuItems[index]; return ListTile( leading: Icon(item.icon), title: Text(item.title), onTap: () => _selectPage(index), ); }), ], ), ), body: menuItems[_selectedIndex].page, // 위에서 지정한 페이지를 body에 담는다. ); } }</syntaxhighlight>
요약:
학교의 모든 지식. SMwiki에서의 모든 기여는 크리에이티브 커먼즈 저작자표시-동일조건변경허락 라이선스로 배포된다는 점을 유의해 주세요(자세한 내용에 대해서는
학교의 모든 지식. SMwiki:저작권
문서를 읽어주세요). 만약 여기에 동의하지 않는다면 문서를 저장하지 말아 주세요.
또한, 직접 작성했거나 퍼블릭 도메인과 같은 자유 문서에서 가져왔다는 것을 보증해야 합니다.
저작권이 있는 내용을 허가 없이 저장하지 마세요!
취소
편집 도움말
(새 창에서 열림)
검색
검색
플러터:화면 전환(Drawer)
편집하기 (부분)
새 주제