SwiftUI 를 활용한 iOS 앱 프로젝트를 생성하는 단계를 정리해보려고 해.
아래 URL 을 참고한 아주 기초적인 내용의 프로젝트야.
참고: https://developer.apple.com/tutorials/swiftui/creating-and-combining-views
Choose a template for your new project: iOS – App
data:image/s3,"s3://crabby-images/fb619/fb619b39a006e2c8e8765856aaabc84cd6a8748a" alt=""
Choose options for your new project:
Interface: SwiftUI
Language: Swift
data:image/s3,"s3://crabby-images/a0e35/a0e35df25f79677a5ecaac2e61a15e3d8af2f43e" alt=""
data:image/s3,"s3://crabby-images/04ef7/04ef71cfd0a8e52065d218c5b0ecbef8208dd09f" alt=""
앱 메인 파일 : iosdiaryApp.swift
//
// iosdiaryApp.swift
// iosdiary
//
// Created by woohaha on 2024/04/17.
//
import SwiftUI
@main
struct iosdiaryApp: App {
var body: some Scene {
WindowGroup {
ContentView()
}
}
}
@main 은 앱의 진입점을 의미
main App 에서 참조하는 뷰 : ContentView.swift
//
// ContentView.swift
// iosdiary
//
// Created by woohaha on 2024/04/17.
//
import SwiftUI
struct ContentView: View {
var body: some View {
VStack {
Image(systemName: "globe")
.imageScale(.large)
.foregroundStyle(.tint)
Text("Hello, world!")
}
.padding()
}
}
#Preview {
ContentView()
}
ContentView 의 미리보기 : #Preview
data:image/s3,"s3://crabby-images/9cf47/9cf4799c905224bed3be6fba74279e677dcd52c6" alt=""
data:image/s3,"s3://crabby-images/bb70b/bb70b6a5d0e99fa1a9143eeabecb4096c1fb8de1" alt=""
Live mode 에서는 코드에 구현된 뷰의 미리보기가 가능
Selectable mode 에서는 배치된 컴포넌트의 속성 설정이 가능
data:image/s3,"s3://crabby-images/2965d/2965dd34d5cce335fb0ada8ca6d2e3a1bbb615de" alt=""
Command+Control 을 누른 상태에서 컴포넌트를 클릭하면 해당 컴포넌트에 대한 Inspector 를 볼 수 있다.
data:image/s3,"s3://crabby-images/ca2b1/ca2b1d756982f1f86a5ec4e8037d2a9ec33306f8" alt=""
data:image/s3,"s3://crabby-images/d72a8/d72a899b07a02892e3f5857489661f8dae8f2033" alt=""
편집기에서 Ctrl 키와 함께 선언을 클릭하고 “Show SwiftUI Inspector…” 를 선택하면 코드뷰에서 인스펙터 팝업메뉴를 볼 수 있다.
data:image/s3,"s3://crabby-images/c908e/c908eb4c1ecaba239abb531c82a02bb28b773ffe" alt=""
VStack, HStack, Spacer
data:image/s3,"s3://crabby-images/a0694/a06940c53a79be62194cced3bbe46b15e63a5c1d" alt=""
struct ContentView: View {
var body: some View {
VStack(alignment: .leading) {
Text("Turtle Rock")
.font(.title)
HStack {
Text("Joshua Tree National Park")
.font(.subheadline)
Spacer()
Text("California")
.font(.subheadline)
}
}
.padding()
}
}
뷰의 중첩
신규 뷰 생성
data:image/s3,"s3://crabby-images/0e218/0e2185af34afd66db138cd67e29257e051e7144d" alt=""
data:image/s3,"s3://crabby-images/d3035/d303542cf267a134b07ff438d0528a80bacfb1f5" alt=""
import SwiftUI
struct CircleImage: View {
var body: some View {
Text("Hello, World!")
}
}
#Preview {
CircleImage()
}
Text 컴포넌트 지우고 Image 컴포넌트 추가
import SwiftUI
struct CircleImage: View {
var body: some View {
Image("turtlerock")
}
}
#Preview {
CircleImage()
}
turtlerock 은 Asset 에 추가해둔 이미지 리소스 이름
data:image/s3,"s3://crabby-images/a51a2/a51a2c59e72b4623104a466783852139109064b7" alt=""
data:image/s3,"s3://crabby-images/63d88/63d8869074217b2c6e046f52d7000bf7b3667b7b" alt=""
ContentView 에 CircleImage 뷰를 추가
import SwiftUI
struct ContentView: View {
var body: some View {
VStack(alignment: .leading) {
CircleImage()
Text("Turtle Rock")
.font(.title)
HStack {
Text("Joshua Tree National Park")
.font(.subheadline)
Spacer()
Text("California")
.font(.subheadline)
}
}
.padding()
}
}
#Preview {
ContentView()
}
data:image/s3,"s3://crabby-images/39f52/39f5268554e379387158417eec484627c575eb16" alt=""
글꼴 수정자의 이동
이동 전
HStack {
Text("Joshua Tree National Park")
.font(.subheadline)
Spacer()
Text("California")
.font(.subheadline)
}
이동 후
HStack {
Text("Joshua Tree National Park")
Spacer()
Text("California")
}
.font(.subheadline)