我想创建从同一个基类继承但有自己的函数的对象的向量,这些函数不在基类中(创建虚函数是不可能的,因为继承的类接受不同的变量作为参数一个函数)。
基类:模型
从Model类继承的第一个类:Bus
void Bus::draw_model_bus(angle_x, angle_y, P_scene, V_scene, M_scene) const;
从Model类继承的第二个类:Grass
void Grass::draw_model_grass(P_scene, V_scene, M_scene) const;
... 我想让在存储在这个模型向量中的 Bus 和 Grass 对象上调用上述函数成为可能。 std::vector<Model*> models;
下面的代码不起作用:
models[0]->draw_model_bus(angle_x, angle_y, P_scene, V_scene, M_scene);
models[1]->draw_model_grass(P_scene, V_scene, M_scene);
我想像这样初始化这些对象:
// Bus
models.emplace_back(Bus("res/models/Bus.obj", "res/textures/Bus_tex.tga.png"));
models[0]->read_model();
// Grass
models.emplace_back(Grass("res/models/grass.obj", "res/textures/grass.png"));
models[1]->read_model();
如何像我上面描述的那样存储这些对象?
答案 0 :(得分:1)
恐怕您想要实现的目标不可能以简单的方式实现。那是因为您尝试使用的 C++ 机制并非旨在以这种方式使用。
继承 - 您可以在以下情况下使用它:
为了解决使用不同参数的问题,您可以将它们封装到一个包装对象中,该对象可以从第一组或第二组创建。像这样:
class Input {
public:
Input(int angle_x, int angle_y, int P_scene, int V_scene, int M_scene);
Input(int P_scene, int V_scene, int M_scene);
...
};
class Model {
public:
virtual void draw(const Input& in);
...
};
class Bus: public Model {
public:
void draw(const Input& in) override;
...
};
class Grass: public Model {
public:
void draw(const Input& in) override;
...
};
int main() {
std::vector<Model*> models;
...
models[0]->draw(Input(angle_x, angle_y, P_scene, V_scene, M_scene));
models[1]->draw(Input(P_scene, V_scene, M_scene));
}