2

我在我的项目中使用 Apple 的大图像缩小示例代码来加载可以缩放的大图像。

示例项目可以在这里下载:Apple Large Image Downsizing

UIScrollView源码可以直接在这里查看: ImageScrollView.m

除了用户可以放大到无穷大之外,它运作良好。似乎当 Apple 使用 UIScrollView 的缩放功能时,实际缩放是通过重新缩放源图像而不是通过转换 UIView 来执行的。(虽然我对它的工作原理的理解有点不稳定!)

我正在寻找将最大缩放限制为图像的全分辨率。

4

1 回答 1

1

我不知道那个项目,但它似乎没有做你真正想要的。它可以让您拍摄一个非常大的图像文件并缩小它的大小。

有一个 github 项目PhotoScrollerNetwork,它可以让您下载巨大的 JPEG 图像(一个是 NASA 18,000 x 18,000)并在它们到达时逐步解码。然后它使用 CATiledLayers 以足够小的缩小显示图像以适合窗口,但可以缩小到完整的图像分辨率。这可能更符合您的目标。

该项目基于 Apple 的 PhotoScroller 项目,该项目仅适用于预先平铺的图像。

编辑:我下载了大图像缩小项目。它与 Apple 的PhotoScroller有很多共同之处,如果您浏览后面的项目,您可能会弄清楚如何限制缩放。我怀疑这与以下几行有关:

    self.maximumZoomScale = 5.0f;
    self.minimumZoomScale = 0.25f;

也就是说,我将树叶图像粘贴到 PhotoScrollerNetwork 的捆绑包中,并在 iPhone 4 上进行了比较。Large Image Downsizing 项目花了一分钟来解码图像,您可以在渲染时看到图像的增量视图,但它(我相信)它需要磁盘上的整个图像才能继续。

PhotoScrollerNetwork 能够在 32 秒内解码图像 - 大约只有一半时间。如果你从网络下载,它会在接收到数据时对图像进行解码,因此从最后一块数据到你看到图像的延迟很小。

PhotoScrollerNetwork 提供:

  • 并发图像下载和渲染

  • 自动设置细节级别以优化全尺寸和全屏显示图像

  • 非常平滑的缩放和平移(由于预渲染图块)

  • 没有文件保存在磁盘上(但它使用磁盘缓存):这意味着如果应用程序崩溃不需要清理。

    以下日志消息:

    2012-09-05 11:46:11.784 LargeImage[2242:3107] 开始缩小尺寸。迭代:14,平铺高度:754.000000,剩余高度:425 2012-09-05 11:46:11.788 LargeImage[2242:3107] 迭代 1 的 14 2012-09-05 11:46:13.132 LargeImage[2242:3107] 迭代2 of 14 2012-09-05 11:46:15.148 LargeImage[2242:3107] 迭代 3 of 14 2012-09-05 11:46:17.526 LargeImage[2242:3107] 迭代 4 of 14 2012-09-05 11: 46:20.627 LargeImage[2242:3107] 迭代 5 of 14 2012-09-05 11:46:24.017 LargeImage[2242:3107] 迭代 6 of 14 2012-09-05 11:46:27.696 LargeImage[2242:3107] 迭代7 of 14 2012-09-05 11:46:31.823 LargeImage[2242:3107] 迭代 8 of 14 2012-09-05 11:46:36.638 LargeImage[2242:3107] 迭代 9 of 14 2012-09-05 11: 46:41.791 LargeImage[2242:3107] 第 10 次迭代,共 14 次 2012-09-05 11:46:47.309 LargeImage[2242:3107] 第 11 次迭代,共 14 次 2012-09-05 11:46:53。

    2012-09-05 11:57:24.465 PhotoScrollerNetworkTurbo[2262:1c03] 初始化:总计:270237696 已使用:163041280 免费:107196416 [驻留=6574080 虚拟=346882048] 2012-09-05 11:57:24.531cScrollerNetwork[ ] ORIENTATION=1 字符串=1 2012-09-05 11:57:24.535 PhotoScrollerNetworkTurbo[2262:1c03] ZLEVELS=5 2012-09-05 11:57:57.463 PhotoScrollerNetworkTurbo[2262:1c03] FINISH-I: 32974 毫秒 2012- 09-05 11:57:57.946 PhotoScrollerNetworkTurbo[2262:1c03] 已完成:总计:260521984 已使用:219987968 免费:40534016 [驻留=3469312 虚拟=349683712]

于 2012-09-05T11:50:48.767 回答