/** * @file components.hpp * @brief Where all of an enities possible components are stored. * Using an ECS (Entity component system) the entities are given components on the fly, * this allows the entity to change stats or skills on the go. This also allows every "object" * the be an entity, and it gives the game a much better customizability over xml. */ #ifndef COMPONENTS_HPP #define COMPONENTS_HPP #include /** * @struct Position * @brief Stores the position of an entity on the xy plane. */ struct Position { /** * Constructor that sets the position of the object, if nothing is passed it will default to 0. * @param x The x position the object will be placed at. * @param y the y position the object will be placed at. */ Position(float x = 0.0f, float y = 0.0f): x(x), y(y) {} float x; /**< The x position in the world */ float y; /**< The y position in the world */ }; /** * @struct Direction * @brief Store an entities velocity. * This allows the entity to move throughout the world. */ struct Direction { /** * Constructor that sets the velocity, if no position is passed, it defaults to (0,0). * @param x The velocity of the object on the x axis. * @param y The velocity of the object on the y axis. */ Direction(float x = 0.0f, float y = 0.0f): x(x), y(y) {} float x; /**< Velocity the object is moving in the x direction, this is added to the position */ float y; /**< Velocity the object is moving in the y direction, this is added to the position */ }; /** * @struct Physics * @brief Allows and entity to react to gravity and frictions. * When an entity inherits this component it will react with gravity and move with friction. */ struct Physics { /** * Constructor that sets the gravity constant, if not specified it becomes 0. * @param g The non default gravity constant. */ Physics(float g = 0.0f): g(g) {} float g; /**< The gravity constant, how fast the object falls */ }; /** * @struct Health * @brief Gives and entity health and stuff. */ struct Health { /** * Constructor that sets the variables, with 0 health as default. */ Health(int h = 0, int m = 0) : health(h), maxHealth(m) {} int health; int maxHealth; }; /** * @struct Solid * @brief Allows an entity to collide with other objects. * When an entity has this component it can collide with the world and other objects. */ struct Solid { /** * Constructor that sets the entities dimensions based on what is passed. * @param w The desired width of the entity. * @param h The desired height of the entity. */ Solid(float w = 0.0f, float h = 0.0f): width(w), height(h) {} float width; /**< The width of the entity in units */ float height; /**< The height of the entity in units */ }; struct SpriteData { uint sheetID; vec2 offset; vec2 size; }; //TODO /** * @struct Sprite * @brief If an entity is visible we want to be able to see it. * Each entity is given a sprite, a sprite can consist of manu frames or pieces to make one. */ struct Sprite { std::vector> getSprite() { return sprite; } int clearSprite() { if (sprite.empty()) return 0; sprite.clear(); return 1; } int addSpriteSegment(SpriteData data, vec2 loc) { //TODO if sprite is in this spot, do something sprite.push_back(std::make_pair(data, loc)); return 1; } int changeSpriteSegment(SpriteData data, vec2 loc) { for (auto &s : sprite) { if (s.second == loc) { s.first = data; return 1; } } addSpriteSegment(data, loc); return 0; } std::vector> sprite; }; //TODO struct Animate { std::vector> sprite_e; std::vector> sprite_c; }; //TODO struct Input { }; #endif //COMPONENTS_HPP