我正在尝试从 iPad 照片库中创建所选照片的缩略图 (288x288)。我在 UITableView 中显示了一组 ALAsset 对象,当我选择一行时,会显示该图像的较大预览 (288x288)。为了防止主线程阻塞,我试图在后台线程上创建缩略图,并将缩略图的副本缓存到文件系统。
在选中TableView行时的视图控制器中,我调用LoadPreviemage中的背景:
- (void)tableView:(UITableView *)tableView
didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
// get the upload object from an array that contains a ALAsset object
upload = [uploads objectAtIndex:[indexPath row]];
[self performSelectorInBackground:@selector(loadPreviewImage:)
withObject:upload];
}
我传递了一个包含asseturl 属性的自定义上传对象:
- (void)loadPreviewImage:(MyUploadClass*)upload
{
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
UIImage *preview = [upload previewImage];
[self performSelectorOnMainThread:@selector(setPreviewImage:)
withObject:preview
waitUntilDone:YES];
[pool release];
}
这在主线程上调用以在加载后显示缩略图:
- (void)setPreviewImage:(UIImage*)image
{
self.imageViewPreview.image = image;
[self layoutSubviews];
}
这是 MyUploadClass 的一个方法:
- (UIImage *)previewImage
{
__block UIImage *previewImage = [[UIImage imageWithContentsOfFile:
[self uploadPreviewFilePath]] retain];
if (previewImage == nil && asseturl)
{
ALAssetsLibrary* library = [[ALAssetsLibrary alloc] init];
[library assetForURL:self.asseturl resultBlock:^(ALAsset *asset)
{
ALAssetRepresentation *rep = [asset defaultRepresentation];
previewImage = [UIImage imageWithCGImage: [rep fullScreenImage]];
previewImage = [[previewImage resizedImageWithContentMode:UIViewContentModeScaleAspectFit
bounds:CGSizeMake(288, 288)
interpolationQuality:kCGInterpolationHigh] retain];
NSData *previewData = UIImageJPEGRepresentation(previewImage, 1.0);
[previewData writeToFile:[self uploadPreviewFilePath] atomically:YES];
}
failureBlock:^(NSError *error){ }];
[library release];
}
return [previewImage autorelease];
}
问题是我总是第一次得到 nil previewImage 并且只有在缓存缩略图之后我才得到一个图像对象。我究竟做错了什么?有没有更好的方法来解决这个问题?