HP Trivia (5)
Books & Questions 이번 강의에서는 HP Trivia 앱의 Settings 화면(도서 선택 화면) 구성을 준비하기 위한 기초 작업을 시작한다. 사용자가 퀴즈에서 출제될 도서를 선택할 수 있도록 UI를 만들 예정인데, 실제 뷰(View)를 구현하기 전에 이를 뒷받침할 데이터 모델(Book)과 관련 클래스부터 정리할 필요가 있다. ...
Books & Questions 이번 강의에서는 HP Trivia 앱의 Settings 화면(도서 선택 화면) 구성을 준비하기 위한 기초 작업을 시작한다. 사용자가 퀴즈에서 출제될 도서를 선택할 수 있도록 UI를 만들 예정인데, 실제 뷰(View)를 구현하기 전에 이를 뒷받침할 데이터 모델(Book)과 관련 클래스부터 정리할 필요가 있다. ...
Single Responsibility Principle 이전 글에서 간단히 언급했던 부분이지만, 이번엔 이 주제를 조금 더 구체적으로 짚고 넘어가려 한다. 현재 ContentView를 보면 모든 UIComponents를 직접 작성하여 코드의 가독성이 상당히 떨어지고 있다. 이제 View들을 새롭게 파일을 만들어서 코드를 옮김으로써 유지, 보수에...
Custom Animations 지난 글에서는 AVAudioPlayer를 활용해 사운드를 재생하고, transition 애니메이션과 함께 청각적 몰입감을 더하는 방법을 구현했다. 이번 글에서는 SwiftUI에서 사용자 정의 애니메이션(Custom Animations)을 통해 보다 세밀하고 생동감 있는 시각 효과를 만들어보려 한다. 참고로 이...
Audio 이제 이전 글에서 구현한 transition animation 효과에 맞춰 사운드를 재생시켜, 유저에게 시각뿐 아니라 청각적으로도 몰입감을 줄 수 있도록 해보려 한다. import AVKit @State private var audioPlayer: AVAudioPlayer! .onAppear { animateViewsIn = ...
📁 Folder vs Group (Xcode) 항목 Folder (파란색) Group (회색) 기본 적용 버전 Xcode 16부터 기본 Xcode 15 이하에서 기본 파일 시스템 반영 실제 macOS...
Predicate 수정 CoreData에서 SwiftData로의 마이그레이션을 마치며 기본적인 구조와 동작 오류는 대부분 해결했다. 하지만 실제 앱에서 데이터를 “조건에 맞게 필터링”하는 기능, 즉 Predicate는 아직 손대지 않은 상태이다. 이번 글에서는 SwiftData에서 predicate를 어떻게 사용하는지, 기존 방식과 어떤 차이가 있...
SwiftData 사용하기 Migration 하기 사실 이전에도 CoreData → SwiftData 마이그레이션 작업을 진행한 적이 있다. 이전글 참고. SwiftData 모델을 만들기 위해 Editor 메뉴에서 Create SwiftData Model을 실행하면, 다음과 같이 자동 생성된 코드가 나타난다: 예시: @Model public ...
Appgroup AppGroup 역시 이전에 다뤄봤던 내용이다. 이전글 참고. App Group 설정 및 권한 부여 Widget도 동일하게 해주자. 이렇게 추가해주면 된다. 효율적인 파일 관리를 위해 새롭게 추가된 Extension.entitlements 파일도 아래로 옮겨주자. 이때 발생하는 에러 해당 문제를 해결하기위해...
Widget UI Design 이제 디자인을 해보려고한다 디자인은 이렇게 할 것이다. UI구성은 지난글에서도 정리했지만 WidgetEntryView가 담당한다 struct DexWidgetEntryView : View { var entry: Provider.Entry var body: some View { VS...
WidgetKit으로 홈 화면에 포켓몬 위젯 표시하기 Widget 만들기 앱을 실행하지 않아도 정보를 확인할 수 있게 하려면 Widget이 필요하다. 이번 글에서는 WidgetKit을 사용해 포켓몬 정보를 아래 사진처럼 홈 화면에서 바로 볼 수 있도록 위젯을 만들어본다. 이것도 역시 전에 공부를 했던 적이 있기에 WidgetKit 지난글을 참...