强制着色器编译
着色器是在GPU上执行的小程序,当然需要花费一些时间来进行编译和加载。 通常,编译和加载单个GPU程序不需要花费很多时间,但是着色器通常具有很多“变体”。 复杂的着色器在各种情况下都有多个预处理器指令(定义),这些指令的每种组合都定义了一个着色器变体。 因此,我们最终不得不编译成千上万个稍有不同的GPU程序。 在运行时按需编译着色器会导致冻结,并需要额外的内存。 为了减少这种开销,所有必需的着色器组合都会被解析,编译并存储在着色器缓存中。 从缓存加载预编译的着色器要快得多。
OpenGL的着色器缓存表示将着色器从 UUSL 预先翻译为 GLSL ,而不是编译。它的生成速度是DirectX的 5-10 倍,但使用的磁盘空间是 5-6 倍。
对着色器缓存没有特殊要求,例如安装或设置任何其他软件。
每次引擎未能从缓存中检索着色器时,所需的着色器都会被编译并自动添加到缓存中。但是,这可能会导致您的应用程序“打h”(冻结一会儿)。对于许多应用程序(例如实时模拟器),这是完全不可接受的。因此,关键是您应该拥有最完整的着色器缓存,其中包含应用程序中使用的所有变体。
所有着色器的预编译是一项重要的功能,可确保在您的项目完成并且最终版本可以交付给客户时,您将拥有完整的着色器缓存。这显着减少了最终版本构建中的冻结次数,并平滑了应用程序的帧速率。已为项目中的所有材料预先编译了着色器。
通过加载工具栏上Play按钮附近的工具栏上的Precompile All Shaders按钮或通过加载世界时通过Settings窗口的Editor部分可以使用此功能。
您可以通过以下方式之一使用它:
-
恒定的后台预编译
启用此按钮后,每次创建新材质时,您将在视口中的着色器编译中看到以下消息:
如果通过编译消息上的相应按钮使UnigineEditor的UI响应变得太慢,则可以停止着色器缓存的生成过程。尚未为其编译着色器的材质将临时替换为灰色且没有纹理的基础材质。根据您计算机的性能,这可能需要花费几秒钟的时间。此选项可确保您始终具有所选图形API的完整着色器缓存。
按需预编译
有时,不断进行的着色器后台编译可能会干扰并减慢您的工作速度,这对于某些引擎而言是典型的。 UNIGINE使您可以禁用着色器预编译。您可以在评估最终版本的性能之前启用它。在这种情况下,着色器缓存的生成将花费更多的时间(最多半小时),具体取决于项目的复杂性和所选的图形API。但是它只会执行一次,而不是每次更改材料时都会减慢您的工作。
建议图形程序员使用此模式,以在更改材料状态时节省重新编译的时间。
强制着色器预编译可确保为项目中的所有材质提供最完整的独立于世界的着色器缓存。 但是,更改某些本地设置,例如用于大地坐标,地形,水或云的设置(例如,通过Tracker或您的应用程序逻辑更改某些材质状态)仍会导致重新编译着色器,但仅仅是重新编译一种仅针对相应类型的对象执行。
应该执行以下操作来为您的项目生成最完整的着色器缓存:
- 打开所有包含大地坐标,地形,水或云的世界。
- 对于这些世界,请执行以下操作:
- 水-将场景摄影机置于水上,水下和两种介质之间的水线处。
- 地形-将场景摄像机放在地形上方,然后将其移至地形表面。
- 云-将场景摄像机放在云之上,云之下和云内部。
- 为所有计划通过应用程序逻辑进行切换的材料状态创建并启动轨道。
在data文件夹内生成DirectX / OpenGL的输出着色器缓存:
- shader_d3d11.cache
- shader_gl.cache
当您的项目完成并且最终版本可以移交给客户时,您应该将两个缓存文件(shader_gl.cache和shader_d3d11.cache)都复制到最终版本的data目录中。
如果您通过命令行或引擎初始化传递了项目名称:
-project_name "YourProject"
- Windows - C:/Users/<username>/YourProject/
- Linux - /home/<username>/.YourProject/