在c++中创建数据驱动的结构
Creating data driven structs in c++?
我正在为游戏制作实体组件系统。我将我的组件实现为具有成员变量的结构:
struct Position
{
float x;
float y;
}
struct Render
{
unsigned int texture;
}
这一切都很好,而且尽可能简单,如果我想添加一个新的组件类型,我必须创建一个新结构并将其添加到代码中。
但这里有一个问题:我想让玩家在游戏编译后创建添加新组件类型的MOD?
例如,假设modder提供了一个定义组件的文件,该文件包含如下内容:
position
float x
float y
我可以做到这一点的一种方法是让每个组件都有一个映射字符串(变量名)及其值的映射。我会有一个int映射,一个float映射,等等。然后组件看起来像这样:
struct Component
{
string type;
map<string, int> ints;
map<string, float> floats;
}
然后,游戏将读取一个定义组件的文件,并将变量添加到地图中。现在我的问题是:
- 这是个好主意吗
- 由于我每帧都访问这些变量,访问速度会因为地图而变慢吗
- 这个问题的最佳解决方案是什么
编辑:我应该指出,这些文件定义了全新类型的结构,因此,与其在代码中手动添加以下内容:
struct Health
{
float max_hp;
float hp;
}
我会写一个文件,其中包含:
health
float max_hp
float hp
让游戏从中读取类定义。
对象可以有一组基本属性和自定义属性。引擎必须依赖于基元属性的存在,并且通常不会访问自定义属性。例如,在mods中定义"位置"属性是没有意义的,因为引擎必须依赖于该属性的存在,并将以一种非常特殊的方式使用它。另一方面,自定义属性可能会在mods中使用的脚本语言中使用。如果以这种方式组织,则不会出现速度问题。低级别属性以最大速度访问,而自定义属性以名称访问,但与脚本语言的解释相比,速度的微小损失可以忽略不计。
相关文章:
- 如何在C++中序列化结构数据
- 正在转换结构数据的字节序
- C++ - 使用结构数据类型将单词中的单个小写字符更改为大写,反之亦然
- 在结构数据类型中更改每个字符的 ASCII 值
- C++ - 检查结构数据类型中的单词是否为回文
- 如何将结构数据成员传递到函数中
- 在std::线程中使用已分配的结构数据
- 将结构数据存储在循环缓冲区中
- 通过指针算法访问结构数据成员
- 将结构数据类型传递给 C++ 中的命名管道
- CLI/C# 将 std::vector<> 结构数据传递给 C#
- 使用来自 C 的内存地址的 Julia 读取/写入结构数据
- CPP 在读取结构数据时无限循环错误?
- 为什么C++编译器不优化对结构数据成员的读取和写入,而不是不同的局部变量?
- Boost 的数据驱动测试的联接运算符"+"损坏了第一列
- 使用Hazelcast替换共享内存结构数据
- 带有结构数据的 Gmock
- 结构数据D = {0}和结构数据D = {}之间是否存在任何区别
- 有没有办法将数组行为作为静态结构数据成员?
- 在c++中创建数据驱动的结构