aboutsummaryrefslogtreecommitdiffstats
path: root/include/components.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'include/components.hpp')
-rw-r--r--include/components.hpp137
1 files changed, 137 insertions, 0 deletions
diff --git a/include/components.hpp b/include/components.hpp
new file mode 100644
index 0000000..34a1906
--- /dev/null
+++ b/include/components.hpp
@@ -0,0 +1,137 @@
+/**
+ * @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 <entityx/entityx.h>
+
+/**
+ * @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 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<std::pair<SpriteData, vec2>> 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<std::pair<SpriteData, vec2>> sprite;
+};
+
+//TODO
+struct Animate {
+ std::vector<std::pair<SpriteData, vec2>> sprite_e;
+ std::vector<std::pair<SpriteData, vec2>> sprite_c;
+};
+
+//TODO
+
+struct Input {
+
+};
+
+#endif //COMPONENTS_HPP