안녕하세요! 이번 포스팅은 실시간 미세먼지 & 날씨 알림 앱 개발 시리즈의 세 번째 글입니다.
이전 글에서는 Android 개발 환경을 세팅하고 Flutter 프로젝트를 생성했는데요,
이번 글에서는 Flutter로 기본 UI를 어떻게 구성할지 그리고 앞으로 앱의 전체 화면을 어떻게 설계할지를 소개하려고 합니다.
🛠️ 1. Flutter 프로젝트 구조 살펴보기
Flutter 프로젝트를 생성하면 다음과 같은 디렉토리 구조가 만들어집니다:
my_app/
├── android/ // Android 관련 파일
├── ios/ // iOS 관련 파일
├── lib/ // Flutter 앱 소스코드 (💡 대부분 이 폴더를 수정합니다)
│ └── main.dart // 앱 시작점
├── pubspec.yaml // 패키지 설정 파일
└── ...
이 중 우리는 lib/ 폴더와 pubspec.yaml 파일을 주로 다루게 됩니다.
📦 2. 필요한 패키지 설치
API 연동과 상태 관리를 위해 자주 사용하는 패키지를 미리 설치해두는 것이 좋습니다.
# pubspec.yaml
dependencies:
flutter:
sdk: flutter
http: ^0.14.0 # HTTP 요청용
flutter_dotenv: ^5.1.0 # 환경변수(API 키 등) 관리용
provider: ^6.1.0 # 상태 관리용
설정 후에는 아래 명령어를 실행해 패키지를 적용해주세요:
flutter pub get
🧱 3. 앱 기본 구조 만들기
이제 lib/main.dart 파일을 열고, 아래와 같이 기본 구조를 작성해봅니다:
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(
title: '미세먼지 & 날씨 알림 앱',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const HomeScreen(),
);
}
}
class HomeScreen extends StatelessWidget {
const HomeScreen({super.key});
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('실시간 미세먼지 & 날씨'),
centerTitle: true,
),
body: const Center(
child: Text('데이터 로딩 중...'),
),
);
}
}
위 코드를 실행하면 기본적인 앱 화면이 뜨고, “데이터 로딩 중...”이라는 텍스트가 표시됩니다.
🎨 4. 앞으로 만들 UI 구상해보기
이제 어떤 화면을 만들지 상상해보며 간단한 UI 설계를 해볼게요.
앱이 실행되면 아래와 같은 정보가 화면에 표시될 예정입니다:
📍 위치: 서울시 강남구
🌤️ 날씨: 맑음, 15°C
🟡 미세먼지(PM10): 보통 (45㎍/m³)
🟠 초미세먼지(PM2.5): 나쁨 (61㎍/m³)
🔄 새로고침 버튼
이러한 화면 구성을 위해 다음과 같은 위젯들을 사용할 예정입니다:
- Column, Row: 정보 정렬용
- Card: 미세먼지 정보를 카드 형태로 표현
- ElevatedButton: 새로고침 버튼
- Icon: 날씨, 위치 등을 시각적으로 표현
🧭 5. 앞으로의 개발 순서
지금까지는 Flutter UI 구성의 기초를 다졌습니다.
다음 단계에서는 실제 데이터를 불러오고 화면에 표시하는 기능을 구현할 예정입니다.
다음 포스팅 예고:
📌 #4 – 위치 권한 요청 & 현재 위치 가져오기
또는
📌 #4 – OpenWeatherMap & AirKorea API 연동 (날씨 & 미세먼지 데이터 가져오기)
✨ 마무리
지금은 단순한 “데이터 로딩 중...” 화면만 보이지만,
곧 실제로 날씨와 미세먼지 정보를 실시간으로 보여주는 알림 앱으로 발전할 예정입니다! 😎
Flutter가 낯설거나 초보자여도,
이 시리즈를 통해 완성까지 차근차근 따라갈 수 있도록 도와드릴게요!
그럼 다음 포스팅에서 뵙겠습니다 🚀