我正在开发一个使用大量图像的 iOS 应用程序。我对如何在应用程序中加载图像感到困惑。 similar question大约5年前被问到。但从那以后发生了很多变化。所以我想,开始一个新线程会更有意义。
我觉得主要有两个选择:
使用 PaintCode 应用程序(您可以找到它 here),它为您提供 CG 代码以在运行时绘制图像。
放置 .png 图像文件(1x、2x、3x)
关于第一个选项的事情是:
• The first most important and unbeatable feature: Draw dynamic images i.e. to be able to change the content and gives basic animation effects using variables and equations
• The second most important thing: parametric images that behaves perfectly when frame changes no stretching or distortion
• Less size - As we not gonna use image files, reduces the overall size of the app drastically (top concern these days). E.g. PaintCode App in itself weights only ~5 MB (leaving out icon files).
• Resolution independence
• Very easy to use. Especially you don't need to remember names. You simply make some function calls.
我主要担心的是:
- 在运行时绘制图像是否会影响性能和其他关键参数。
- 在什么情况下,png 文件更合适。
所以,我在这里,向更多知识渊博的人征求意见。 提前致谢。
最佳答案
如果绘图很简单 - 使用 Core Graphics。
您在所有支持 Core Graphics/PaintCode 方法的观点上都是正确的。
正如您所说,它是面向 future 的,并且比导入 Assets 灵活得多。
您想更改自定义按钮的颜色吗?在您的函数中输入不同的参数,而不是为每个分辨率重新制作 3 张图像。
您想按比例放大该绘图吗?只需用新尺寸重新绘制即可。
新款 iPhone 8s 会在不久的将来推出,配备 4 倍显示屏?您的应用已经可以处理它。
正如您所说,它减小了应用程序包的大小,这很了不起。
- 这减少了用户的下载量,也减少了您对大小优化的担忧。
不过。
Core Graphics 的绘图是 100% 在 CPU 上完成的,因此如果您在主线程上进行大量复杂的绘图,将会影响性能。
作为Tricertops says ,复杂 CG 绘图的一个主要示例是具有大半径的阴影。另一个例子是在您的上下文中使用复杂的路径。
不过不要绝望,有办法解决这个问题!
您可以在后台线程上进行离屏绘图,然后将绘制的图像传递到主线程上的屏幕(您必须 从主线程进行 UI 更新),但这仍然会导致一些延迟问题(图像不知从哪里出现在屏幕上)。但是,这可能是加载复杂绘图的好方法,您将在应用的后续阶段使用这些绘图。
您还可以通过在应用加载时加载您的 Core Graphics 图像来牺牲一些应用启动时间,但这对于用户来说可能是不希望的,具体取决于图像的复杂性和数量你需要画画。
您可以通过保留经常绘制的图像(按钮背景等)的缓存来重复使用绘图。这将通过牺牲一点 RAM 来提高性能。 PaintCode 实际上是 automatically does this when you use non-parameterised StyleKits .
虽然,iOS 硬件比以前快得多when this question was asked ,绘制 Core Graphics 代码的实际 CPU 使用率比以前少得多,因此您现在可以在更快的设备上绘制更复杂的图形。
但是,您可能会发现一些复杂的绘图根本不可能,或者需要 永远 在 Core Graphics 中创建。在这种情况下,我肯定建议使用图像。
As the answerer非常 Eloquent 地放在你链接到的帖子上:
The fastest program is the one that reaches the market first.
如果您发现自己花费数周时间尝试在 Core Graphics 中创建绘图,那么您最好只使用图像并更高效地花费时间!
尽管如此,只要您保持绘图简单,并尽可能重复使用绘图,您就不必担心使用 Core Graphics 时的性能问题。
在我看来,只要使用得当,使用 Core Graphics/PaintCode 进行简单绘图的优点远远大于缺点。
关于iOS - 哪个是放置图像的更好选择?核心图形(PaintCode App)与图像文件(png),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35369300/