data:image/s3,"s3://crabby-images/223bf/223bf1389f1a43726ee7b194b1f45832acf6756a" alt="StoreApp - TEXT 넣기"
1. MaterialApp : 새까만 화면
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp() } }
data:image/s3,"s3://crabby-images/ea86f/ea86fdb1d80b574ac96e52db3021d952427ad4fe" alt="notion image"
2. Scaffold는 선택적 매개 변수
- 위젯의 뼈대 제공
data:image/s3,"s3://crabby-images/c3342/c334282f1c02f6b60576a13be35d32fa625975cf" alt="notion image"
3. Row : 새로 정렬하기
children: [] // list의 위젯타입
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( body: Column(), // 새로 정렬 ), ); } }
4. Test : 키 값 없이 쓸 수 있는 시그니처 매개변수
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: Scaffold( body: Column( // 새로 정렬, 데이터를 여러건 둘 수 있음 children: [ // list의 위젯타입 Text("안녕"), // 키값 없이 쓸 수 있는 시그니처 매개변수 Text("안녕"),], ), ), ); } }
data:image/s3,"s3://crabby-images/b3c88/b3c883fab6db9578c5d37b3f15ad45ff00d6de38" alt="notion image"
data:image/s3,"s3://crabby-images/bdb80/bdb802b6a4e4f265d725f4073fa10728712a4b92" alt="notion image"
5. 선택하기
CTRL + W
data:image/s3,"s3://crabby-images/2c751/2c751f29353396d115391dcdd679d23c4f8d1b9d" alt="notion image"
data:image/s3,"s3://crabby-images/bee16/bee16c370e113ff8fa637e5eab4e388e12c9103f" alt="notion image"
6. scaffold와 body에 그림을 그리면 됨
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return const Placeholder(); } }
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold(); // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 } }
data:image/s3,"s3://crabby-images/79191/79191554389d813e970ae8a777e4e699d097c268" alt="notion image"
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: Column( children: [ Row( // 가로 행 children: [ Text("Woman"), ], ), ], ), ); } }
6. 자동 정렬 설정하기
data:image/s3,"s3://crabby-images/220c5/220c5ebd4ea3f716e30051eb40618e6e7368f5ca" alt="notion image"
실습하기
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: Column( children: [ Row( // 가로 행 children: [ Text("Woman"), Text("Kids"), Text("Shoes"), Text("Bag"), ], ), ], ), ); } }
data:image/s3,"s3://crabby-images/7984e/7984e015d270aa5601f9f8f946287194c91a4e60" alt="notion image"
7. 구조 보기
data:image/s3,"s3://crabby-images/3e354/3e3549baf64bc13079d2acd69e08eb074b6ba816" alt="notion image"
data:image/s3,"s3://crabby-images/f2698/f269869584856c473b4c89cca1d69c7534f7039a" alt="notion image"
data:image/s3,"s3://crabby-images/13c46/13c46c67ca04ba9b575c4159ec8203e62f19a90b" alt="notion image"
data:image/s3,"s3://crabby-images/2820c/2820c53c6a5e3791f4af3b66f1d284081d17c0ff" alt="notion image"
- inSet 영역 : 이미 사용하고 있는 영역, 화면을 가리는 영역
data:image/s3,"s3://crabby-images/90bf3/90bf337f6a6d01a007aec1bbd1d271f5e831392a" alt="notion image"
data:image/s3,"s3://crabby-images/e9111/e9111389967defb274e95367eaf03749f7ce4143" alt="notion image"
8. inSet 영역 피하기
- inSet : 이미 사용하고 있는 영역, 화면을 가리는 영역
data:image/s3,"s3://crabby-images/809e7/809e73e671ac55f1f2a8dd86b7d7227f06019791" alt="notion image"
- 다 계층 구조임
data:image/s3,"s3://crabby-images/bdbb7/bdbb7ecd03c61d725da43bb1fc4ccf161eb6062f" alt="notion image"
SafeArea // 시스템 UI를 자동으로 피해줌
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: SafeArea( child: Column( children: [ Row( // 가로 행 children: [ Text("Woman"), Text("Kids"), Text("Shoes"), Text("Bag"), ], ), ], ), ), ); } }
data:image/s3,"s3://crabby-images/d0e87/d0e878ca0ed0bf1d8a3cba4bacfa602a17e2b83a" alt="notion image"
- heap에 text를 띄우면서 text의 reference가 저장되는 것
data:image/s3,"s3://crabby-images/c7066/c7066925bd6ea37071f015401be744a01f6fdac5" alt="notion image"
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: SafeArea( child: Column( children: [ Padding( padding: const EdgeInsets.all(25.0), child: Row( // 가로 행 mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text( "Woman", style: TextStyle(),), Text("Kids"), Text("Shoes"), Text("Bag"), ], ), ), ], ), ), ); } }
data:image/s3,"s3://crabby-images/a9be0/a9be050a417cb8c4faeb60581d8c4af7d8da3458" alt="notion image"
data:image/s3,"s3://crabby-images/11c18/11c18997cf567bf41050995d7745cf321ec52c46" alt="notion image"
11. 글자 굵기 조절하기
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: SafeArea( child: Column( children: [ Padding( padding: const EdgeInsets.all(25.0), child: Row( // 가로 행 mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text( "Woman", style: TextStyle(fontWeight: FontWeight.bold), ), Text("Kids"), Text("Shoes"), Text("Bag"), ], ), ), ], ), ), ); } }
data:image/s3,"s3://crabby-images/89503/895031c77aa8e22999eb9c60eb0e0ded15a4986e" alt="notion image"
import 'package:flutter/material.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); // 디폴트 생성자 -> 생략 가능 @override Widget build(BuildContext context) { return MaterialApp( home: StorePage(), ); } } class StorePage extends StatelessWidget { const StorePage({super.key}); @override Widget build(BuildContext context) { return Scaffold( // 페이지 만드는 구조 -> 모든 페이지가 다 가지고 있어야 함 body: SafeArea( child: Column( children: [ Padding( padding: const EdgeInsets.all(25.0), child: Row( // 가로 행 mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [ Text( "Woman", style: TextStyle(fontWeight: FontWeight.bold), ), Text( "Kids", style: TextStyle(fontWeight: FontWeight.bold), ), Text( "Shoes", style: TextStyle(fontWeight: FontWeight.bold), ), Text( "Bag", style: TextStyle(fontWeight: FontWeight.bold), ), ], ), ), ], ), ), ); } }
data:image/s3,"s3://crabby-images/e3ccb/e3ccb39b204a933f3e14be6365b31b6d2e2b01b1" alt="notion image"
Share article