iOS ๐ŸŽ/SwiftUI

Definition @resultBuilder struct ViewBuilder ํด๋กœ์ €์—์„œ ๋ทฐ๋ฅผ ๊ตฌ์„ฑํ•˜๋Š” ์‚ฌ์šฉ์ž ์ง€์ • ํŒŒ๋ผ๋ฏธํ„ฐ ์†์„ฑ func contextMenu( @ViewBuilder menuItems: () -> MenuItems ) -> some View ํด๋กœ์ € ํŒŒ๋ผ๋ฏธํ„ฐ๋ฅผ ํ†ตํ•ด child view๋ฅผ ์ƒ์„ฑํ•˜๊ณ ์ž ํ•  ๋•Œ ViewBuilder๋ฅผ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค. ์œ„์™€ ๊ฐ™์ด ํŒŒ๋ผ๋ฏธํ„ฐ๋กœ ViewBuilder๋ฅผ ์‚ฌ์šฉํ•ด ํด๋กœ์ €๋กœ child view๋ฅผ ํฌํ•จํ•˜๋Š” ๋ทฐ๋ฅผ ์ƒ์„ฑํ•  ์ˆ˜ ์žˆ๋‹ค. myView.contextMenu { Text("Cut") Text("Copy") Text("Paste") if isSymbol { Text("Jump to Definition") } } contextMenu์˜ menuItems ํด..
ํฐํŠธ๋Š” ํ”„๋ฆฌํ…๋‹ค๋“œ ์‚ฌ์šฉํ•จ (์‚ฌ์ดํŠธ๋งํฌ) Pretendard Pretendard ํ”„๋ฆฌํ…๋‹ค๋“œ Pretendard ํ”„๋ฆฌํ…๋‹ค๋“œ ๊ธ€๊ผด ๋‹ค์šด๋กœ๋“œ ์ผ๋ณธ์–ด ๋ฒ„์ „ ๋‹ค์šด๋กœ๋“œ GitHub์—์„œ ๋ณด๊ธฐ system-ui๋ฅผ ๋Œ€์ฒดํ•˜๋Š” ๊ธ€๊ผด Apple์˜ system-ui๊ฐ€ ์ต์ˆ™ํ•œ ๋‚˜๋กœ์„œ๋Š” San Francisco์™€ Apple SD ์‚ฐ๋Œ๊ณ ๋”• Neo๊ฐ€ ์—†๋Š” cactus.tistory.com ๊ธ€๊ผด ๋‹ค์šด๋กœ๋“œ๋ฅผ ๋ˆŒ๋Ÿฌ์„œ ๋งฅ์— ์ €์žฅ ํ”ผ๊ทธ๋งˆ์—์„œ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•ด ๊ฐ ํ•ญ๋ชฉ์„ ๋”๋ธ” ํด๋ฆญํ•ด์„œ ์„ค์น˜ Figma ํ…์ŠคํŠธ๋ฅผ ์ถ”๊ฐ€ํ•œ ํ›„ ํฐํŠธ, ํฐํŠธ์˜ ๊ตต๊ธฐ, ์ž๊ฐ„, ํ–‰๊ฐ„์„ ์ง€์ • ๊ทธ ํ›„ Text ์˜†์— ์  ๋„ค๊ฐœ ์•„์ด์ฝ˜ ํด๋ฆญ ํ…์ŠคํŠธ ์Šคํƒ€์ผ ๋ฉ”๋‰ด๊ฐ€ ๋‚˜์˜ค๋ฉด + ๋ฒ„ํŠผ์„ ๋ˆŒ๋Ÿฌ ์ƒˆ๋กœ์šด ํ…์ŠคํŠธ ์Šคํƒ€์ผ์„ ๋“ฑ๋ก ์ƒˆ๋กœ์šด ํ…์ŠคํŠธ ์Šคํƒ€์ผ์˜ ์ด๋ฆ„์„ ์ง€์ •ํ•œ ๋’ค create style์„ ๋ˆŒ๋Ÿฌ ์ €์žฅ..
Attributed ํ…์ŠคํŠธ๋‚˜ ๋ณ„๋‹ค๋ฅธ ์ฝ”๋“œ ์—†์ด ๋ฐ‘์ค„, ํ•˜์ดํผ๋งํฌ ์ด๋™์„ ์ž‘์„ฑํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. struct LinkView: View { var body: some View { Link("๋„ค์ด๋ฒ„๋กœ ์ด๋™", destination: URL(string: "https://naver.com")!) } } Link๋ผ๋Š” ๋ทฐ๋ฅผ ์ด์šฉํ•˜๋ฉด ํ™”๋ฉด์— ๋ณด์ผ ํ…์ŠคํŠธ์™€ ์ด๋™ํ•  ์›น์‚ฌ์ดํŠธ ์ฃผ์†Œ๋ฅผ ์‰ฝ๊ฒŒ ์ž‘์„ฑํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. Link("๋„ค์ด๋ฒ„๋กœ ์ด๋™", destination: URL(string: "https://naver.com")!) .fontWeight(.heavy) .foregroundStyle(.green) ํฐํŠธ์˜ ๋ณ€๊ฒฝ๋„ ์‰ฝ์Šต๋‹ˆ๋‹ค. ๋งŒ์•ฝ ์‚ฌ์šฉ์ž์—๊ฒŒ ์ด๊ฒƒ์ด ๋‹จ์ˆœ ํ…์ŠคํŠธ๊ฐ€ ์•„๋‹Œ ํ•˜์ดํผ๋งํฌ ์ด๋™์ด๋ผ๋Š” ๊ฒƒ์„ ์ธ์ง€ ์‹œ์ผœ ์ฃผ๊ณ  ์‹ถ์€ ๊ฒฝ์šฐ ..
bottom card view, botton sheet ๋“ฑ ์šฉ์–ด๊ฐ€ ๋งŽ์€๋ฐ modifier์˜ ์ด๋ฆ„์€ sheet์ž…๋‹ˆ๋‹ค @State private var isShowingSheet: Bool = false ํ™”๋ฉด์— sheet์œผ๋กœ ๋„์šธ view๋ฅผ ๋ณด์—ฌ์ค„์ง€ ์—ฌ๋ถ€๋ฅผ ์œ„ํ•ด State๋ฅผ ํ•˜๋‚˜ ์„ ์–ธํ•ด ์ค๋‹ˆ๋‹ค. false์ด๋ฉด ํ™”๋ฉด์— ๋ณด์ด์ง€ ์•Š๊ฒŒ ๋˜๊ณ , true์ด๋ฉด ํ•˜๋‹จ์— sheet ํ˜•ํƒœ๋กœ view๊ฐ€ ๋ณด์ด๊ฒŒ ๋ฉ๋‹ˆ๋‹ค. Button { isShowingSheet.toggle() print(isShowingSheet) } label: { Text("๋ฐ”ํ…€์‹œํŠธ ๋„์šฐ๊ธฐ") } isShowingSheet ๊ฐ’์„ ๋ฐ”๊พธ๊ธฐ ์œ„ํ•œ Button์„ ํ•˜๋‚˜ ๋งŒ๋“ญ๋‹ˆ๋‹ค. ๋ฒ„ํŠผ์„ ๋ˆ„๋ฅด๋ฉด isShowingSheet ์„ ํ† ๊ธ€ํ•ด ์ค๋‹ˆ๋‹ค. .sheet(isPrese..
UIKit์—์„œ AVKit์˜ AVPlayer๋ฅผ ์‚ฌ์šฉํ•ด์„œ ๋™์˜์ƒ์„ ๋ณด์—ฌ ์ค„ ์ˆ˜ ์žˆ์—ˆ์Šต๋‹ˆ๋‹ค. SwiftUI์—์„œ ๋™์˜์ƒ์„ ํ™”๋ฉด์— ๋ณด์—ฌ์ฃผ๊ณ  ์ปจํŠธ๋กค ํ•˜๊ธฐ ์œ„ํ•ด์„œ๋Š” UIViewControllerRepresentable์„ ์‚ฌ์šฉํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. UIKit์˜ UIViewController๋ฅผ SwiftUI์˜ View๋กœ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•ด UIViewControllerRepresentable์„ ์ฑ„ํƒํ•˜๋Š” struct๋ฅผ ์ƒ์„ฑํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. View๊ฐ€ ํ™”๋ฉด์— ๋ณด์ด๋ฉด ์ž๋™์œผ๋กœ ๋™์˜์ƒ์ด ์‹คํ–‰๋˜๋Š” ๊ฐ„๋‹จํ•œ ์˜ˆ์ œ์ž…๋‹ˆ๋‹ค. import SwiftUI import AVKit struct VideoPlayerView: UIViewControllerRepresentable { /// ์™ธ๋ถ€์—์„œ AVPlayer์˜ ์ƒํƒœ๋ฅผ ๋ณ€๊ฒฝํ•˜๊ฑฐ๋‚˜ ์•ก์„ธ์Šคํ•  ์ˆ˜ ์žˆ์Œ @Bindin..
previews๋ž€? ์ฝ”๋“œ๊ฐ€ ๋ณ€๊ฒฝ๋˜๋ฉด ์บ”๋ฒ„์Šค์— ๋””์ž์ธ๊ณผ ๋ ˆ์ด์•„์›ƒ์ด ์‹ค์‹œ๊ฐ„์œผ๋กœ ๋ณ€๊ฒฝ๋˜๋Š” ๊ฒƒ์„ ํ™•์ธ ํ•  ์ˆ˜ ์žˆ๋‹ค. ์ด ๋ฏธ๋ฆฌ๋ณด๊ธฐ ๊ธฐ๋Šฅ์„ ์ œ๊ณต ์บ”๋ฒ„์Šค์—์„œ ์ธํ„ฐ๋ ‰์…˜์„ ์ง€์›ํ•จ. ๋ฒ„ํŠผ ํด๋ฆญ์‹œ print๋ฌธ์„ ์‚ฌ์šฉํ•ด์„œ ์ฝ˜์†”์— ๋กœ๊ทธ๋ฅผ ์ฐ๋Š” ๊ฒƒ๋„ ๊ฐ€๋Šฅ ๋‹ค์–‘ํ•œ ๋””๋ฐ”์ด์Šค ํƒ€์ž… ์ง€์› ๋‹คํฌ ๋ชจ๋“œ ํ™•์ธ ๊ฐ€๋Šฅ ๋ทฐ ์‚ฌ์ด์ฆˆ์— ๋งž๋„๋ก ์กฐ์ ˆํ•ด์„œ ๋ทฐ์˜ ๋ชจ์–‘์„ ํ™•์ธ ํ•  ์ˆ˜ ์žˆ์Œ static var previews: some View { HikeCustomButtonView() .previewLayout(.sizeThatFits) .padding() } ์บ”๋ฒ„์Šค์—์„œ ๋งˆ์šฐ์Šค ์ปค์„œ ๋ชจ์–‘์„ ๋ˆŒ๋Ÿฌ์ฃผ๋ฉด ํ”„๋ ˆ์ž„(๋ฒ ์ ค)์ด ์ œ๊ฑฐ๋œ ๋ฏธ๋ฆฌ๋ณด๊ธฐ ํ™”๋ฉด์ด ์บ”๋ฒ„์Šค์— ๋‚˜ํƒ€๋‚ฉ๋‹ˆ๋‹ค.
@inlinable public func foregroundStyle(_ style: S) -> some View where S : ShapeStyle foregroundStyle์„ ์‚ฌ์šฉํ•ด์„œ Color, ShapeStyle์„ ์ง€์ •ํ•  ์ˆ˜ ์žˆ์Œ @frozen public struct LinearGradient : ShapeStyle, View LinearGradient๋Š” ShapeStyle๋กœ์„œ ๊ทธ๋ž˜๋””์–ธํŠธ์˜ ๋ฐฉํ–ฅ๊ณผ ์ƒ‰์ƒ์„ ์ง€์ •ํ•  ์ˆ˜ ์žˆ๋‹ค. ex) .foregroundStyle( LinearGradient(colors: [.pink, .purple, .blue], startPoint: .topLeading, endPoint: .bottomTrailing) ) colors์—๋Š” ์ƒ‰์ƒ์„ ์ง€์ •ํ•ด ์ฃผ๋ฉด ๋˜๋ฉฐ ์ธ๋ฑ์Šค 0๋ฒˆ..
์ฐธ๊ณ  ์‚ฌ์ดํŠธ ๋ฐ ์ถœ์ฒ˜ https://www.youtube.com/watch?v=ZQXzZ1hxQwo ์œ„ ์›๋ณธ ์˜์ƒ์„ ์ฐธ๊ณ  ํ•˜์‹œ๋ฉด ๋” ์ž์„ธํžˆ ์•Œ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค! ์œ„ ์˜์ƒ์ด ์žˆ์–ด ํ•ด๋‹น ํฌ์ŠคํŒ…์€ ๊ณต๋ถ€ํ•˜๋‹ค ์•Œ๊ฒŒ๋œ ์ ๋งŒ ์ ์–ด ๋†“์•˜์Šต๋‹ˆ๋‹ค. NavigationLink NavigationLink๋ฅผ ์‚ฌ์šฉํ•˜๋ฉด ๋„ค๋น„๊ฒŒ์ด์…˜ ์Šคํƒ์„ ์Œ“์„ ์ˆ˜ ์žˆ์Œ NavigationView { VStack { NavigationLink(value: , label: View#>) } .padding() } value ๋Š” ์ด๋™ ์‹œํ‚ค๊ธฐ ์œ„ํ•ด ๋งํฌ๋ฅผ ๊ฑธ ๋ทฐ, label์€ ์Šคํƒ์œผ๋กœ ์Œ“์„ ๋ทฐ๋ฅผ ํด๋กœ์ €๋กœ ์ „๋‹ฌ NavigationView { VStack { NavigationLink { Text("๋‘ ๋ฒˆ์งธ ๋ทฐ") } label: { Text("์ฒซ ๋ฒˆ์งธ ๋ทฐ") ..
fram
'iOS ๐ŸŽ/SwiftUI' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๊ธ€ ๋ชฉ๋ก (2 Page)