data:image/s3,"s3://crabby-images/57126/5712671641646423cfa3330c4784cf05c501e84a" alt="ProfileApp - 풀이"
1.theme
[ 일반 컬러랑 메티리얼 컬러의 차이점 ]
메터리얼 컬러 -> 좀 더 연한 빨강, 좀 더 진한 빨강 막 이런... 더 여러가지 색 사용 가능 색상을 하나만 표현하지 않는다!
data:image/s3,"s3://crabby-images/e1589/e1589c2709ebf79003af2cd93efa7935a7f9fd29" alt="notion image"
data:image/s3,"s3://crabby-images/5242c/5242c2e944dc1ed87d0b3a2ae065e2b69e3fff55" alt="notion image"
메테리얼 컬러만 지원. 테마로 적용하면 모든게 다 적용되니까... 테마에 적용한 것임 테마 설정하면 위젯을 만들때 스코필드의 뼈대 테마들을 한방 적용 가능! -> 편해서 씀! 일단 우린 앱의 메인 색상과(primarySwatch)와 appBarTheme 적용 가능하다는 것만 알자 나중에 하나하나씩 적용해보자
- primary switch : app의 메인 컬러
data:image/s3,"s3://crabby-images/00083/0008315a0c058bfbff0f47858114a53066deaaf3" alt="notion image"
- 색깔 진하게 하기
data:image/s3,"s3://crabby-images/5bc63/5bc63d88242ee0423fd80e67ed22815743c901ac" alt="notion image"
- 내가 만든 메터리얼 컬러
data:image/s3,"s3://crabby-images/c7e7c/c7e7c948144c64dbb2ab9102c8db6e67ad35fc5c" alt="notion image"
data:image/s3,"s3://crabby-images/814ad/814ad7995596ed81f057828038a603532cc1e3cc" alt="notion image"
- 테마로 적용 → 모든 페이지에 적용됨
2.
- endDrawer :
data:image/s3,"s3://crabby-images/87c4c/87c4c16739532e00376ab84c4c61bfd22e6cc12b" alt="notion image"
- drawer
data:image/s3,"s3://crabby-images/f1758/f175868d696d13f95669538c33bfb05ea11b95c6" alt="notion image"
data:image/s3,"s3://crabby-images/95734/9573473b676cd7c9c8141a12f9ceefd9e31cf798" alt="notion image"
leading이 나와야 드로우(저 파란거)가 나옴
3.
data:image/s3,"s3://crabby-images/3573f/3573f013394aaebf424bad5414d958397e60562c" alt="notion image"
위젯이 자기 속성으로 사이즈를 안들고 있으면 SizedBox를 사용해서 크기를 주면 된다. 그러나 이렇게 사이즈를 딱 박아버리면 재사용 불가능! 재사용할 수 있게 적어야함
data:image/s3,"s3://crabby-images/bcd5c/bcd5c9b14f16056f079b5562e8cd0d5416ba79c8" alt="notion image"
재사용 위해 빼주기
data:image/s3,"s3://crabby-images/ad885/ad88588bef5b59a61245cb1498f235c6ac5c4f10" alt="notion image"
디폴트값 100을 넣어줌. 디폴트값을 설정해줬기에 required 필요없음!
data:image/s3,"s3://crabby-images/b09f2/b09f2e688f8f23659d5ba5a3cf57d68c41d99170" alt="notion image"
이것이 재사용 가능한 컴퍼넌트 컴퍼넌트가 엄청나게 많겠죠? -> 페이지 별로 컴퍼넌트를 관리함. 공통 컴퍼넌트도 있겠고...
data:image/s3,"s3://crabby-images/65c7f/65c7faa60465168bda7fe14628ca520781be3b4e" alt="notion image"
data:image/s3,"s3://crabby-images/bda81/bda81e66cedbc1caf3825bffb16412d716f9d124" alt="notion image"
data:image/s3,"s3://crabby-images/488e5/488e566aba2947a815e335fc292ff0a52fa27468" alt="notion image"
- 일급 객체라 가능함
data:image/s3,"s3://crabby-images/bdb42/bdb429bcea8b830b8915b824583aa35e8589032c" alt="notion image"
- 버튼 크기를 사이즈 박스로 감싸서 조절함
data:image/s3,"s3://crabby-images/88d32/88d32ced71af51d83faf17ce801d617402af0b7e" alt="notion image"
import 'package:flutter/material.dart'; import 'package:profile_app/theme.dart'; import 'components/profile_buttons.dart'; import 'components/profile_count_info.dart'; import 'components/profile_drawer.dart'; import 'components/profile_header.dart'; import 'components/profile_tab.dart'; void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return MaterialApp( theme: theme(), home: ProfilePage(), ); } } class ProfilePage extends StatelessWidget { const ProfilePage({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Scaffold( endDrawer: ProfileDrawer(), appBar: _buildProfileAppBar(), body: Column( children: [ SizedBox(height: 20), ProfileHeader(), SizedBox(height: 20), ProfileCountInfo(), SizedBox(height: 20), ProfileButtons(), Expanded(child: ProfileTab()), ], ), ); } AppBar _buildProfileAppBar() { return AppBar(); } }
import 'package:flutter/material.dart'; import 'package:profile_app/theme.dart'; import 'components/profile_buttons.dart'; import 'components/profile_count_info.dart'; import 'components/profile_drawer.dart'; import 'components/profile_header.dart'; import 'components/profile_tab.dart'; import 'components/profile_tap2.dart'; void main() { runApp(MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); @override Widget build(BuildContext context) { return MaterialApp( theme: theme(), home: ProfilePage(), ); } } class ProfilePage extends StatelessWidget { @override Widget build(BuildContext context) { return Scaffold( endDrawer: ProfileDrawer(), appBar: _buildProfileAppBar(), body: Column( children: [ SizedBox(height: 20), ProfileHeader(), SizedBox(height: 20), ProfileCountInfo(), SizedBox(height: 20), ProfileButtons(), // 남아있는 세로 공간을 모두 차지하기 위해 Expanded를 준다 Expanded(child: profile_tab2(), ), ], ), ); } AppBar _buildProfileAppBar() { return AppBar( leading: Icon(Icons.arrow_back_ios), title: Text("Profile"), centerTitle: true, ); } }
import 'package:flutter/material.dart'; class profile_tab2 extends StatelessWidget { const profile_tab2({ super.key, }); @override Widget build(BuildContext context) { return DefaultTabController( length: 2, initialIndex: 0, child: Column( children: [ TabBar( tabs: [ Tab(icon: Icon(Icons.car_crash)), Tab(icon: Icon(Icons.car_rental)), ], ), Expanded( child: TabBarView( children: [ GridView.builder( gridDelegate: SliverGridDelegateWithFixedCrossAxisCount( crossAxisCount: 3, ), itemBuilder: (context, index) { return Image.network( "https://picsum.photos/id/${index + 1}/200/200"); }, ), Container( color: Colors.red, ), ], ), ), ], ), ); } }
data:image/s3,"s3://crabby-images/85504/855044cdb1711741175b56a183ab47f1d696baf4" alt="notion image"
30개를 new해서 띄우면 비효율적
화면에는 5개밖에 못 띄우니까 앱은 프로세스 1개로 관리
윈도우는 켜진게 모두 다 프로세스지만 앱은 아님
폰은 컴퓨터만큼 퍼포먼스가 좋지 않음
이 앱이 여러가지의 프로세스를 가지고 좋은 퍼포먼스를 내야하는데
앱마다 프로세스를 다 만들어내면 너무 빡셈
→ 안드로이드나 ios들은 프로세스를, 하나로 관리
하나의 프로세스로 관리 함.
카톡이랑 브라우저가 여러개로 동시에 안 켜짐
카카오톡이라는 앱이 하나 켜지잖아? 카톡이 화면에 떳겠죠?
카카오톡 프로세스 번호 1 -> 그럼 프로세스가 1을 관리한다.
그럼 휴대폰 화면을 밑으로 내려버리잖아? (홈화면이나...)
컴퓨터는 밑으로 내린다고 해서 메모리가 잡고있는게 사라지지 않는다. 꺼진게 아니다.
그러나 폰은 애가 관리하는 이 프로세스, 데이터들을 현재 그 상태를 물리적인 저장 장소에
저장해놓고, 메모리에선 지워짐.
즉, 애가 메모리로 관리하고 있진 않음!!
이 상태에서 인스타를 켰다고 하자.
그럼 인스타 프로세스 번호 2
그럼 프로세스는 1이 아니라 2를 관리. (번호로 관리한다) 인스타가 메모리에 뜸!
쓰다가 인스타를 내리잖아? 또 인스타를 물리적으로 그 상태를 (포크 떠버림) 저장해버림.
다시 열 때, 그 상태를 복원 시키면서 메모리가 활성화 됨!
앱은 원 프로세스!
컴퓨터는 내려도 다 떠있음~~
그렇게 메모리가 중요한 애들이 30개를 모두 다 띄우진 않겠죠?
어떻게 하는걸까?
컬렉션을 하나 만들어서 arrayList를 하나 만든다.
이 화면이 build 될 때, 화면의 높이를 계산한다. 500이네?
내가 지금 그려야할 객체의 높이도 계산한다. 100이네?
화면에 보일 수 있는건 5개밖에 없네? 연산이 가능
객체를 5개만 만들잖아? 스크롤 하는 순간 6번째 애가 엄청 늦게 올라올 것
5개가 아니라 30% 정도를 메모리에 더 띄움
즉, 객체를 5개 만들더라도 띄우는건 7개가 띄워지는 것
viewHolder 같은 곳에 순수한 디자인
데이터가 바인딩 되어있지 않은 디자인을(껍데기만) 객체로 만들어서 띄워놓음
통신을 해서 그리잔항?
빠져나가면서 올라올 것
30%를 더 그려야 순수해짐
3개를 더 그려야 함
화면에서 보이지 않는 애들도 2~30%는 더 만들어야 스크롤리 스무스해짐
어떻게 해야 메모리를 효율적으로 쓸 수 있을까?
올라간 디자인 안의 데이터만 빼고 8,9 번 데이터를 바인딩해서 집어넣는것
그럼 7개만 가지고 놀 수 있음
30개는 만들지 않아도 됨
이게 뷰 홀더 패턴
data:image/s3,"s3://crabby-images/204ab/204ab1079ce40343c70da0b7b45ea068e57ea5e6" alt="notion image"
리쿼스트 관리 기술 = 풀링 기술
이게 가장 효과적
만들어놓고 재사용하기
빌드 : 데이터를 폴딩해서 바꿔 끼워 사용하는 것
Share article