我在 iOS8.1 上使用照片框架并使用 requestImageDataForAsset 请求 Assets 的图像数据...大部分时间它都有效,我得到图像数据和包含您在下面看到的内容的字典。但有时调用完成,但数据为零,字典包含三个通用的条目。
调用在同一个线程上按顺序执行。它不特定于任何特定图像。该错误将发生在我过去成功打开的图像上。有人遇到过吗?
+ (NSData *)retrieveAssetDataPhotosFramework:(NSURL *)urlMedia resolution:(CGFloat)resolution imageOrientation:(ALAssetOrientation*)imageOrientation {
__block NSData *iData = nil;
PHFetchResult *result = [PHAsset fetchAssetsWithALAssetURLs:@[urlMedia] options:nil];
PHAsset *asset = [result firstObject];
PHImageManager *imageManager = [PHImageManager defaultManager];
PHImageRequestOptions *options = [[PHImageRequestOptions alloc]init];
options.synchronous = YES;
options.version = PHImageRequestOptionsVersionCurrent;
@autoreleasepool {
[imageManager requestImageDataForAsset:asset options:options resultHandler:^(NSData *imageData, NSString *dataUTI, UIImageOrientation orientation, NSDictionary *info) {
iData = [imageData copy];
NSLog(@"requestImageDataForAsset returned info(%@)", info);
*imageOrientation = (ALAssetOrientation)orientation;
}];
}
assert(iData.length != 0);
return iData;
}
这是我获得图像数据和元数据字典的期望结果:
requestImageDataForAsset returned info({
PHImageFileDataKey = <PLXPCShMemData: 0x1702214a0> bufferLength=1753088 dataLength=1749524;
PHImageFileOrientationKey = 1;
PHImageFileSandboxExtensionTokenKey = "6e14948c4d0019fbb4d14cc5e021199f724f0323;00000000;00000000;000000000000001a;com.apple.app-sandbox.read;00000001;01000003;000000000009da80;/private/var/mobile/Media/DCIM/107APPLE/IMG_7258.JPG";
PHImageFileURLKey = "file:///var/mobile/Media/DCIM/107APPLE/IMG_7258.JPG";
PHImageFileUTIKey = "public.jpeg";
PHImageResultDeliveredImageFormatKey = 9999;
PHImageResultIsDegradedKey = 0;
PHImageResultIsInCloudKey = 0;
PHImageResultIsPlaceholderKey = 0;
PHImageResultWantedImageFormatKey = 9999;
})
这是我偶尔得到的。图像数据为零。字典收录的不多。
requestImageDataForAsset returned info({
PHImageResultDeliveredImageFormatKey = 9999;
PHImageResultIsDegradedKey = 0;
PHImageResultWantedImageFormatKey = 9999;
})
最佳答案
我遇到了类似症状的问题 requestImageDataForAsset
返回了 nil 图像数据,但还伴随着这样的控制台错误消息:
[Generic] Failed to load image data for asset <PHAsset: 0x13d041940> 87CCAFDC-A0E3-4AC9-AD1C-3F57B897A52E/L0/001 mediaType=1/0, sourceType=2, (113x124), creationDate=2015-06-29 04:56:34 +0000, location=0, hidden=0, favorite=0 with format 9999
就我而言,从 iOS 10.x 升级到 11.0.3,然后升级到 11.2.5 后,问题突然开始发生在特定设备上,只有 iCloud 共享相册中的 Assets 。认为也许requestImageDataForAsset
试图使用本地缓存在 /var/mobile/Media/PhotoData/PhotoCloudSharingData/
中的文件(来自信息字典的 PHImageFileURLKey
键)并且缓存可能已损坏,我考虑了如何清除该缓存。
在 iOS 中切换“iCloud 照片共享”开关“设置 -> 帐户和密码 -> iCloud -> 照片 似乎已经成功了。 requestImageDataForAsset
现在正在为那些以前失败的 Assets 工作。
2018 年 3 月 9 日更新
我现在可以重现这个问题。它似乎发生在从 iTunes 恢复备份后:
- 使用 iOS 应用程序并从 iCloud 共享相册中检索照片。
- 使用 iTunes 备份 iOS 设备。
- 使用 iTunes 恢复备份。
- 再次使用该应用从 iCloud 共享相册中检索相同的照片现在失败并显示上述控制台消息。
切换“iCloud 照片共享”开关仍然可以解决问题。据推测,恢复过程以某种方式破坏了一些缓存。我已将其作为错误 38290463 报告给 Apple。
关于ios - 照片框架 requestImageDataForAsset 偶尔会失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28170444/