PHAsset

  • 父類:NSObject

展示一張Live Photo——這個(gè)照片包含了拍攝時(shí)刻之前以及之后的動(dòng)作和聲音。

一、概述

在iOS和tvOS中,你可以使用這個(gè)類來(lái)從用戶的圖庫(kù)中(使用PHAssetPHImageManager類獲取)引用Live Photo,在其他的位置(如通過(guò)社交網(wǎng)絡(luò)分享圖片)使用獲得的數(shù)據(jù)來(lái)加載展示Live Photo對(duì)象,并將Live Photo加載在PHLivePhotoView上來(lái)進(jìn)行展示。
在iOS和tvOS,以及MacOS中,你可以使用這個(gè)類來(lái)在一個(gè)照片編輯擴(kuò)展中展示編輯Live Photo的過(guò)程。

注意
關(guān)于如何將Live Photo和你的應(yīng)用的用戶體驗(yàn)整合到一起,請(qǐng)查看iOS Human Interface Guidelines中的Live Photos

PHLivePhoto類對(duì)于Live Photo同UIImageNSImage)對(duì)于靜態(tài)圖片的作用是一樣的。一個(gè)UIImage或者NSImage對(duì)象并不是一張圖片的加載的數(shù)據(jù)文件,而是一個(gè)可以被展示在視圖中的準(zhǔn)備使用的圖片——同樣的,一個(gè)PHLivePhoto對(duì)象標(biāo)示的是一個(gè)已經(jīng)準(zhǔn)備好使用PHLivePhotoView展示動(dòng)作和聲音的Live Photo,不是照片庫(kù)的一個(gè)入口也不是構(gòu)成一個(gè)Live Photo的數(shù)據(jù)源。(想要Live Photo作為照片庫(kù)的元素,請(qǐng)使用PHAsset類。想要使用構(gòu)成一個(gè)Live Photo的數(shù)據(jù)源,請(qǐng)使用PHAssetResource類。)

提示
想要在網(wǎng)頁(yè)上展示Live Photo的內(nèi)容,請(qǐng)使用LivePhotosKit JS框架。

二、內(nèi)容

1. 檢查一個(gè)Live Photo

@property(readonly, nonatomic) CGSize size;

Live Photo的大小。

2. 從數(shù)據(jù)文件中加載一個(gè)Live Photo

+ (PHLivePhotoRequestID)requestLivePhotoWithResourceFileURLs:(NSArray<NSURL *> *)fileURLs placeholderImage:(UIImage *)image targetSize:(CGSize)targetSize contentMode:(PHImageContentMode)contentMode resultHandler:(void (^)(PHLivePhoto *livePhoto, NSDictionary *info))resultHandler;
  • fileURLs NSArray - 一個(gè)URL的數(shù)組,這個(gè)數(shù)組包含了多個(gè)構(gòu)成一個(gè)Live Photo的資源的URL,獲得URL請(qǐng)使用PHAssetResource類。
  • image UIImage - Live Photo的全部?jī)?nèi)容被加載并顯示之前的替代圖片。
  • targetSize CGSize - 想要的Live Photo的大小。傳入CGSizeZero則為L(zhǎng)ive Photo的原始大小。
  • contentMode PHImageContentMode - 如何將圖像與所請(qǐng)求的大小的縱橫比相匹配。詳細(xì)內(nèi)容請(qǐng)查看PHImageContentMode
  • resultHandler block - 圖片被加載完成的回調(diào)。
  • livePhoto PHLivePhoto - 請(qǐng)求的Live Photo。
  • info NSDictionary - 關(guān)于請(qǐng)求狀態(tài)的信息。具體內(nèi)容請(qǐng)查看下面Result Handler Info Dictionary Keys

從給定的源文件中異步加載一個(gè)Live Photo。將會(huì)返回一個(gè)用來(lái)標(biāo)示請(qǐng)求的唯一的ID。
使用這個(gè)方法從之前在照片庫(kù)中獲取的數(shù)據(jù)文件中加載用來(lái)展示的Live Photo對(duì)象。例如,社交網(wǎng)絡(luò)應(yīng)用可以使用PHAssetResource來(lái)獲取一個(gè)用戶的照片庫(kù)中構(gòu)成一個(gè)Live Photo的數(shù)據(jù)文件,并將它們上傳到服務(wù)器。然后,在另一個(gè)用戶的設(shè)備中,這個(gè)應(yīng)用下載這些數(shù)據(jù)文件并且使用這個(gè)方法來(lái)重新創(chuàng)建一個(gè)Live Photo對(duì)象來(lái)使用PHLivePhotoView類進(jìn)行展示。

注意
想要獲取一個(gè)表示一個(gè)在用戶照片庫(kù)中的Live Photo資源的PHLivePhoto對(duì)象,使用PHAsset類定位資源并用PHImageManager類來(lái)獲取資源的Live Photo數(shù)據(jù)來(lái)進(jìn)行展示。
想要向照片庫(kù)中引入一個(gè)Live Photo,請(qǐng)使用PHAssetCreationRequest類。

