我在我的应用程序中有一个UICollectionView,每个单元格都是UIImageView和一些文本标签。问题是,当我有UIImageViews显示他们的图像时,滚动性能是可怕的。它远不如UITableView的滚动体验,甚至没有UIImageView的UICollectionView。可怜的UICollectionView使用UIImage滚动性能
我发现this question从几个月前,似乎找到了答案,但它是用RubyMotion编写的,我不明白这一点。我试图看看如何将其转换为Xcode,但由于我从未使用过NSCache,所以有点难。那里的海报也指出here有关除了他们的解决方案之外的其他实现,但我不知道该把代码放在哪里。可能是因为我不明白first question的代码。
有人能帮助翻译成Xcode吗?
def viewDidLoad
...
@images_cache = NSCache.alloc.init
@image_loading_queue = NSOperationQueue.alloc.init
@image_loading_queue.maxConcurrentOperationCount = 3
...
end
def collectionView(collection_view, cellForItemAtIndexPath: index_path)
cell = collection_view.dequeueReusableCellWithReuseIdentifier(CELL_IDENTIFIER, forIndexPath: index_path)
image_path = @image_paths[index_path.row]
if cached_image = @images_cache.objectForKey(image_path)
cell.image = cached_image
else
@operation = NSBlockOperation.blockOperationWithBlock lambda {
@image = UIImage.imageWithContentsOfFile(image_path)
Dispatch::Queue.main.async do
return unless collectionView.indexPathsForVisibleItems.containsObject(index_path)
@images_cache.setObject(@image, forKey: image_path)
cell = collectionView.cellForItemAtIndexPath(index_path)
cell.image = @image
end
}
@image_loading_queue.addOperation(@operation)
end
end
下面是从second question代码的first question的提问者说解决了这个问题:
UIImage *productImage = [[UIImage alloc] initWithContentsOfFile:path];
CGSize imageSize = productImage.size;
UIGraphicsBeginImageContext(imageSize);
[productImage drawInRect:CGRectMake(0, 0, imageSize.width, imageSize.height)];
productImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
同样,我不知道如何/在哪里实现这一点。
非常感谢。
发布您的代码!你有什么尝试?为什么你的应用程序的性能变慢?分析它看看发生了什么的结果是什么? – 2013-04-03 22:49:55
这不是我的整个应用程序性能低下,它只是滚动UICollectionView中的单元格。该应用程序的其余部分表现非常好。我目前使用'cell.cardImageView.image = [UIImage imageWithData:[NSData dataWithContentsOfFile:tempCard]];'设置图像。正在使用的图像不是应用程序包的一部分,但通常会下载并存储在Caches文件夹中。 – Nick 2013-04-04 02:11:48