iOS - 哪个是放置图像的更好选择?核心图形(PaintCode App)与图像文件(png)

标签 ios performance core-graphics resolution paintcode

我正在开发一个使用大量图像的 iOS 应用程序。我对如何在应用程序中加载图像感到困惑。 similar question大约5年前被问到。但从那以后发生了很多变化。所以我想,开始一个新线程会更有意义。

我觉得主要有两个选择:

  1. 使用 PaintCode 应用程序(您可以找到它 here),它为您提供 CG 代码以在运行时绘制图像。

  2. 放置 .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.

我主要担心的是:

  1. 在运行时绘制图像是否会影响性能和其他关键参数。
  2. 在什么情况下,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/

相关文章:

ios - iOS 11.3 更新是否会破坏人脸节点上的 ARKit/SceneKit SCNMaterial 渲染?

ios - 如何在 Swift 中显示溢出到另一个单元格的单元格阴影

css - 后代选择器或特定类?

macos - 如何在共享上下文中渲染到 FBO?

objective-c - 对路径中的变换参数使用 NULL 和 CGAffineTransformIdenity 之间的区别

ios - SQLitt.Swift unregonized token 从 Swift 3.0 到 Swift 4.2 的转换错误

performance - 什么是 FLOP/s?它是衡量性能的一个很好的指标吗?

javascript - JS 方言的二进制处理速度

ios - 我们应该使用哪个 CGImageAlphaInfo?

ios - iphone "add to home screen"忽略查询字符串参数