c++ - 基于着色器文件创建和链接动态头文件
问题描述
我目前正在创建一个游戏引擎,我目前的问题是反映着色器(基本上是一个二进制文件,其中包含有关结构的信息,我需要例如结构的大小或其位置)。现在我使用 spirv-cross (解析库)来获取每一个信息,但问题是我在运行时拥有它。
我不想写两次完全相同的结构(在着色器和 hpp 文件中)。此外,不同的对齐方式等可能存在一些问题。在运行时,我拥有有关大小、偏移量的所有信息,但这意味着我需要使用std::vector
(或任何其他堆分配)创建缓冲区,而不仅仅是uint8_t buffer[size]
.
因为我在运行应用程序之前有我的着色器文件,所以我可以只使用一个预处理工具,它会为我创建一个带有结构和/或模板化特征的头文件,但现在我考虑引擎中的用户体验。他不会编译任何东西,所以引擎的预期行为是track changes in shaders -> preprocessing -> creation of shader via graphics API
。这只是我的看法,也许有更好的方法。
问题是:我可以使用预处理工具创建一个标题并将其动态链接到我的程序吗?生成的头文件看起来像这样
template<string shaderName>
struct ShaderTraits;
template<>
struct ShaderTraits<"shader.spv"> {
bufferSize = 128;
offsets = [0, 20, 4]
types = <AnotherStruct, Array[3], float>
getField1(buffer) { return reinterpret_cast<types[0]&>(buffer + offset[0]); }
...
}
另一个问题是我在编译时不会有一个参数(着色器文件名)。因此,我无法将我的特征与模板分开。有没有办法在运行时按字符串分隔类定义?
另外:如果您知道处理着色器的更好方法,请告诉我
解决方案
推荐阅读
- sqlite - TEXT 列上 WHERE 子句的奇怪 sqlite3 行为
- bash - 如何用命令行参数替换bash变量
- grafana - 用于 grafana 的 influxdb 中两个不同查询的单行查询百分比
- amazon-web-services - 配置输出 S3 存储桶以允许 AWS Transcribe 存储转录结果时出现问题
- java - EventQueue.invokeLater() 有一些错误
- makefile - 使用 Jobs (Multicore) 标志会导致 Makefile 编译失败
- scala - 交错多个流
- wordpress - 允许用户选择他们喜欢的类别并保存它们
- excel - 允许 Excel 宏在受保护的工作表上运行
- python - 模块“Crypto.PublicKey.RSA”没有属性“import_key”