웅재의 코딩세상
Shazam - view 만들어보기 3 본문
- MainAxisAlignment 와 CrossAxisAlignment를 사용해 전체 틀을 정렬해주었고, 위 설정 아이콘과 라이브러리 텍스트는 spaceBetween 속성을 사용해 마지막에 icon(null)을 사용해 정렬해주었다.
- divider()를 사용해 각각의 구역을 나누어 주었다.
import 'package:flutter/material.dart';
class FirstPage extends StatelessWidget {
const FirstPage({
Key? key,
}) : super(key: key);
@override
Widget build(BuildContext context) {
const songs = [
{
'imageUrl': 'https://i.ibb.co/MRSqtP8/autumnnight.jpg',
'title': '가을밤에 든 생각',
'artist': '잔나비',
},ㄴ
{
'imageUrl': 'https://i.ibb.co/MRSqtP8/autumnnight.jpg',
'title': '가을밤에 든 생각',
'artist': '잔나비',
},
{
'imageUrl': 'https://i.ibb.co/MRSqtP8/autumnnight.jpg',
'title': '가을밤에 든 생각',
'artist': '잔나비',
},
{
'imageUrl': 'https://i.ibb.co/MRSqtP8/autumnnight.jpg',
'title': '가을밤에 든 생각',
'artist': '잔나비',
},
{
'imageUrl': 'https://i.ibb.co/MRSqtP8/autumnnight.jpg',
'title': '가을밤에 든 생각',
'artist': '잔나비',
},
{
'imageUrl': 'https://i.ibb.co/MRSqtP8/autumnnight.jpg',
'title': '가을밤에 든 생각',
'artist': '잔나비',
},
];
return Scaffold(
body: SafeArea(
child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 16),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Container(
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Padding(
padding: const EdgeInsets.symmetric(vertical: 4),
child: Icon(
Icons.settings,
),
),
Text(
'라이브러리',
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 18,
),
),
Icon(null),
],
),
),
SizedBox(
height: 8,
),
Container(
child: Padding(
padding: const EdgeInsets.only(top: 10),
child: Row(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
ImageIcon(
NetworkImage("https://i.ibb.co/hxNbZ8p/shazam.png"),
size: 20,
),
SizedBox(width: 15),
Text(
'Shazam',
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 20,
),
)
],
),
),
),
Divider(),
Container(
child: Padding(
padding: const EdgeInsets.only(top: 10),
child: Row(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Icon(Icons.person_rounded),
SizedBox(width: 15),
Text(
'아티스트',
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 20,
),
)
],
),
),
),
Divider(),
Container(
child: Padding(
padding: const EdgeInsets.only(top: 10),
child: Row(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Icon(Icons.music_note),
SizedBox(width: 15),
Text(
'회원님을 위한 재생 목록',
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 20,
),
)
],
),
),
),
SizedBox(height: 20),
Text(
'최근 Shazam',
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 20,
),
),
SizedBox(height: 20),
Expanded(
child: GridView.builder(
gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
crossAxisCount: 2,
childAspectRatio: 3 / 5,
),
itemCount: songs.length,
itemBuilder: (context, index) {
var song = songs[index];
String imageUrl = song['imageUrl']!;
String title = song['title']!;
String artist = song['artist']!;
index % 2 == 0; // 왼쪽, 1이면 오른쪽
return Container(
margin: EdgeInsets.only(
left: 4,
right: 4,
top: 4,
bottom: 4,
),
decoration: BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.all(
Radius.circular(8),
),
boxShadow: [
BoxShadow(
color: Colors.grey.withOpacity(0.5),
blurRadius: 1,
spreadRadius: 1,
),
],
),
child: Column(
children: [
ClipRRect(
borderRadius: BorderRadius.only(
topLeft: Radius.circular(8),
topRight: Radius.circular(8),
),
child: Image.network(
imageUrl,
fit: BoxFit.cover,
height: MediaQuery.of(context).size.width *
0.5 *
5 /
3 *
0.55,
),
),
Expanded(
child: Container(
padding: const EdgeInsets.all(8),
width: double.infinity,
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(
title,
style: TextStyle(
fontSize: 18,
fontWeight: FontWeight.bold,
),
),
Text(
artist,
style: TextStyle(
fontSize: 14,
color: Colors.grey[600],
),
),
Spacer(),
Image.network(
"https://i.ibb.co/KG9m5QS/applemusic.png",
width: 60,
),
SizedBox(height: 5),
],
),
),
)
],
),
);
},
),
)
],
),
),
),
);
}
}
반응형
'android 개발 > android 실습(flutter)' 카테고리의 다른 글
Shazam - view 만들어보기 4 (0) | 2023.05.20 |
---|---|
Shazam - view 만들어보기 2 (0) | 2023.05.20 |
Shazam - view 만들어보기 1 (0) | 2023.05.20 |
당근마켓 view 만들어보기 (0) | 2023.05.19 |
로그인 페이지 만들기 - 2 (0) | 2023.05.13 |