[英]How to Load images from photo library lazily?
我想延迟加载图像并在启用分页的scrollview中显示它。 一次加载所有图像会导致App崩溃,因为我正在加载fullScreenImage。 如果我使用AspectRatioThumbnail加载缩略图,它的效果很好,但是图像质量较差。 因此,我只想为可见页面加载图像,而不是一次加载所有内容。 如果我知道如何从照片库延迟加载图像,则只能使用三页显示图像。 以下是我的代码...
-(void)loadImagesFromLibrary{
imageList = [[NSMutableArray alloc] init];
ALAssetsLibrary *library = [[ALAssetsLibrary alloc] init];
CGFloat __block xaxis=05;
NSUInteger __block images = 0;
dispatch_queue_t queue = dispatch_get_main_queue();
dispatch_async(queue, ^(void){
[library enumerateGroupsWithTypes:ALAssetsGroupSavedPhotos
usingBlock:^(ALAssetsGroup *group, BOOL *stop) {
if(group){
[group setAssetsFilter:[ALAssetsFilter allPhotos]];
[group enumerateAssetsUsingBlock:^(ALAsset *assets, NSUInteger index, BOOL *innerStop){
if (assets && [[assets valueForProperty:ALAssetPropertyType] isEqualToString:ALAssetTypePhoto])
{
//ALAssetRepresentation *representation = [assets defaultRepresentation ];
//UIImage *img = [UIImage imageWithCGImage:[representation fullScreenImage]];
UIImage *img = [UIImage imageWithCGImage:[assets aspectRatioThumbnail]];
if(img){
[imageList addObject:img];
UIImageView *imageView = [[UIImageView alloc] initWithFrame:CGRectMake(xaxis, 5, 300, HEIGHT)];
[imageView setImage:[self rectSizeFormat:img Size:CGSizeMake(300, HEIGHT)]]; //resizing the image
[imageView setTag:images++];
[imageView setUserInteractionEnabled:YES];
UITapGestureRecognizer *tapGesture = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(displayImageInMiddleView:)];
[tapGesture setNumberOfTapsRequired:1];
[imageView addGestureRecognizer:tapGesture];
[tapGesture release];
[scrollView addSubview: imageView];
[imageView release];
xaxis+=320;
}
}
}];
[scrollView setContentSize:CGSizeMake(xaxis, HEIGHT)];
}
else{
DLog(@"No image");
}
}
failureBlock:^(NSError *err) {
DLog(@"%@", [err localizedDescription]);
}];
});
}
我知道无法用几行来解释。 我要问的只是给我一个提示,以实现我想要的目标,或者建议我如何以其他方式实现目标。 提前谢谢了。
我对“幻灯片”类型的显示器有类似的问题。 我的解决方案是枚举目标相册中的资产,并逐一列出
当我需要每个胶片图像的高分辨率版本时,我会触发一个异步请求,以使用保存的assetURL加载完整尺寸的图像。 当然这是异步的,因此,当图像最终从资产库到达时,您必须在UI中放置一个位置(在我的情况下为UIImageView)以放置图像。 在加载完整尺寸的图像之前,我将缩略图显示在同一UIImageView中(具有scale-aspect-fit)。
图像加载的异步特性是一个真正的烦恼。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.