data:image/s3,"s3://crabby-images/550ec/550ecf5d749825cb587bbb13731341b5748ad47d" alt="RecipeApp - body만들기"
1. 상단에 아이콘 만들기
- 아이콘이 안보이면 디폴트가 흰색이라 안보임
- 플러서 인스펙트로 확인하고 색상 변경하기
- 보통 키 값이 없으면 시그니처임
import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import '../components/recipe_list_item.dart'; import '../components/recipe_menu.dart'; import '../components/recipe_title.dart'; class RecipePage extends StatelessWidget { @override Widget build(BuildContext context) { return Scaffold( backgroundColor: Colors.white, appBar: _buildRecipeAppBar(), body: Padding( padding: const EdgeInsets.symmetric(horizontal: 20), child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ RecipeTitle(), RecipeMenu(), RecipeListItem("coffee", "made Coffee"), RecipeListItem("burger", "made Burger"), RecipeListItem("pizza", "made Pizza"), ], ), ), ); } AppBar _buildRecipeAppBar() { return AppBar( backgroundColor: Colors.white, elevation: 1.0, actions: [ Icon( CupertinoIcons.heart, color: Colors.redAccent, ), SizedBox(width: 15,) ], ); } }
data:image/s3,"s3://crabby-images/bb6e4/bb6e4f7b293ee2b6f0dbe0986fd1607ac9ba17a3" alt="notion image"
2. 제목 넣기
- Text 넣기
import 'package:flutter/material.dart'; class RecipeTitle extends StatelessWidget { const RecipeTitle({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Padding( padding: const EdgeInsets.only(top: 20), child: Text( "Recipes", style: TextStyle(fontSize: 20), ), ); } }
data:image/s3,"s3://crabby-images/16ad8/16ad8f6ffc7ede805ccf48ca4c7e44dc41170205" alt="notion image"
data:image/s3,"s3://crabby-images/e76f7/e76f71d4e9580ae1209062e1aeb60b5534aaa776" alt="notion image"
data:image/s3,"s3://crabby-images/de400/de4004d09ad774fa38c4ea4e89075a64cd315cd1" 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 _appBar(); } Scaffold _appBar() { return Scaffold( appBar: AppBar( actions: [ Icon(CupertinoIcons.search), SizedBox(width: 15), Icon( CupertinoIcons.heart, color: Colors.redAccent, ), SizedBox(width: 15), ], ), body: recipeTitle()); } } class recipeTitle extends StatelessWidget { const recipeTitle({ super.key, }); @override Widget build(BuildContext context) { return Padding( padding: const EdgeInsets.symmetric(horizontal: 20), child: ListView( children: [ SizedBox(height: 20), Text( "Recipe", style: TextStyle(fontSize: 30), ) ], ), ); } }
- font 적용하기
import 'package:flutter/material.dart'; import 'package:recipe_app/pages/recipe_page.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return MaterialApp( debugShowCheckedModeBanner: false, theme: ThemeData(fontFamily: "PatuaOne"), home: RecipePage(), ); } }
data:image/s3,"s3://crabby-images/4fa17/4fa17930bf04432f57653eedb1ab7abd13fae536" alt="notion image"
- 타이틀 수정하기
import 'package:flutter/cupertino.dart'; class recipeTitle extends StatelessWidget { const recipeTitle({ super.key, }); @override Widget build(BuildContext context) { return Padding( padding: const EdgeInsets.symmetric(horizontal: 20), child: ListView( children: [ SizedBox(height: 20), Text( "Recipe", style: TextStyle(fontSize: 30), ) ], ), ); } }
3. 아이콘 넣기
import 'package:flutter/material.dart'; class RecipeMenu extends StatelessWidget { const RecipeMenu({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Padding( padding: const EdgeInsets.only(top: 20), child: Row( children: [ _buildMenuItem(Icons.food_bank, "ALL"), SizedBox(width: 25), _buildMenuItem(Icons.emoji_food_beverage, "Coffee"), SizedBox(width: 25), _buildMenuItem(Icons.fastfood, "Burger"), SizedBox(width: 25), _buildMenuItem(Icons.local_pizza, "Pizza"), ], ), ); } } Widget _buildMenuItem(IconData mIcon, String text) { return Container( width: 60, height: 80, decoration: BoxDecoration( borderRadius: BorderRadius.circular(30), border: Border.all(color: Colors.black12), ), child: Column( mainAxisAlignment: MainAxisAlignment.center, children: [ Icon(mIcon, color: Colors.redAccent, size: 30), SizedBox(height: 5), Text( text, style: TextStyle(color: Colors.black87), ), ], ), ); }
data:image/s3,"s3://crabby-images/26eea/26eeaca0033751818e0bcd3bc97e6919a1d5c080" alt="notion image"
4. 사진과 Text 넣기
import 'package:flutter/material.dart'; class RecipeListItem extends StatelessWidget { final String imageName; final String title; const RecipeListItem(this.imageName, this.title, {Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Padding( padding: const EdgeInsets.symmetric(vertical: 20), child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ AspectRatio( aspectRatio: 2 / 1, child: ClipRRect( borderRadius: BorderRadius.circular(20), child: Image.asset( "assets/images/$imageName.jpeg", fit: BoxFit.cover, ), ), ), SizedBox(height: 10), Text( title, style: TextStyle(fontSize: 20), ), Text( "Have you ever made your own $title? Once you've tried a homemade $title, you'll never go back.", style: TextStyle(color: Colors.grey, fontSize: 12), ), ], ), ); } }
data:image/s3,"s3://crabby-images/8f060/8f0604451083ba33643f8ef8c8d478515be0c520" alt="notion image"
5. overflow 문제 해결하기
import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import '../components/recipe_list_item.dart'; import '../components/recipe_menu.dart'; import '../components/recipe_title.dart'; class RecipePage extends StatelessWidget { @override Widget build(BuildContext context) { return Scaffold( backgroundColor: Colors.white, appBar: _buildRecipeAppBar(), body: Padding( padding: const EdgeInsets.symmetric(horizontal: 20), child: ListView( children: [ RecipeTitle(), RecipeMenu(), RecipeListItem("coffee", "made Coffee"), RecipeListItem("burger", "made Burger"), RecipeListItem("pizza", "made Pizza"), ], ), ), ); } AppBar _buildRecipeAppBar() { return AppBar( backgroundColor: Colors.white, elevation: 1.0, actions: [ Icon( CupertinoIcons.search, color: Colors.black, ), Icon( CupertinoIcons.heart, color: Colors.redAccent, ), SizedBox(width: 15,) ], ); } }
data:image/s3,"s3://crabby-images/c4916/c49163e1a3aef812530a39933ca58ceea2292545" alt="notion image"
6. 사진 크기 조절하기
fit: BoxFit.cover
import 'package:flutter/material.dart'; class RecipeListItem extends StatelessWidget { final String imageName; final String title; const RecipeListItem(this.imageName, this.title, {Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Padding( padding: const EdgeInsets.symmetric(vertical: 20), child: Column(crossAxisAlignment: CrossAxisAlignment.start, children: [ Image.asset( "assets/images/$imageName.jpeg", fit: BoxFit.cover, ), SizedBox(height: 10), Text( title, style: TextStyle(fontSize: 20), ), Text( "Have you ever made your own $title? Once you've tried a homemade $title, you'll never go back.", style: TextStyle(color: Colors.grey, fontSize: 12), ), ]), ); } }
data:image/s3,"s3://crabby-images/0e900/0e9009d349ca4130bc8ff38cf925d2f2c44e28a6" alt="notion image"
- AspectRatio로 비율 수정하기
import 'package:flutter/material.dart'; class RecipeListItem extends StatelessWidget { final String imageName; final String title; const RecipeListItem(this.imageName, this.title, {Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Padding( padding: const EdgeInsets.symmetric(vertical: 20), child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ AspectRatio( aspectRatio: 2 / 1, child: Image.asset( "assets/images/$imageName.jpeg", fit: BoxFit.cover, ), ), SizedBox(height: 10), Text( title, style: TextStyle(fontSize: 20), ), Text( "Have you ever made your own $title? Once you've tried a homemade $title, you'll never go back.", style: TextStyle(color: Colors.grey, fontSize: 12), ), ], ), ); } }
data:image/s3,"s3://crabby-images/be5de/be5de25402cd0be1cf684e550b4c11b708bd4756" alt="notion image"
7. 사진 모서리 둥글게 만들기
child: ClipRRect( borderRadius: BorderRadius.circular(20),
import 'package:flutter/material.dart'; class RecipeListItem extends StatelessWidget { final String imageName; final String title; const RecipeListItem(this.imageName, this.title, {Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Padding( padding: const EdgeInsets.symmetric(vertical: 20), child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ AspectRatio( aspectRatio: 2 / 1, child: ClipRRect( borderRadius: BorderRadius.circular(20), child: Image.asset( "assets/images/$imageName.jpeg", fit: BoxFit.cover, ), ), ), SizedBox(height: 10), Text( title, style: TextStyle(fontSize: 20), ), Text( "Have you ever made your own $title? Once you've tried a homemade $title, you'll never go back.", style: TextStyle(color: Colors.grey, fontSize: 12), ), ], ), ); } }
data:image/s3,"s3://crabby-images/fd13b/fd13b6d23a7bcc68fa1da9322ab38bfa0167d72e" alt="notion image"
Share article