WWDC 23 Swift Student Challenge 수상하였습니다. (Award Recipient)

소개 이번에 애플에서 주최한 WWDC23 Swift Student Challenge(스위프트 스튜던트 챌린지)에 응모하였는데 운이 좋아서 수상하였습니다. 영어로 Award Recipient라고 나와있는데 비공식 용어로는 Winner로 일컫기도 합니다. 사실 작년까지는 이런 공모전이 있는지도 몰랐는데 올해 어떻게 정보를 알게되어 응모하게 되었습니다. Student Challenge에 대한 자세한 내용은 https://developer.apple.com/kr/wwdc23/swift-student-challenge/ 에서 볼 수 있습니다. 이름은 Interval Fairy라는 앱으로, 제작기간은 더보기…

SwiftUI: 웹 뷰(WKWebView) 추가하기 및 자바스크립트 실행 (Representable 사용)

소개 SwiftUI 내부에 웹 뷰(WKWebView)를 추가하는 방법입니다. 원래 웹 페이지를 표시하는 WKWebView는 UIKit과 호환되는 요소인데, 찾아본 결과 SwiftUI에는 웹을 표시할 수 있는 뷰가 없는 것처럼 보여서 역시 Representable을 이용해서 간접적으로 추가하는 방법을 설명하겠습니다.   방법 두 가지 방법을 알아보겠습니다. 단순히 SwiftUI에 웹 뷰를 추가하는 방법입니다. 위 예제의 웹 뷰에서 evaluateJavaScript(_:)를 더보기…

SwiftUI: 하드웨어 키보드 입력 받기 (Representable 사용)

소개 SwiftUI 앱에서 하드웨어 키보드의 입력을 받는 방법입니다. 여기서 하드웨어 키보드란 iOS/iPadOS 환경에서는 USB 키보드, 블루투스 키보드, 액세서리 키보드 등을 뜻하며, Mac Catalyst/M시리즈 CPU 등 맥 환경에서 실행되는 경우에는 노트북의 키보드, 유선 키보드, 블루투스 키보드 등을 뜻합니다. 하드웨어 키보드의 입력에 대한 처리란 이런 키보드에서 키를 눌렀을 때 해야할 작업을 뜻합니다. 더보기…

SwiftUI: 내비게이션 (Navigation) 및 데이터 전달 기초

소개 SwiftUI상에서 내비게이션 (앞, 뒤로 이동하는 뷰들의 집합)을 구현하는 방법입니다. 참고로 iOS 16.0을 기준으로 방법이 매우 다릅니다. 아래와 같은 앱을 만들 것입니다. 3단계 내비게이션이 마련되어 있으며 첫 번째 버튼을 누르면 두 번째 화면으로 이동하며 임의의 색상과 그 색상에 대한 텍스트가 표시됩니다. 두 번째 화면에서는 Go to Jacob Link가 있으며 이 더보기…

SwiftUI: Swift Playgrounds App에서 커스텀 폰트 추가 및 적용

개요 Swift Playgrounds App에서 커스텀 폰트 적용 및 사운드 파일 추가 참고로 여기서 Swift Playgrounds App이란 다음과 같이 Xcode에서 File > New > Project… iOS > Swift Playgrounds App 으로 생성한 프로젝트 및 앱을 뜻합니다.   커스텀 폰트 추가 1) Resources 폴더안에 폰트 파일을 추가합니다. 해당 폴더가 없다면 새로 생성합니다. 더보기…

SwiftUI (Swift Playgrounds App)으로 만든 앱: Chord Diary (코드 감정 기록기)

개요 음악 코드(화음)으로 현재의 감정을 기록해 보세요. 글을 등록하면 코드 음을 재생할 수 있고 해당 코드에 대한 정보도 볼 수 있습니다. (scales-chords.com 사이트 이용)   목적 SwiftUI의 기초 학습 및 상태 관리 학습 목적으로 만들었습니다.   사용 기술 SwiftUI 부분적으로 UIKit 도입 (Representable 사용) Swift Playgrounds App   특징 UserDefaults를 더보기…

SwiftUI: Spacer (스페이서) – 공백 표시 뷰

소개 SwiftUI에서, 스페이서(Spacer)는 공백을 표시하는 View입니다. VStack, HStack에서 사용할 수 있습니다.   참고) ZStack에서도 코드는 동작하지만 ZStack은 Z축의 스택이기 때문에 아래처럼 겹쳐 보입니다. struct StacksView: View { var body: some View { ZStack { Text(“가나다”) Spacer() Text(“ABC”) } } }   Spacer의 기본 사용법 HStack { Text(“가나다”) Spacer() Image(systemName: “play.fill”) 더보기…

SwiftUI: @State와 @Binding의 의미 / 뷰 간의 데이터 전송 (앞→뒤, 뒤→앞)

@State 뷰 계층 구조(view hierarchy)에서 데이터를 저장할 수 있도록 상태(state)를 지정할 때 사용합니다. 변수 앞에 @State를 붙입니다.   UIKit 을 사용했을 때는 어떠한 변수에 변화가 생기면 해당 변화를 직접 관찰하고 반영 해 주어야 했는데 SwiftUI 에서는 property wrapper 를 활용해 이러한 작업을 자동화 할 수 있도록 했다. 변화가 생기면 해당 더보기…

Swift(스위프트): 오디오 라이브러리 AudioKit 프레임워크 소개

AudioKit iOS, macOS 및 tvOS용 Swift 오디오 합성, 처리 및 분석 플랫폼   개요 AudioKit은 코드 저장소, 패키지, 라이브러리, 알고리즘, 애플리케이션, 플레이그라운드, 테스트, 스크립트로 구성된 전체 오디오 개발 생태계(audio development ecosystem)로, 오디오 프로그래머, 앱 개발자, 엔지니어, 연구원, 과학자, 음악가, 게이머 및 프로그래밍을 처음 접하는 사람들의 커뮤니티에 의해 구축되고 사용되는 프레임워크입니다. 더보기…

SwiftUI: Representable을 이용해서 UIViewController 띄우기

소개 SwiftUI 환경에서 UIKit을 이용해 만든 UIViewController를 띄우는 방법에 대한 소개입니다. 예를 들어, MPMediaPickerController (import MediaPlayer 필요)는 UIViewController를 상속받은 뷰 컨트롤러인데 UIKit 환경에서는 self.present(viewController, …)로 바로 띄울 수 있습니다. SwiftUI에서도 이 작업이 가능하지만 복잡한 과정이 필요합니다.   방법 1: UIViewControllerRepresentable을 준수하는 구조체 생성 아래와 같이 UIViewControllerRepresentable를 준수(conform)하는 구조체(struct)를 생성합니다. UIViewControllerRepresentable는 더보기…