본문 바로가기

iOS/STUDY

[iOS] Photos

iOS 및 tvOS에서 iCloud 사진 라이브러리를 포함하여 사진 및 비디오에 직접 접근하기 위한 프레임워크

 

Collection List > Asset Collection > Asset

 

Photos 라이브러리 상호작용

PHPhotoLibrary 객체를 사용하여 사진 콘텐츠에 접근하고, 에셋 및 컬렉션을 변경할 수 있도록 애플리케이션의 사용자 권한을 얻습니다. 권한을 얻으면 사진 라이브러리가 변경될 때 변경사항을 전달받을 수도 있습니다.

 

  • PHPhotoLibrary: 사용자의 사진 라이브러리에 대한 접근 및 변경을 관리하는 공유 객체

 

 

에셋 검색과 조사

이 모델 클래스는 사진 라이브러리의 콘텐츠(에셋, 컬렉션)을 나타냅니다. 읽기 전용이며 변경 불가능하며 메타 데이터만 포함합니다. 에셋과 컬렉션을 사용하려면 이 클래스를 사용하여 지정한 쿼리와 일치하는 객체를 가져옵니다.

 

  • PHAsset: 사진 라이브러리의 이미지, 비디오, 라이브 포토
  • PHAssetCollection: 특별한 순간, 사용자 정의 앨범 또는 스마트 앨범과 같은 사진, 에셋 그룹을 나타냅니다.
  • PHCollectionList: 특별한 순간, 사용자 정의 앨범, 특별한 순간들 연도와 같은 에셋 컬렉션이 포함된 그룹을 나타냅니다.
  • PHCollection: 에셋 컬렉션 및 컬렉션 리스트의 추상 슈퍼 클래스
  • PHObject: 모델 객체(에셋 및 컬렉션)의 추상 슈퍼 클래스
  • PHFetchResult: 가져오기 메서드에서 반환된 에셋 또는 컬렉션의 정렬된 목록
  • PHFetchOptions: 에셋 또는 컬렉션 객체를 가져올 때 Photos에서 반환하는 결과에 필터링, 정렬 등 영향을 주는 옵션

 

에셋 콘텐츠 로딩

이 클래스를 사용하여 이미지, 비디오, 라이브 포토 콘텐츠를 요청할 수 있습니다.

 

  • PHImageManager: 미리보기 썸네일 및 에셋과 전체 크기의 이미지 또는 비디오 데이터를 검색하거나 생성하는 방법을 제공합니다.
  • PHCachingImageManager: 많은 에셋을 일괄적으로 미리 로딩하기 위해 최적화된 에셋과 관련된 섬네일 및 전체 크기의 이미지 또는 비디오 데이터를 검색하거나 생성하는 방법을 제공합니다.
  • PHImageRequestOptions: 이미지 매니저로부터 요청한 에셋 이미지에 영향을 주는 옵션들입니다.
  • PHVideoRequestOptions: 이미지 매니저로부터 요청한 비디오 에셋 데이터에 영향을 주는 옵션들입니다.
  • PHLiveOhotoRequestOptions: 이미지 매니저로부터 요청한 라이브 포토 에셋에 영향을 주는 옵션들입니다.
  • PHLivePhoto: 캡처 직전과 직후 순간의 움직임 및 소리가 포함된 라이브 사진을 표현합니다.

 

변경 요청

에셋이나 컬렉션을 변경하려면 변경 요청 객체를 만들고 명시적으로 사진 라이브러리에 반영합니다. 이 방법을 사용하면 여러 스레드 또는 여러 애플리케이션 및 애플리케이션 확장에서 같은 에셋을 가지며 쉽고, 안전하며 효율적으로 작업할 수 있습니다.

 

  • PHAssetChangeRequest: 사진 라이브러리 변경 블록(클로저)에서 사용하기 위해 에셋의 생성, 삭제, 메타 데이터 수정할 변경 요청 객체 입니다.
  • PHAssetCollectionChangeRequest: 사진 라이브러리 변경 블록(클로저)에서 사용하기 위해 에셋 컬렉션을 생성, 삭제, 수정할 변경 요청 객체입니다.
  • PHCollectionListChangeRequest: 사진 라이브러리 변경 블록(클로저)에서 사용하기 위해 컬렉션 리스트 생성, 삭제, 수정할 변경 요청 객체입니다.

 

 

