aboutsummaryrefslogtreecommitdiffstats
path: root/include/entities.hpp.bak
diff options
context:
space:
mode:
authorClyne Sullivan <tullivan99@gmail.com>2017-02-15 08:51:42 -0500
committerClyne Sullivan <tullivan99@gmail.com>2017-02-15 08:51:42 -0500
commit4a5d0a99f7c83c9f254cbfb8f41828831f8251db (patch)
tree26f2c99558586a1efd59640ba67ebccce5d2be46 /include/entities.hpp.bak
parent29876964587eda6e4d4bfc6543ea31efe983cf0a (diff)
screenshots, arena door
Diffstat (limited to 'include/entities.hpp.bak')
-rw-r--r--include/entities.hpp.bak542
1 files changed, 0 insertions, 542 deletions
diff --git a/include/entities.hpp.bak b/include/entities.hpp.bak
deleted file mode 100644
index e460a27..0000000
--- a/include/entities.hpp.bak
+++ /dev/null
@@ -1,542 +0,0 @@
-/* ----------------------------------------------------------------------------
-** The entity stuffs.
-**
-** Entities.
-** --------------------------------------------------------------------------*/
-#ifndef ENTITIES_H
-#define ENTITIES_H
-#define DEBUG
-
-/* ----------------------------------------------------------------------------
-** Includes section
-** --------------------------------------------------------------------------*/
-
-// local game includes
-#include <common.hpp>
-#include <quest.hpp>
-#include <inventory.hpp>
-#include <texture.hpp>
-#include <save_util.hpp>
-#include <coolarray.hpp>
-
-// local library includes
-#include <tinyxml2.h>
-using namespace tinyxml2;
-
-/* ----------------------------------------------------------------------------
-** Structures section
-** --------------------------------------------------------------------------*/
-
-/**
- * An entity type enumerator for identifying entities.
- */
-enum _TYPE {
- UNKNOWNT = -999, /**< who knows? */
- OBJECTT = -2, /**< an object (Object) */
- STRUCTURET, /**< a structure (Structures *) */
- PLAYERT, /**< the player (Player *) */
- NPCT, /**< an NPC (NPC *) */
- MERCHT, /**< a merchant (Merchant *) */
- MOBT /**< A mob (Mob *) */
-};
-
-/**
- * An enumerator for entity gender.
- */
-enum GENDER{
- MALE, /**< male */
- FEMALE /**< female */
-};
-
-/**
- * An enumerator for strcture types.
- * The subtype of a structure will affect how it is drawn and how it functions.
- */
-enum BUILD_SUB{
- TOWN_HALL = 0, /**< a town hall */
- HOUSE, /**< a generic house */
- HOUSE2, /**< a generic house of a different style */
- HOUSE3, /**< a generic house of a different style */
- HOUSE4, /**< a generic house of a different style */
- FOUNTAIN, /**< a fountain, creates water particles */
- LAMP_POST, /**< a lamppost, creates light */
- FIRE_PIT, /**< a firepit, creates fire particles / light */
- STALL_MARKET = 70, /**< a stall for a merchant */
- STALL_TRADER
-};
-
-/**
- * A structure for tracking potential trades between the player and a merchant.
- */
-struct Trade {
- // the names of the items up for trade
- std::string item[2];
- // how much of each item to trade
- int quantity[2];
-
- // constructs a trade with the given values
- Trade(int qo, std::string o, int qt, std::string t) {
- item[0] = o;
- item[1] = t;
- quantity[0] = qo;
- quantity[1] = qt;
- }
-
- // creates an empty trade item
- Trade(void) {
- item[0] = "";
- item[1] = "";
- quantity[0] = 0;
- quantity[1] = 0;
- }
-};
-typedef struct Trade Trade;
-
-/* ----------------------------------------------------------------------------
-** Variables section
-** --------------------------------------------------------------------------*/
-
-// the size of the player's inventory
-extern const unsigned int PLAYER_INV_SIZE;
-// the size of an NPC's inventory
-extern const unsigned int NPC_INV_SIZE;
-
-/* ----------------------------------------------------------------------------
-** Classes / function prototypes section
-** --------------------------------------------------------------------------*/
-
-// a prototype of the world class, necessary for some function prototypes
-class World;
-class IndoorWorld;
-
-/**
- * The light structure, used to store light coordinates and color.
- */
-
-class Light{
-public:
- vec2 loc; /**< Light location */
- Color color; /**< Light color */
- float radius; /**< Light radius */
-
- bool belongsTo;
- Entity *following;
-
- bool flame;
- float fireFlicker;
- vec2 fireLoc;
- Light()
- {
- loc = vec2(0,0);
- color = Color(1.0, 1.0, 1.0);
- radius = 0;
-
- belongsTo = false;
- following = nullptr;
-
- flame = false;
- }
-
- Light(vec2 l, float r, Color c)
- {
- loc = l;
- color = c;
- radius = r;
-
- belongsTo = false;
- following = nullptr;
-
- flame = false;
- }
-
- void follow(Entity *f)
- {
- following = f;
- belongsTo = true;
- }
-
- void makeFlame(void)
- {
- flame = true;
- }
-
- void createFromXML(XMLElement *e);
-};
-
-/**
- * The entity class.
- * This class contains common functions and variables for all types of
- * entities, i.e. a common structure.
- */
-class Entity{
-protected:
- // an incrementer for invincibility after a hit
- unsigned int hitCooldown;
-
- // an incrementer for triggering change of movement with wander()
- int ticksToUse;
-
- // entity handles an applied hit (sword) if set true
- bool forcedMove;
-
- // if set false, entity will be destroyed
- bool alive;
-
- // TODO
- float targetx;
-
- // the cooldown display (red overlay)
- float hitDuration;
-
- // the max cooldown display
- float maxHitDuration;
-
- // the entity's XML element, for saving/loading stuff
- XMLElement *xmle;
-
-public:
- // contains the entity's coordinates, in pixels
- vec2 loc;
- float z;
-
- // contains the entity's velocity, in pixels
- vec2 vel;
-
- // the entity's width, in pixels
- float width;
-
- // the entity's height, in pixels
- float height;
-
- // a speed multiplier, applied to velocity
- float speed;
-
- // when true player may interact, and the entity's name will be drawn
- bool near;
-
- // when true, the entity can move
- int canMove;
-
- // tells direction entity is facing
- bool right, left;
-
- // tells if the entity is from another world
- char outnabout;
-
- // set to 1 if entity is on the ground, 0 if in the air
- unsigned char ground;
-
- // the entity's inventory
- Inventory *inv;
-
- // the entity's light
- Light light;
-
- // the entity's health
- float health;
-
- // the most health the entity can have
- float maxHealth;
-
- // the type of the entity
- _TYPE type;
-
- // the entity's subtype, if applicable
- int subtype;
-
- // the entity's name, randomly generated on spawn
- std::string name;
-
- // the entity's gender
- GENDER gender;
-
- // a texture handler for the entity
- TextureIterator tex;
-
- // draws the entity to the screen
- void draw(void);
-
- // spawns the entity at the given coordinates
- void spawn(float, float);
-
- // allows the entity to wander, according to what class is deriving this.
- virtual void wander(int){}
- virtual void wander(void){}
-
- // allows the entity to interact with the player
- virtual void interact(void){}
-
- // causes the entity to move to the given x coordinate
- void moveTo(float dest_x);
-
- // causes the entity to follow the one provided
- void follow(Entity *e);
-
- // causes the entity to take a player-inflicted hit
- void takeHit(unsigned int _health, unsigned int cooldown);
-
- // returns the amount of cool down before next hit
- unsigned int coolDown();
-
- // set the cool down
- void setCooldown(unsigned int c);
-
- // handles hits if they've been taken
- void handleHits(void);
-
- // insures that the entity is dead
- void die(void);
-
- // checks if the entity is alive
- bool isAlive(void) const;
-
- // checks if the entity is hit in some way
- bool isHit(void) const;
-
- // returns true if this entity is near the one provided
- bool isNear(const Entity *e);
-
- // returns true if the coordinate is within the entity
- bool isInside(vec2 coord) const;
-
- // constructs the entity with an XML thing-thang
- virtual void createFromXML(XMLElement *e, World *w=nullptr) =0;
- virtual void saveToXML(void) =0;
-
-/* Entity
-
- **
- * Forces the given entity to follow this one.
- *
- void lead(Entity *e, unsigned int how);
-
- **
- * Attempts to break free from any following.
- *
- void unfollow(void);*/
-
- // a common constructor, clears variables
- Entity(void);
-
- // frees memory taken by the entity
- virtual ~Entity(){}
-};
-
-class Player : public Entity {
-public:
- Entity *ride;
- QuestHandler qh;
-
- Player();
- ~Player();
- void save(void);
- void sspawn(float x,float y);
- void createFromXML(XMLElement *e, World *w);
- void saveToXML(void);
-};
-
-class Structures : public Entity {
-public:
- BUILD_SUB bsubtype;
- World *inWorld;
- World *insideWorld;
- std::string inside;
- std::string textureLoc;
-
- GLuint insideTex;
-
- Structures();
- ~Structures();
-
- unsigned int spawn(BUILD_SUB, float, float);
- void createFromXML(XMLElement *e, World *w);
- void saveToXML(void);
-};
-
-
-class NPC : public Entity {
-private:
- // the number of the random dialog to use
- unsigned int randDialog;
-
- unsigned int dialogCount;
-
-public:
- int dialogIndex;
-
- NPC();
- ~NPC();
-
- void drawThingy(void) const;
-
- void addAIFunc(bool preload);
-
- void interact();
- void wander(int);
- void createFromXML(XMLElement *e, World *w);
- void saveToXML(void);
-};
-
-class Merchant : public NPC {
-public:
- std::vector<Trade>trade;
- uint currTrade;
-
- std::string text[4];
- std::string *toSay;
- //greeting
- //accept
- //deny
- //farewell
-
- void interact();
- Structures *inside;
-
- Merchant();
- ~Merchant();
-
- void wander(int);
- void saveToXML(void);
-};
-
-class Object : public Entity{
-public:
- std::string iname;
- std::string pickupDialog;
- bool questObject = false;
-
- Object();
- Object(std::string in,std::string pd);
- ~Object();
-
- void reloadTexture(void);
-
- void interact(void);
-
- bool operator==(const Object &o) {
- return (name == o.name) && (loc == o.loc);
- }
- void createFromXML(XMLElement *e, World *w);
- void saveToXML(void);
-};
-
-/**
- * The particle class, handles a single particle.
- */
-class Particles{
-public:
- // the location of the particle
- vec2 loc;
- float zOffset;
-
- // the width of the particle, in pixels
- float width;
-
- // the height of the particle, in pixels
- float height;
-
- // the velocity of the particle, in pixels
- vec2 vel;
-
- // the color of the particle
- Color color;
-
- // TODO
- vec2 index;
-
- // the amount of milliseconds left for the particle to live
- float duration;
-
- // when true, the particle will move
- bool canMove;
-
- // TODO
- bool fountain;
-
- // when true, the particle will be affected by gravity
- bool gravity;
-
- // when true, draws the particle behind structures
- bool behind;
-
- // when true, the particle will bounce on impact with ground
- bool bounce;
-
- Structures *stu;
-
- Particles(void){}
-
- // creates a particle with the desired characteristics
- Particles(float x, float y, float w, float h, float vx, float vy, Color c, float d);
-
- // allows the particle to be destroyed
- ~Particles(void){}
-
- // draws the particle
- void draw(GLfloat*& p) const;
-
- // updates a particle
- void update(float _gravity, float ground_y);
-
- // returns true if the particle should be killed
- bool timeUp(void);
-};
-
-#include <mob.hpp>
-
-constexpr Object *Objectp(Entity *e) {
- return (Object *)e;
-}
-
-constexpr NPC *NPCp(Entity *e) {
- return (NPC *)e;
-}
-
-constexpr Structures *Structurep(Entity *e) {
- return (Structures *)e;
-}
-
-constexpr Merchant *Merchantp(Entity *e) {
- return (Merchant *)e;
-}
-
-#include <entityx/entityx.h>
-#include <events.hpp>
-
-class PlayerSystem : public entityx::System<PlayerSystem>, public entityx::Receiver<PlayerSystem> {
-private:
- Player **m_Player;
- bool m_MoveLeft, m_MoveRight;
-
-public:
- PlayerSystem(Player **p)
- : m_Player(p), m_MoveLeft(false), m_MoveRight(false) {}
-
- void update(entityx::EntityManager &en, entityx::EventManager &ev, entityx::TimeDelta dt) override;
-
- void configure(entityx::EventManager &ev);
- void receive(const KeyDownEvent &kde);
- void receive(const KeyUpEvent &kue);
-};
-
-void entityxTest();
-
-#endif // ENTITIES_H
-
-/**
-ENTITY TYPES
--1 STRUCTURES
-|->1 Village
-|->2 Castle
-|
-0 PLAYERS
-|->Player
-|
-1 NPCS
-|->0 Base
-|->1 Merchant
-|
-2 MOBS
-|->1 Rabbit
-|->2 Bird
-**/