일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 상호배제
- 데드락
- 앨런
- 비동기
- Apple Developer Academy
- forEach
- 알고리즘
- struct
- COLOR
- SwiftUI
- core data
- 동시성
- Swift
- 오브젝트
- decode
- IOS
- Algorithm
- scrollview
- UserDefaults
- async
- @state
- 인프런
- 운영체제
- Linked List
- Codable
- deadlock
- 동기화
- 프로세스 스케줄링
- 가상 메모리
- 100 days of SwiftUI
Archives
- Today
- Total
기어가더라도 제대로
[SwiftUI-기초] Scrolling Grid 본문
수직그리드
- 엑셀에 보면 row와 column 으로 나뉜것과 같은 효과를 줄 수 있는 View 입니다.
struct ContentView: View {
let layout = [
GridItem(.fixed(80)),
GridItem(.fixed(80)),
GridItem(.fixed(80))
]
var body: some View {
ScrollView {
LazyVGrid(columns: layout) {
ForEach(0..<1000) {
Text("Item \($0)")
}
}
}
}
}
- 특이점으로는 기본적으로 Lazy Grid를 사용한다는점..
- 그리고 몇개의 컬럼이 필요할지, 몇개의 로우가 필요할지를 Layout 으로 잡는 다는 점 이외에는 똑같습니다.
가변폭 그리드
- 근데 보면 layout 의 아이템으로 gridItem(.fixed(80)) 이라는 것이 있는데요.
- 한 칸이 80 너비를 사용한다고 보입니다.
- 그런데 말입니다.. 이렇게 고정된 값을 사용하면, 별로 좋지않아요. 기기마다 화면의 크기가 제각각인데 일관된 뷰를 그릴수 없게 됩니다.
let layout = [
GridItem(.adaptive(minimum: 80)),
]
- 이런식으로 적응형으로 선언할 수도 있습니다.
- "최소한 80은 되어야한다" 고 선언하는 것이죠.
let layout = [
GridItem(.adaptive(minimum: 80, maximum: 120)),
]
- 이렇게도 선언할 수 있습니다.
- "최소 80은 보장하고, 최대로 120 이상 넘을 순 없다"
수평 그리드
- 수직으로 그리드를 그린다면 당연히 수평으로도 그릴수 있습니다.
ScrollView(.horizontal) {
LazyHGrid(rows: layout) {
ForEach(0..<1000) {
Text("Item \($0)")
}
}
}
- lazyHGrid 줄에 column 대신 row 로 변경된것도 깨알이네요.
- LazyVGrid -> LazyHGrid
- ScrollView 옆에 .horizontal 도 붙어줬네요.
'SwiftUI - 기초' 카테고리의 다른 글
[SwiftUI-기초] Shape, 도형 (0) | 2022.11.15 |
---|---|
[SwiftUI-기초] path (0) | 2022.11.14 |
[SwiftUI-기초] 계층적인 Codable 데이터 다루기 (0) | 2022.11.10 |
[SwiftUI-기초] NavigationLink (0) | 2022.11.09 |
[SwiftUI-기초] ScrollView, Stack, Lazy Stack (0) | 2022.11.08 |
Comments