[공식문서로 iOS 배우기] UIKit Tutorial - 9. System Frameworks

Updated:

  • 공식 자료를 학습하고 정리했으며 잘못된 정보가 있을 수 있습니다.
  • 문서의 단순 번역은 경어체를, 직접 작성한 내용은 평어체를 사용합니다.
  • 원문: Apple Developer - iOS App Dev Tutorials - UIKit
  • GitHub에서 보기

📌 메모

배운 내용이나 메모는 소제목에 압정(📌) 이모지를 표시하여 작성하고 이곳에 링크합니다.




Chapter 9. System Frameworks

이벤트 저장소에 데이터를 저장할 때 Today 앱과 EventKit의 미리 알림을 동기화합니다.

Loading Reminders

EventKit 프레임워크는 사용자의 캘린더 이벤트와 미리 알림의 접근 권한을 제공합니다. EventKit을 사용하여 미리 알림 앱과 Today 앱 간에 데이터를 공유할 수 있습니다.

1. Request Access to User Data

캘린더 데이터베이스는 사용자의 캘린더와 미리 알림 데이터를 저장합니다. 앱이 데이터베이스에 접근하기 전에 반드시 사용자에게 허가를 받아야 합니다.

이 섹션에서는 데이터베이스의 항목을 쿼리하고 수정하는 데 사용하는 EKEventStore 오브젝트를 인스턴스화합니다. 그리고 이벤트 저장소를 통해 사용자의 미리 알림에 대한 접근을 요청합니다.

2. Load Reminders

이 섹션에서는 이벤트 저장소에서 미리 알림을 로드하는 메서드를 작성합니다. 저장소는 EKReminder 오브젝트의 옵셔널 배열을 반환하므로, ReminderListDataSource의 새 프로퍼티에 저장하기 전에 Reminder 오브젝트로 변환해야합니다.

📌 compactMap과 map의 차이

EKEventStore에서 fetchReminders로 가져온 EKReminders를 Today 앱의 미리 알림 모델인 Reminder로 변환할 때 compactMap을 사용했고 map 과의 차이점이 설명돼있다.

Step 8

Like map(:), the compactMap(:) method performs the given transformation with each element of the collection, but it also unwraps optionals, discarding any that are nil.

compactMap은 map과 비슷하지만, 옵셔널 언랩핑하여 반환한다는 차이가 있다. 이때 nil이 되는 경우는 폐기되므로 compactMap을 사용하면 nil이 아닌 collection을 반환한다.

3. Display Reminders

이 섹션에서는 저장소에서 미리 알림을 검색하고 화면에 표시합니다.

4. Responding to Notifications

Today 앱은 사용자가 앱을 실행할 때 이벤트 저장소에서 미리 알림을 로드합니다. 그러나 Today 앱이 동작하는 동안 다른 앱과 프로세스가 저장소를 업데이트할 수 있습니다.

앱의 최신 상태를 유지하기 위해 notification에 data source를 등록합니다. data source가 change notification을 받을 때마다 저장소에서 미리 알림 데이터를 다시 로드합니다.

📌 더 이상 사용되지 않는 옵저버 제거

더 이상 사용되지 않는 옵저버는 제거해 줘야 한다. 인스턴스가 메모리에서 해제될 때 시스템이 deinit()을 자동으로 호출해 주므로 옵저버로 등록한 클래스의 deinit()에서 옵저버를 제거해 주자.

Step 4

It’s your responsibility to remove observers when they’re no longer used. You can remove your class as an observer in its deinit method.

5. Check Your Understanding

Q1. 사용자의 캘린더와 미리 알림 데이터에 대한 접근을 제공하는 클래스는 무엇인가요?

A. EKEventStore

Q2. 앱이 미리 알림에 대한 접근권한을 물어볼 때 사용자가 “Dont’t Allow”를 탭하면 미리 알림에 대한 이벤트 저장소의 authorization status는 무엇인가요?

A. denied

Q3. 아래 코드 샘플에서 fetched의 타입은 무엇인가요?

let eventStore = EKEventStore()

func loadReminders() {
   let predicate = eventStore.predicateForReminders(in: nil)
   eventStore.fetchReminders(matching: predicate) { (fetched) in
      
   }
}

A. [EKReminder]?

Saving Reminders

Today 앱이 거의 완성됐지만 추가해야 하는 몇 가지 중요한 기능이 있습니다. 미리 알림을 저장해야 하고 무언가 잘못됐을 때 alert controller를 띄워야 합니다.

이 튜토리얼에서는 이벤트 저장소에 미리 알림을 저장하고 삭제합니다. 또한 저장 작업이 실패하면 사용자에게 alert controller를 띄웁니다.

1. Load a Specific Reminder

