ios - 照片框架 requestImageDataForAsset 偶尔会失败

标签 ios objective-c photosframework

我在 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 恢复备份后:

  1. 使用 iOS 应用程序并从 iCloud 共享相册中检索照片。
  2. 使用 iTunes 备份 iOS 设备。
  3. 使用 iTunes 恢复备份。
  4. 再次使用该应用从 iCloud 共享相册中检索相同的照片现在失败并显示上述控制台消息。

切换“iCloud 照片共享”开关仍然可以解决问题。据推测,恢复过程以某种方式破坏了一些缓存。我已将其作为错误 38290463 报告给 Apple。

关于ios - 照片框架 requestImageDataForAsset 偶尔会失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28170444/

相关文章:

ios - 读取“设置包”简单值的值

ios - 应用内购买产品 ID 更新落后一位

ios - 请求 AVAssets 时维护顺序

ios - 添加新叠加层时,MKMapView 叠加层重绘(闪烁)。 MKPolyLines 呈锯齿状

ios - ifndef,常量的定义和直接赋值

ios - 按下指向 TableView 的按钮时应用程序崩溃

ios - UIImage 到 PHAsset

iOS 照片框架 : how to revert image asset to original

ios - (NSCFType set) - iOS 6 中无法识别的选择器

objective-c - Core Data 中对多关系的属性声明