Photos Framework requestImageDataForAsset occasionally fails

前端 未结 4 1839
不思量自难忘°
不思量自难忘° 2020-12-24 14:54

I\'m using the photos framework on iOS8.1 and requesting the image data for the asset using requestImageDataForAsset... Most of the time it works and I get the image data an

相关标签:
4条回答
  • 2020-12-24 15:06

    The following code maybe help. I think the class PHImageRequestOptions has a bug, so I pass nil , and then fix the bug.

       dispatch_semaphore_t sema = dispatch_semaphore_create(0);
                [[PHImageManager defaultManager] requestImageDataForAsset:asset options:nil resultHandler:^(NSData * _Nullable imageData, NSString * _Nullable dataUTI, UIImageOrientation orientation, NSDictionary * _Nullable info) {
                    assetModel.size = imageData.length;
                    NSString *filename = [asset valueForKey:@"filename"];
                    assetModel.fileName = filename;
                    dispatch_semaphore_signal(sema);
                }];
                dispatch_semaphore_wait(sema, DISPATCH_TIME_FOREVER);
    
    0 讨论(0)
  • 2020-12-24 15:21

    You are likely iterating through an array, and memory is not freed timely, you can try the below code. Make sure theData is marked by __block.

    @autoreleasepool {
        [imageManager requestImageDataForAsset:asset options:options resultHandler:^(NSData *imageData, NSString *dataUTI, UIImageOrientation orientation, NSDictionary *info) {
            NSLog(@"requestImageDataForAsset returned info(%@)", info);
            theData = [imageData copy];
        }];
    }
    
    0 讨论(0)
  • 2020-12-24 15:27

    I had a problem with similar symptoms where requestImageDataForAsset returned nil image data but was also accompanied by a console error message like this:

    [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

    In my case, the problem suddenly started happening on a specific device only with assets in iCloud shared albums after upgrading from iOS 10.x to 11.0.3, and since then through to 11.2.5. Thinking that maybe requestImageDataForAsset was trying to use files locally cached in /var/mobile/Media/PhotoData/PhotoCloudSharingData/ (from the info dictionary's PHImageFileURLKey key) and that the cache may be corrupt I thought about how to clear that cache.

    Toggling the 'iCloud Photo Sharing' switch in iOS' Settings -> Accounts & Passwords -> iCloud -> Photos seems to have done the trick. requestImageDataForAsset is now working for those previously failing assets.

    Update 9th March 2018

    I can reproduce this problem now. It seems to occur after restoring a backup from iTunes:

    1. Use the iOS app and retrieve photos from an iCloud shared album.
    2. Backup the iOS device using iTunes.
    3. Restore the backup using iTunes.
    4. Using the app again to retrieve the same photos from the iCloud shared album now fails with the above console message.

    Toggling the 'iCloud Photo Sharing' switch fixes it still. Presumably the restore process somehow corrupts some cache. I've reported it as Bug 38290463 to Apple.

    0 讨论(0)
  • 2020-12-24 15:27

    Getting back to this after a long while, I have solved a big part of my problem. No mystery, just bad code:

    PHFetchResult *result = [PHAsset fetchAssetsWithALAssetURLs:@[urlMedia] options:nil];
    PHAsset *asset = [result firstObject];
    
    if (asset != nil) { // the fix
        PHImageManager *imageManager = [PHImageManager defaultManager];
        PHImageRequestOptions *options = [[PHImageRequestOptions alloc]init];
        ...
    }
    

    The most common cause for me was a problem with the media URL passed to fetchAssetsWithALAssetURLs causing asset to be nil and requestImageDataForAsset return a default info object.

    0 讨论(0)
提交回复
热议问题