Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- combine
- 리펙터링
- map
- Xcode
- HIG
- swift documentation
- ios
- Clean Code
- tableView
- UITextView
- UICollectionView
- uiscrollview
- Protocol
- swiftUI
- SWIFT
- collectionview
- 리팩토링
- Observable
- Refactoring
- 리펙토링
- 애니메이션
- Human interface guide
- ribs
- 스위프트
- 클린 코드
- rxswift
- clean architecture
- uitableview
- RxCocoa
- MVVM
Archives
- Today
- Total
김종권의 iOS 앱 개발 알아가기
[iOS - SwiftUI] HStack, VStack, ZStack, LazyStack 사용 방법 (+ @unknown, @frozen) 본문
iOS 기본 (SwiftUI)
[iOS - SwiftUI] HStack, VStack, ZStack, LazyStack 사용 방법 (+ @unknown, @frozen)
jake-kim 2022. 8. 24. 23:07HStack 개념
- 선언부
@frozen struct HStack<Content> where Content : View
cf) @frozen이란?
@unknown 먼저 알기)
- enum타입을 접근하는 switch-case문에서 사용되는 키워드
- 추가적인 case가 생겼을 때, 기존에 switch-case문에서 해당 case를 선언하지 않고 @unknown default로 선언해 놓으면 사용하는 쪽에서 warning 메시지를 받아볼 수 있어 인지할 수 있게끔 하는 키워드
- 그냥 default만 사용하면 어떤 새로 추가되는 case가 있는지 모르지만, @unlnown default를 사용하면 추가적인 case문이 있다고 warning메시지로 알려주는 기능
enum Color {
case blue(name: String, alpha: CGFloat)
case green(name: String, alpha: CGFloat)
case red
}
@frozen 개념)
- frozen: 얼은 상태 (enum 타입에서 case가 추가적으로 생겨나지 않을 것임을 명시)
- 컴파일러는 더욱 효율적으로 컴파일
- Library Evelolution mode가 안켜져있으면 키워들르 안써도 암묵적으로 모두 @frozen으로 생성
@frozen enum Color {
case blue(name: String, alpha: CGFloat)
case green(name: String, alpha: CGFloat)
case red
}
@frozen struct로 쓰는 경우 )
- frozen 어트리뷰트의 정의되로 타입이 더이상 늘어나지 않을것을 제한하는 것이므로, 라이브러리의 다음 버전에서 만약 @frozen이 붙은 struct에서 변경을하거나 제거하거나 프로퍼티의 순서를 변경하려고 하지 못하게 하는것
HSatck, VStack, ZStack 사용 방법
- HSTack, VStack, ZStack은 화면에서 보이지 않아도 모두 렌더링되므로, 가급적이면 subviews들이 적거나 의도적으로 lazy하게 뷰를 렌더링하고 싶지 않은 경우만 사용
- Lazy하게 사용해야하는 경우: ScrollView를 이용해서 현재 디바이스 화면에 보이지 않고, 스크롤해야 다른 뷰가 보일때 굳이 보이지 않는 뷰들은 렌더링을 미리 하지 않아도 되므로 스크롤될때 (뷰가 화면에 보이기 시작할때) 렌더링해주어야 효율적
- subviews들이 많은 경우는 아래에서 알아볼 LazyHStack, LazyVStack, LazyZStack 사용
- HStack은 아래 생성자를 이용하여 구현
@inlinable public init(
alignment: VerticalAlignment = .center,
spacing: CGFloat? = nil,
@ViewBuilder content: () -> Content
)
- 구현
var body: some View {
HStack(
alignment: .top,
spacing: 10
) {
ForEach(1...5, id: \.self) {
Text("Item \($0)")
}
}
}
- 보통 padding, border, font를 추가하여 사용
HStack(
alignment: .top,
spacing: 10
) {
ForEach(1...5, id: \.self) {
Text("Item \($0)")
}
}
.padding()
.border(Color.purple)
.font(.body)
- VStack도 동일하게 사용
VStack(
alignment: .trailing,
spacing: 10
) {
ForEach(1...5, id: \.self) {
Text("Item \($0)")
}
}
.padding()
.border(Color.purple)
.font(.body)
ZStack
- ZStack은 VStack, HStack을 생각하면 쉽게 이해 가능
- ZStack은 뷰 위쪽에 쌓는 것
- 뷰 위쪽에 손쉽게 레이아웃을 배치할 수 있는 장점이 있어서 사용
- 아래처럼 1 뷰 위에 2뷰가 오른쪽 상단에 위치하고 싶은 경우 ZStack을 사용하면 매우 편리
// ZStack의 속성을 trailing, top으로 해놓고, 1번 텍스트를 넣은 후 2번 텍스트를 넣으면 오른쪽 상단에 차곡차곡 쌓이는 것
struct SomeView: View {
var body: some View {
ZStack(alignment: Alignment(horizontal: .trailing, vertical: .top)) {
Text("1")
.font(.headline)
.frame(width: 300, height: 300, alignment: .center)
.border(Color.gray, width: 1)
Text("2")
.font(.title)
.frame(width: 100, height: 100, alignment: .center)
.border(Color.white, width: 1)
}
}
}
- 만약 하나 더 추가하면 2번의 오른쪽 상단에 추가
struct SomeView: View {
var body: some View {
ZStack(alignment: Alignment(horizontal: .trailing, vertical: .top)) {
Text("1")
.font(.headline)
.frame(width: 300, height: 300, alignment: .center)
.border(Color.gray, width: 1)
Text("2")
.font(.title)
.frame(width: 100, height: 100, alignment: .center)
.border(Color.white, width: 1)
Text("3") // <-
.font(.title)
.frame(width: 50, height: 50, alignment: .center)
.border(Color.white, width: 1)
}
}
}
LazyStack
- iOS 14부터 지원
- ScrollView과 Stack을 같이 쓸 때, ScrollView에 담겨있고 스크롤해야 보이는, 뷰를 처음에 모두 렌더링할 필요 없는 경우 효율성을 위해서 lazy하게 사용
ScrollView(.horizontal) {
LazyHStack(alignment: .top, spacing: 10) {
ForEach(1...100, id: \.self) {
Text("Column \($0)")
}
}
}
* 전체 코드: https://github.com/JK0369/ExStack-SwiftUI
* 참고
https://developer.apple.com/documentation/swiftui/lazyhstack
https://docs.swift.org/swift-book/ReferenceManual/Attributes.html
https://www.swift.org/blog/library-evolution/
'iOS 기본 (SwiftUI)' 카테고리의 다른 글
[iOS - SwiftUI] ForEach, ScrollView, DynamicViewContent (onDelete, onInsert, onMove) 사용 방법 (2) | 2022.08.26 |
---|---|
[iOS - SwiftUI] List 사용방법 (리프레시, multiSelection, Section, Hierarchical List, ListStyle) (0) | 2022.08.25 |
[iOS - SwiftUI] NavigationView, NavigationLink 사용 방법 (0) | 2022.08.23 |
[iOS - SwiftUI] Stepper 사용 방법 (0) | 2022.08.22 |
[iOS - SwiftUI] Slider 사용 방법 (0) | 2022.08.21 |
Comments