[Flutter] 반응형 스크린 사이즈

2023. 9. 23. 14:26·Web & Android/Flutter
목차
  1. 현재 기기의 스크린 사이즈 출력하고 싶은 경우
  2. 화면 폭에 따라 위젯을 다르게 보여주고 싶은 경우
  3. 화면 폭에 따라 스타일 변경하고 싶은 경우
  4. 스타일 변경 라이브러리
  5. assets 이미지도 해상별로 준비

현재 기기의 스크린 사이즈 출력하고 싶은 경우

MediaQuery.of(context).size.width; //폭 (LP단위)
MediaQuery.of(context).size.height; //높이 (LP단위)
MediaQuery.of(context).padding.top; //기기의 상단바 부분 높이 (LP단위)
MediaQuery.of(context).devicePixelRatio; //이 기기는 1LP에 픽셀이 몇개 들어있는지

 

화면 폭에 따라 위젯을 다르게 보여주고 싶은 경우

MediaQuery.of(context).size.width < 600
? Home()
: 큰화면에서보여줄다른위젯()

 

화면 폭에 따라 스타일 변경하고 싶은 경우

Text(
'글자임',
style: TextStyle(
fontSize: MediaQuery.of(context).size.width > 600 ? 30 : 16,
)
)

→ 함수로 빼도 됨

(class들 바깥 아무데나)
fontsize1(c){
if (MediaQuery.of(c).size.width > 600){
return 30;
} else {
return 16;
}
}
Text(
'글자임',
style: TextStyle(
fontSize: fontsize1(context),
)
)

⇒ 한 번에 모든 글자를 스타일주고 싶다면 ThemeData() 안에 넣으면 됨

→ Theme() 위젯으로 감싸면 중간에 ThemeData()를 하나 만들 수 있는데 거기에 넣어도 됨

스타일 변경 라이브러리

  • auto_size_text
    • Text 위젯에서 글자가 특정 글자 수를 넘을 때 자동으로 점 3개로 생략하거나, 폰트 사이즈를 설정한 대로 줄일 수 있음
  • reponsive_sizer
    • width: Adaptive.w(20) 이러면 위젯의 폭을 화면크기의 20%로 설정 가능
    • TextStyle(fontSize: 15.sp) 이러면 글자크기를 화면크기에 비례해서 설정 가능

⇒ 근데 글자사이즈는 이렇게 하면 너무 큰 화면에선 글자가 너무 커져서 직접하는게 낫다.

assets 이미지도 해상별로 준비

  • 이미지 넣고 싶으면
    • assets 폴더에 넣고 pubspec.yaml 파일에 등록하고 Image.asset() 여기서 사용
    • assets안에 2.0x 폴더랑 3.0x 폴더 만들고 거기에 똑같은 이미지를 넣음→ MediaQuery.of(context).devicePixelRatio가 1~2면 2.0x에 있는 이미지를 씀
    • → MediaQuery.of(context).devicePixelRatio가 2~3이면 3.0x에 있는 이미지를 씀
    • assets/my_icon.png assets/2.0x/my_icon.png assets/3.0x/my_icon.png assets/4.0x/my_icon.png
저작자표시 비영리 변경금지 (새창열림)

'Web & Android > Flutter' 카테고리의 다른 글

[Flutter] 팝업 버튼  (0) 2023.10.17
[Flutter] 유용한 패키지들  (0) 2023.09.23
[Flutter] notification 알림 주는 법  (1) 2023.09.23
[Flutter] GridView, CustomScrollView 프로필 페이지 만들기  (0) 2023.09.23
[Flutter] Provider : store 여러개 & GET 요청  (0) 2023.09.23
  1. 현재 기기의 스크린 사이즈 출력하고 싶은 경우
  2. 화면 폭에 따라 위젯을 다르게 보여주고 싶은 경우
  3. 화면 폭에 따라 스타일 변경하고 싶은 경우
  4. 스타일 변경 라이브러리
  5. assets 이미지도 해상별로 준비
'Web & Android/Flutter' 카테고리의 다른 글
  • [Flutter] 팝업 버튼
  • [Flutter] 유용한 패키지들
  • [Flutter] notification 알림 주는 법
  • [Flutter] GridView, CustomScrollView 프로필 페이지 만들기
woojin._.
woojin._.
여러가지 개발을 해보며 발생하는 이야기들에 대한 블로그입니다:)
  • woojin._.
    Jin's Dev Story
    woojin._.
  • 전체
    오늘
    어제
    • 분류 전체보기 (823) N
      • Tools (25)
        • eGovFrame (3)
        • GeoServer (3)
        • QGIS (2)
        • LabelImg (2)
        • Git (6)
        • GitHub (1)
        • Eclipse (7)
        • Visual Studio (1)
      • Web & Android (121)
        • SpringBoot (37)
        • Three.js (2)
        • Spring Data JPA (9)
        • 스프링 부트 쇼핑몰 프로젝트 with JPA (25)
        • Thymeleaf (4)
        • Spring Security (15)
        • Flutter (29)
      • Programming Language (61)
        • JAVA (27)
        • JavaScript (14)
        • Dart (2)
        • Python (15)
        • PHP (3)
      • Database (43)
        • PostgreSQL (32)
        • MYSQL (7)
        • Oracle (3)
        • MSSQL (1)
      • SERVER (17)
        • TCP_IP (3)
        • 리눅스 (7)
        • AWS (7)
      • Coding Test (439) N
        • 백준[JAVA] (102) N
        • 프로그래머스[JAVA] (260)
        • 알고리즘 고득점 Kit[JAVA] (3)
        • SQL 고득점 Kit[ORACLE] (74)
      • CS 지식 (49)
        • [자료구조] (14)
        • [네트워크] (12)
        • [데이터베이스] (10)
        • [알고리즘] (9)
        • [운영체제] (4)
      • 기타 (6)
      • 자격증 & 공부 (62)
        • 정보처리기사 (2)
        • SQLD (6)
        • 네트워크관리사 2급 (5)
        • 리눅스마스터 1급 (44)
        • 리눅스마스터 2급 (1)
        • ISTQB (3)
        • 시스템보안 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 인기 글

  • 태그

    Spring Security
    Flutter
    데이터
    백준
    postgresql
    스프링 부트 쇼핑몰 프로젝트 with JPA
    spring
    pcce 기출문제
    python
    Java
    Oracle
    baekjoon
    플러터
    Linux
    CS지식
    springboot
    CS
    JPA
    리눅스
    프로그래머스
    programmers
    자바
    DB
    리눅스마스터
    스프링부트
    스프링
    시큐리티
    backjoon
    데이터베이스
    리눅스마스터 1급
  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
woojin._.
[Flutter] 반응형 스크린 사이즈

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.