Today 앱은 내부의 미리 알림 모델을 사용하여 미리 알림을 보여줍니다. 이벤트 저장소에 미리 알림 데이터를 작성하기 전에 해당 EKReminder 오브젝트를 검색해야 합니다. 이 섹션에서는 지정된 identifier의 EKReminder 오브젝트를 검색하는 새 메서드를 작성합니다.

2. Save a Specific Reminder

이제 identifier로 EKReminder 오브젝트를 검색할 수 있습니다. 다음으로 이벤트 저장소에 미리 알림 데이터를 작성해야 합니다. 이 섹션에서는, 이벤트 저장소에 미리 알림 데이터를 저장하는 새 메서드를 작성합니다.

3. Update Reminder

이전 섹션에서 작성한 저장 메서드는 새 미리 알림을 작성하거나 기존 미리 알림을 업데이트할 때 작동합니다. 이 섹션에서는 새 저장 메서드를 호출하도록 update(_:at:) 메서드를 리팩토링합니다.

4. Create New Reminders

이 섹션에서는 이벤트 저장소에 새 미리 알림을 저장하도록 앱을 업데이트합니다.

5. Delete Reminders

이 섹션에서는 사용자가 table view에서 미리 알림을 삭제하기 위해 스와이프 할 때 이벤트 저장소에서 미리 알림을 제거하는 메서드를 추가합니다.

6. Implement Error Handling

이벤트 저장소의 변경이 성공했을 때만 앱이 table과 progress view를 업데이트합니다. 이 섹션에서는 작업이 실패했을 때 사용자에게 alert을 표시합니다.

7. Check Your Understanding

Q1. 앱에 이벤트 알림 시스템을 추가하는 간단한 방법은 무엇인가요?

A. Create an EKReminder with an array of EKAlarm objects.

Q2. 아래 UIAlertController을 만드는 controllerSyltedeletedActionStyle값은 무엇인가요?

// Set styles
//let controllerStyle: UIAlertController.Style =
//let deleteActionStyle: UIAlertAction.Style =

// Answer
let controllerStyle: UIAlertController.Style = .alert
let deleteActionStyle: UIAlertAction.Style = .destructive

let alert = UIAlertController(title: "Alert", message: "Message", preferredStyle: controllerStyle)
alert.addAction(UIAlertAction(title: "Delete", style: deleteActionStyle, handler: { _ in } ))
alert.addAction(UIAlertAction(title: "Update", style: .default, handler: { _ in } ))
self.present(alert, animated: true, completion: nil)

Continuing Your Learning

당신은 앱 개발 입문서를 완료하고 미리 알림과 통합된 현실적인 앱을 구축했습니다. 배운 내용을 복습하고 앞으로 무엇을 해야 할지 아이디어를 얻으세요.

1. What You’ve Learned

이 모듈을 통해 Today 앱을 구축하고 UIKit의 핵심에 대해 배웠습니다.

  • view controller를 사용하여 앱의 view 계층을 관리하고 view와 data source 간의 동작을 편성합니다.
  • table view에 여러 data soure를 지원하는 로직을 정의했습니다. 각 data sourece에 대한 로직을 캡슐화하는 베스트 사례를 따랐습니다.
  • 시스템에서 정의된 attribute를 적용하여 앱이 편하게 느껴지도록 했습니다. 그리고 앱을 Eventkit과 통합하여 데이터를 미리 알림과 동기화했습니다.

2. What’s Next?

다음은 학습을 계속하기 위한 몇 가지 리소스입니다.

3. Connecting with Others

  • Apple Developer Forum에서 동료 개발자, 멘토, 애플 엔지니어와 친해지세요. UIKit 태그를 검색하여 시작합니다.
  • [Swift community forums]에 합류하여 곧 나올ㄹ 언어 기능에 대해 논의하고 기여하세요.
  • 당신 지역의 iOS 개발자 밋업을 검색하세요.

4. Researching Design

  • Apple Design Awards Winners에서 애플 개발자 커뮤니티가 만든 아름다운 앱에서 영감을 얻으세요.
  • UIKit의 view, control, bar와 그 attribute가 어떻게 애플 디자인 원칙을 정립했는지 연구하며 Human Interface Guidelines에 익숙해지세요.

5. Creating More Apps

  • Apple Developer app을 다운로드하고 what’s new in UIKit and iOS를 받아보세요. 또한 Swift, testing, networking, 그리고 다른 다양한 주제에 대한 세션을 찾을 수 있습니다.
  • Mac Catalyst를 사용하여 macOS로 앱 마이그레이션을 시도하세요.
  • Apple Developer Documentation을 읽고 다음 프로젝트를 위한 영감을 찾거나 샘플 코드 프로젝트를 살펴보세요.
  • Today 앱에 새 기능을 추가하기 위해 스스로 도전하세요. Scrumdinger에서 배웠던 것을 적용하고 사용자가 미리 알림을 완료했을 때 AVFoundation으로 사운드를 재생하세요.

Leave a comment