From 326cd4e5fdc396c5c34ac9371b53d2838ea9ee4d Mon Sep 17 00:00:00 2001 From: Andy Date: Fri, 14 Oct 2016 08:19:30 -0400 Subject: Started some fancy work on components --- brice.dat | 6 +-- include/components.hpp | 137 +++++++++++++++++++++++++++++++++++++++++++++++++ src/entities.cpp | 5 ++ xml/!town.xml | 10 ++-- xml/mobs.xml | 15 ++++++ 5 files changed, 165 insertions(+), 8 deletions(-) create mode 100644 include/components.hpp create mode 100644 xml/mobs.xml diff --git a/brice.dat b/brice.dat index 2653f9c..308f5c8 100644 --- a/brice.dat +++ b/brice.dat @@ -1,7 +1,7 @@ 3 Slow -1 -canJump 0 +canJump +1 canSprint -0 +1 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 + +/** + * @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> 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 diff --git a/src/entities.cpp b/src/entities.cpp index 0f8c3b7..3afcc40 100644 --- a/src/entities.cpp +++ b/src/entities.cpp @@ -12,6 +12,11 @@ #include #include +///NEW +#include +#include +///OLD + extern std::istream *names; extern Player *player; // main.cpp diff --git a/xml/!town.xml b/xml/!town.xml index a03e0bf..3ac9772 100644 --- a/xml/!town.xml +++ b/xml/!town.xml @@ -4,11 +4,11 @@ -300 - - - - - + + + + + diff --git a/xml/mobs.xml b/xml/mobs.xml new file mode 100644 index 0000000..238c582 --- /dev/null +++ b/xml/mobs.xml @@ -0,0 +1,15 @@ + + + + + + + + + + + 10 + + + + -- cgit v1.2.3