에셋 콘텐츠 수정

애플리케이션 또는 확장 프로그램에서 이 클래스들을 사용하여 사진 라이브러리의 편집 및 반영을 위해 에셋 데이터에 접근합니다. 사진들은 각 수정 사항을 버전별로 에셋 및 보정 데이터를 관리 하므로 애플리케이션 또는 확장 프로그램을 사용하여 다른 기기에서도 이전에 수정한 내용을 되돌리거나 계속 사용할 수 있습니다. 사진 편집 확장기능을 만들려면 이 클래스들과 PhotosUI 프레임워크와 같이 사용하세요.

 

  • PHContentEditingInput: 편집할 에셋의 이미지, 비디오, 라이브 포토의 콘텐츠에 대한 정보와 접근 권한을 제공하는 컨테이너 입니다.
  • PHContentEditingOutput: 에셋의 사진, 비디오, 라이브 포토의 콘텐츠를 편집한 결과를 제공한는 컨테이너 입니다.
  • PHAdjustmentData: 편집 효과를 재구성하거나 되돌릴 수 있는 에셋의 사진, 비디오, 라이브 포토 콘텐츠의 수정사항에 대한 설명입니다.

 

 

AdjustmentDate (필터?)

 

  • PHContentEditingInputRequestOptions: 에셋의 콘텐츠를 수정하도록 요청할 때 이미지, 비디오 데이터전송에 영향을 주는 옵션입니다.
  • PHLivePhotoEditingContext: 라이브 포토의 사진, 비디오, 오디오 콘텐츠를 수정하기 위한 편집 세션입니다.
  • PHLivePhotoFrame: 편집 컨텍스트에서 라이브 포토의 단일 프레임에 대한 이미지 콘텐츠를 제공하는 컨테이너 입니다.

 

 

변경사항 관찰

Photos 프레임워크는 다른 애플리케이션이나 다른 기기에서 사진의 정보를 변경할 때마다 애플리케이션에 알려줍니다. 이러한 객체는 변경 전후의 객체 상태에 대한 정보를 제공하므로 사용자 인터페이스를 쉽게 업데이트하여 일치시킬 수 있습니다.

 

  • PHPhotoLibraryChangeObserver: 사진 라이브러리에서 발생한 변경사항을 알리기 위해 구현할 수 있는 프로토콜입니다.
  • PHChange: 사진 라이브러리에서 발생한 변경사항에 대한 설명입니다.
  • PHObjectChangeDetails: 에셋 또는 컬렉션 객체에서 발생한 변경사항에 대한 설명입니다.
  • PHFetchResultChangeDetails: 가져오기 결과에 나열된 에셋 또는 컬렉션 객체에서 발생한 변경사항에 대한 설명입니다.

 

에셋 리소스로 작업하기

에셋 리소스 객체는 각 에셋의 데이터 저장소를 나타냅니다. 이러한 객체를 사용해 에셋을 직접 백업하고 복원할 수 있습니다.

 

  • PHAssetResource: 사진 라이브러리의 사진, 비디오, 라이브 포토 에셋과 관련된 기본 데이터 리소스입니다.
  • PHAssetCreationRequest: 사진 라이브러리 변경 블록(클로저)에서 사용하기 위해 기본 데이터 리소스에서 새로운 에셋을 생성하라는 요청.
  • PHAssetResourceCreationOptions: 기본 리소스에서 새로운 에셋을 만드는데 영향을 주는 옵션들입니다.
  • PHAssetResourceManager: 에샛과 관련된 리소스에 대한 기본 데이터 저장소에 접근하는 방법을 제공합니다.
  • PHAssetResourceRequestOptions: 에셋 리소스 관리자가 요청한 기본 에셋 데이터 전달에 영향을 주는 옵션입니다.

 

 

https://developer.apple.com/documentation/photokit

 

Apple Developer Documentation

 

developer.apple.com

 

 

출처: 부스트코스 iOS 앱 프로그래밍

'iOS > STUDY' 카테고리의 다른 글

[iOS] xib  (0) 2021.05.22
[iOS] 동시성 프로그래밍  (0) 2021.05.11
[iOS] scrollview autolayout  (0) 2021.03.31
[iOS] The data couldn’t be read because it is missing.  (1) 2021.03.20
[iOS] segue로 데이터 전달  (0) 2021.03.19