這個(gè)方法是異步的。Photos在后臺(tái)線程中加載、驗(yàn)證以及準(zhǔn)備數(shù)據(jù),然后調(diào)用你的resultHandler回調(diào)并傳入一個(gè)已經(jīng)準(zhǔn)備好進(jìn)行展示的Live Photo對(duì)象。同PHImageManager中類似的方法一樣,Photos可以不止一次的調(diào)用你的resultHandler回調(diào)——第一次,提供一個(gè)低質(zhì)量的Live Photo對(duì)象(只包含方法的image參數(shù)中的靜態(tài)圖像),然后之后會(huì)返回一個(gè)全部的動(dòng)作和聲音內(nèi)容的Live Photo。如果在你的resultHandler回調(diào)中的info字典中PHLivePhotoInfoIsDegradedKey對(duì)應(yīng)的值為YESPhotos還將會(huì)再次調(diào)用你的resultHandler回調(diào)。
這個(gè)方法可以從一個(gè)之前獲取的Live Photo資源中的相同的文件集合加載一個(gè)PHLivePhoto對(duì)象。當(dāng)你使用這個(gè)方法,Photos會(huì)驗(yàn)證這些文件以及他們的源數(shù)據(jù)是否可以作為一個(gè)Live Photo被加載。如果Photos不能從給定的文件中加載一個(gè)Live Photo,你的resultHandler回調(diào)中的result參數(shù)則為nil,并且info字典將包含一個(gè)NSError對(duì)象來(lái)描述錯(cuò)誤。

Result Handler Info Dictionary Keys

  • NSString *const PHLivePhotoInfoErrorKey;
    加載請(qǐng)求的照片時(shí)發(fā)生錯(cuò)誤。值為一個(gè)NSError對(duì)象。
  • NSString *const PHLivePhotoInfoIsDegradedKey;
    標(biāo)示當(dāng)前返回的livePhoto是否是請(qǐng)求的照片的臨時(shí)低質(zhì)量的結(jié)果。如果為YES,回調(diào)在之后還會(huì)調(diào)用來(lái)返回完整的Live Photo的數(shù)據(jù)。
  • NSString *const PHLivePhotoInfoCancelledKey;
    加載請(qǐng)求的照片是否被取消。
+ (void)cancelLivePhotoRequestWithRequestID:(PHLivePhotoRequestID)requestID;

取消一個(gè)異步請(qǐng)求。
當(dāng)你使用上面的方法異步請(qǐng)求從源文件中加載一個(gè)Live Photo,這個(gè)方法會(huì)返回這個(gè)請(qǐng)求的一個(gè)數(shù)值標(biāo)識(shí)。想要在這個(gè)請(qǐng)求完成前取消這個(gè)請(qǐng)求,調(diào)用此方法并傳入這個(gè)請(qǐng)求的數(shù)值標(biāo)識(shí)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,923評(píng)論 6 535
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,740評(píng)論 3 420
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 176,856評(píng)論 0 380
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 63,175評(píng)論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,931評(píng)論 6 410
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 55,321評(píng)論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,383評(píng)論 3 443
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 42,533評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,082評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,891評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,067評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,618評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,319評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 34,732評(píng)論 0 27
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 35,987評(píng)論 1 289
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,794評(píng)論 3 394
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,076評(píng)論 2 375

推薦閱讀更多精彩內(nèi)容

  • 在微博上出現(xiàn)了越來(lái)越多的被標(biāo)記為 Live 的圖片,這種圖片是一種動(dòng)圖 LivePhoto,長(zhǎng)按之后會(huì)進(jìn)行播放。那...
    wvqusrtg閱讀 5,000評(píng)論 0 9
  • 相冊(cè)適配 前言 由于在iOS8及以后蘋(píng)果將原有的操作相冊(cè)的ALAssetsLibrary framework替換為...
    wentianen閱讀 1,838評(píng)論 0 6
  • 父類:PHCollection 一個(gè)照片資源分類的表現(xiàn)形式,例如一個(gè)時(shí)刻,用戶創(chuàng)建的相冊(cè)或者智能相冊(cè)。 一、概述 ...
    Shmily落墨閱讀 7,797評(píng)論 2 6
  • 本文為大地瓜原創(chuàng),歡迎知識(shí)共享,轉(zhuǎn)載請(qǐng)注明出處。雖然你不注明出處我也沒(méi)什么精力和你計(jì)較。作者微信號(hào):christg...
    大地瓜123閱讀 3,743評(píng)論 0 0
  • ? 自從二維碼出世,阿里巴巴和騰訊便使得二維碼成功在中國(guó)大陸上發(fā)芽并將之發(fā)揚(yáng)光大——它在國(guó)人的生活中已經(jīng)占據(jù)了重要...
    新媒礦閱讀 368評(píng)論 0 0