super 编辑:
好吧,经过几次不同的修改,我有一个更明确的问题。基本上我正在努力使用 NSCache。我有一个 Collection View ,如下所示,我希望能够最大程度地减少图像的滚动延迟,我大部分时间都在这样做。困难的部分是移动到全尺寸图像。这是另一种 View ,我希望过渡到全尺寸照片,就像 Apple 对他们的照片应用所做的那样。
似乎 Apple 正在缓存图像并以不同方式访问它们。我发现我需要加载原始缩略图,然后在下载全尺寸图像时我可以替换它。但我不确定该怎么做。
到目前为止我所拥有的是:
UICollectionview
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view.
self.myCache = [[NSCache alloc] init];
}
//Reusable cell structure
- (UICollectionViewCell *)collectionView:(UICollectionView *)cv cellForItemAtIndexPath:(NSIndexPath *)indexPath {
//cell
CoverPhotoCell *cell = [cv dequeueReusableCellWithReuseIdentifier:@"CoverImgCell" forIndexPath:indexPath];
cell.backgroundColor = [UIColor blackColor];
cell.clipsToBounds = YES;
cell.opaque = YES;
cell.layer.shouldRasterize = YES;
cell.layer.rasterizationScale = [UIScreen mainScreen].scale;
Media *object = [[Media alloc] init];
object = [self.photoListArray objectAtIndex:indexPath.item];
//Remove old cell
for (UIView *subview in [cell subviews]){
if (subview.tag != 0 )
{
[subview removeFromSuperview];
}
}
//UIImage
UIImage *thumbImg = [_myCache objectForKey:object.url];
if (thumbImg) {
cell.imageView.image = thumbImg;
}
else {
cell.imageView.image = nil;
UIImage *thumbImg = [[UIImage alloc] initWithCGImage:[object.asset aspectRatioThumbnail]];
dispatch_async(dispatch_get_main_queue(), ^{
cell.imageView.image = thumbImg;
});
[_myCache setObject:thumbImg forKey:object.url];
}
//thumbnail
cell.imageView.tag = indexPath.row + 1;
cell.imageView.layer.borderWidth = 5;
cell.imageView.layer.borderColor = [UIColor whiteColor].CGColor;
cell.imageView.contentMode = UIViewContentModeScaleAspectFit;
cell.imageView.frame = CGRectMake(0, 0, 125, 125);
return cell;
}
//User taps image
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender
{
if ([segue.identifier isEqualToString:@"PhotoSegue"]) {
DetailPageController *controller = segue.destinationViewController;
NSIndexPath *selectedIndex = [self.collectionView indexPathsForSelectedItems][0];
controller.initialIndex = (NSUInteger)selectedIndex.item;
controller.photos = self.photoListArray;
}
}
这就是我的 NSCache 代码,然后我使用 segue 到显示全分辨率照片的全 View Controller 。如何先加载缩略图,然后再加载全尺寸图像。
还有关于苹果如何如此快速地加载其图像的想法吗?他们是否使用不同的缓存方式?还是我做错了什么。
完善的编辑:
有人可以发布或至少向我指出一些示例代码,其中我在用户快速滚动时显示缩略图并在他们减速时加载实际图像,类似于我猜苹果电影预告片应用程序。
最佳答案
一个完整的代码答案对于 SO 来说太过分了。所以我尝试描述基础知识:
您应该创建自己的图像缓存。使用页面 ScrollView ,最多可以看到两个图像。在启用分页的 ScrollView 中查看照片,图像缓存必须至少保存三张全尺寸图像。
缓存的工作原理如下:
假设您有一个图像列表,可以通过与“相册查看器” ScrollView 中的位置相对应的索引来访问它。
从当前索引,(异步地)将图像加载到 index-1、index 和 index+1 的缓存中,除非该图像已存在于缓存中或索引超出范围。
当用户开始滚动时,下一张图片将变为可见。
当用户向前滚动并滚动半页时,当前索引 将增加 1。此时,可以看到两个图像 - 各占一半。现在,当索引发生变化时,您将当前索引 2 处的图像抛出,并在当前索引 + 1 处加载下一张图像。
当用户向后滚动时,索引会减一。您将 at index+2 抛出并加载当前 index-1 的相应图像。
您可以通过添加与上述完全相同的缩略 View 缓存来改进该方案,但使用的范围更广,比如提前加载 20 张图像。当尚未加载全尺寸图像时,使用缩略图作为“占位符”(注意:一切都应该是异步的)。
如果用户“快速”滚动,则不要加载完整尺寸的图像,只需等待速度降低到一定程度即可。您可以通过一些努力来确定滚动的速度。
如果用户滚动得非常快,那么即使是缩略图在应该显示时也不可用。然后,求助于静态占位符图像。 (还要注意不要用拇指图像覆盖全尺寸图像)。
关于ios - 平滑滚动 500 多张图片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18538467/
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下
我是Rails的新手,所以请原谅简单的问题。我正在为一家公司创建一个网站。那家公司想在网站上展示它的客户。我想让客户自己管理这个。我正在为“客户”生成一个表格,我想要的三列是:公司名称、公司描述和Logo。对于名称,我使用的是name:string但不确定如何在脚本/生成脚手架终端命令中最好地创建描述列(因为我打算将其设置为文本区域)和图片。我怀疑描述(我想成为一个文本区域)应该仍然是描述:字符串,然后以实际形式进行调整。不确定如何处理图片字段。那么……说来话长:我在脚手架命令中输入什么来生成描述和图片列? 最佳答案 对于“文本”数
我正在尝试解析一个文本文件,该文件每行包含可变数量的单词和数字,如下所示:foo4.500bar3.001.33foobar如何读取由空格而不是换行符分隔的文件?有什么方法可以设置File("file.txt").foreach方法以使用空格而不是换行符作为分隔符? 最佳答案 接受的答案将slurp文件,这可能是大文本文件的问题。更好的解决方案是IO.foreach.它是惯用的,将按字符流式传输文件:File.foreach(filename,""){|string|putsstring}包含“thisisanexample”结果的
1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里
print"Enteryourpassword:"pass=STDIN.noecho(&:gets)puts"Yourpasswordis#{pass}!"输出:Enteryourpassword:input.rb:2:in`':undefinedmethod`noecho'for#>(NoMethodError) 最佳答案 一开始require'io/console'后来的Ruby1.9.3 关于ruby-为什么不能使用类IO的实例方法noecho?,我们在StackOverflow上
我正在尝试找出一种方法来显示来自不在RAILS_ROOT下(在RedHat或Ubuntu环境中)的已安装文件系统的图像。我不想使用符号链接(symboliclink),因为这个应用程序实际上是通过Tomcat部署的,而当我关闭Tomcat时,Tomcat会尝试跟随符号链接(symboliclink)并删除挂载中的所有图像。由于这些文件的数量和大小,将图像放在public/images下也不是一种选择。我查看了send_file,但它只会显示一张图片。我需要在一个格式良好的页面中显示6个请求的图像。由于膨胀,我宁愿不使用Base64编码,但我不知道如何将图像数据与呈现的页面一起传递下去。
技术选型1,前端小程序原生MINA框架cssJavaScriptWxml2,管理后台云开发Cms内容管理系统web网页3,数据后台小程序云开发云函数云开发数据库(基于MongoDB)云存储4,人脸识别算法基于百度智能云实现人脸识别一,用户端效果图预览老规矩我们先来看效果图,如果效果图符合你的需求,就继续往下看,如果不符合你的需求,可以跳过。1-1,登录注册页可以看到登录页有注册入口,注册页如下我们的注册,需要管理员审核,审核通过后才可以正常登录使用小程序1-2,个人中心页登录成功以后,我们会进入个人中心页我们在个人中心页可以注册人脸,因为我们做人脸识别签到,需要先注册人脸才可以进行人脸比对,进
当我将IO::popen与不存在的命令一起使用时,我在屏幕上打印了一条错误消息:irb>IO.popen"fakefake"#=>#irb>(irb):1:commandnotfound:fakefake有什么方法可以捕获此错误,以便我可以在脚本中进行检查? 最佳答案 是:升级到ruby1.9。如果您在1.9中运行它,则会引发Errno::ENOENT,您将能够拯救它。(编辑)这是在1.8中的一种hackish方式:error=IO.pipe$stderr.reopenerror[1]pipe=IO.popen'qwe'#
当我尝试使用“套接字”库中的方法“read_nonblock”时出现以下错误IO::EAGAINWaitReadable:Resourcetemporarilyunavailable-readwouldblock但是当我通过终端上的IRB尝试时它工作正常如何让它读取缓冲区? 最佳答案 IgetthefollowingerrorwhenItrytousethemethod"read_nonblock"fromthe"socket"library当缓冲区中的数据未准备好时,这是预期的行为。由于异常IO::EAGAINWaitReadab
我想建立3步用户注册,在第2步上传头像。所以我遵循RyanBates的指南http://railscasts.com/episodes/217-multistep-forms.我正在使用CarrierWavegem来处理上传。但似乎我无法在用户session中存储上传的文件信息(我收到无法转储文件错误)。我在Controller中使用以下技术ifparams[:user][:img_path]@uploader=FirmImgUploader.new@uploader.store!(params[:user][:img_path])session[:img]=@uploaderpara