본문으로 이동
주 메뉴
주 메뉴
사이드바로 이동
숨기기
둘러보기
대문
최근 바뀜
임의의 문서로
미디어위키 도움말
특수 문서 목록
학교의 모든 지식. SMwiki
검색
검색
보이기
로그인
개인 도구
로그인
로그아웃한 편집자를 위한 문서
더 알아보기
기여
토론
플러터:테마
편집하기
문서
토론
한국어
읽기
편집
원본 편집
역사 보기
도구
도구
사이드바로 이동
숨기기
동작
읽기
편집
원본 편집
역사 보기
일반
여기를 가리키는 문서
가리키는 글의 최근 바뀜
파일 올리기
문서 정보
보이기
사이드바로 이동
숨기기
Sam
(
토론
|
기여
)
님의 2026년 1월 7일 (수) 13:45 판
(
→
기본 구조
)
(
차이
)
← 이전 판
|
최신판
(
차이
) |
다음 판 →
(
차이
)
경고: 이 문서의 오래된 판을 편집하고 있습니다.
이것을 게시하면, 이 판 이후로 바뀐 모든 편집이 사라집니다.
경고:
로그인하지 않았습니다. 편집을 하면 IP 주소가 공개되게 됩니다.
로그인
하거나
계정을 생성하면
편집자가 사용자 이름으로 기록되고, 다른 장점도 있습니다.
스팸 방지 검사입니다. 이것을 입력하지
마세요
!
{{플러터}} == 개요 == * 색이나 이런저런 설정을 한번에 변화시키기 위해 테마를 사용한다. * 앱 전체에 적용되는 색상, 폰트, 버튼 스타일 등의 시각적 요소를 일관되게 관리하기 위한 시스템. * Material Design 철학을 기반으로, 위젯 단위가 아닌 앱 단위 스타일 관리. === 장점 === * UI 일관성 유지(당연하지만, 규모가 커질수록 용이해진다.) * 스타일 변경 시 코드 수정 최소화 * 다크 모드 / 라이트 모드 대응 용이 = 기본 구조 = Flutter 앱은 일반적으로 <code>MaterialApp</code> 위젯을 루트로 가지며, 이곳에서 Theme를 정의한다.<syntaxhighlight lang="dart"> MaterialApp( theme: ThemeData( primaryColor: Colors.blue, ), home: MyHomePage(), ); </syntaxhighlight>테마를 설정하지 않으면 기본 값은 아래와 같다고 보면 된다.<syntaxhighlight lang="dart"> MaterialApp( theme: ThemeData.light(), themeMode: ThemeData.light(), ); </syntaxhighlight> == 권장 설정 == Flutter는 라이트 / 다크 테마를 동시에 정의할 수 있다.<syntaxhighlight lang="dart"> MaterialApp( theme: ThemeData.light(), // 라이트 테마에 대한 기본 색상들. darkTheme: ThemeData.dark(), themeMode: ThemeMode.system, // 시스템 설정을 따라 다크테마 지정 결정. useMaterial3: true, // 설정 안해두면 마테리얼2 이다. ); </syntaxhighlight>themeMode 옵션 * ThemeMode.light * ThemeMode.dark * ThemeMode.system 위처럼 light나 dark 테마를 자동으로 넣을 수도 있고, 이후 소개하는 것처럼 색을 수동으로 지정할 수도 있다. === 세부 구성 === ThemaData에 light, dark 등을 지정하지 않고 일일이 구현한다면 아래와 같은 형태이다.<syntaxhighlight lang="dart"> ThemeData.light() ≈ ThemeData( brightness: Brightness.light, colorScheme: ColorScheme.light(), textTheme: Typography.material2018().black, ); </syntaxhighlight> === Material 3 === Flutter 최신 버전에서는 Material 3 사용이 권장된다.<syntaxhighlight lang="dart">ThemeData( useMaterial3: true, );</syntaxhighlight>Material 3 특징: * 둥근 모서리 * 색상 자동 조합 동적인 컬러 시스템 == ColorScheme == Flutter에서는 개별 색상보다 ColorScheme 사용을 권장.<syntaxhighlight lang="dart"> ThemeData( colorScheme: ColorScheme.fromSeed( seedColor: Colors.teal, brightness: Brightness.light, ), ); </syntaxhighlight>주요 색상 구성: * primary * secondary * background * surface * error == TextTheme == 앱 전체 텍스트 스타일을 정의한다.<syntaxhighlight lang="dart"> ThemeData( textTheme: TextTheme( bodyLarge: TextStyle(fontSize: 18), titleLarge: TextStyle(fontWeight: FontWeight.bold), ), ); </syntaxhighlight>자주 사용하는 텍스트 스타일: * bodySmall / bodyMedium / bodyLarge * titleSmall / titleMedium / titleLarge * headlineSmall / headlineMedium / headlineLarge == Button Theme == Flutter 2.0 이후 버튼은 다음 세 가지로 통합되었다. * ElevatedButton * TextButton * OutlinedButton 각 버튼은 개별 스타일을 테마에서 정의할 수 있다. === ElevatedButton Theme === <syntaxhighlight lang="dart"> ThemeData( elevatedButtonTheme: ElevatedButtonThemeData( style: ElevatedButton.styleFrom( backgroundColor: Colors.blue, foregroundColor: Colors.white, ), ), ); </syntaxhighlight> === TextButton Theme === <syntaxhighlight lang="dart"> ThemeData( textButtonTheme: TextButtonThemeData( style: TextButton.styleFrom( foregroundColor: Colors.blue, ), ), ); </syntaxhighlight> == Theme.of(context) == 위젯 내부에서 현재 테마에 접근할 때 사용한다.<syntaxhighlight lang="dart"> final theme = Theme.of(context); Text( 'Hello', style: theme.textTheme.bodyLarge, ); </syntaxhighlight> *
요약:
학교의 모든 지식. SMwiki에서의 모든 기여는 크리에이티브 커먼즈 저작자표시-동일조건변경허락 라이선스로 배포된다는 점을 유의해 주세요(자세한 내용에 대해서는
학교의 모든 지식. SMwiki:저작권
문서를 읽어주세요). 만약 여기에 동의하지 않는다면 문서를 저장하지 말아 주세요.
또한, 직접 작성했거나 퍼블릭 도메인과 같은 자유 문서에서 가져왔다는 것을 보증해야 합니다.
저작권이 있는 내용을 허가 없이 저장하지 마세요!
취소
편집 도움말
(새 창에서 열림)
이 문서에 포함된 문서:
틀:플러터
(
편집
)
검색
검색
플러터:테마
편집하기
새 주제