/** * @file inventory.hpp * @brief Provides an inventory for the player. */ #ifndef INVENTORY_HPP_ #define INVENTORY_HPP_ #include #include #include #include #include #include using namespace tinyxml2; #include #include /** * @struct Item * Contains the information neccessary for an item. */ struct Item { std::string name; /**< The name of the item */ std::string type; /**< The type of the item */ int value; /**< The value/worth of the item */ int stackSize; /**< The stack size of the item */ Texture sprite; /**< The texture for the item (in inventory) */ Item(void) : value(0), stackSize(1) {} /** * Constructs an item from XML. * @param the xml element () */ Item(XMLElement *e) { name = e->StrAttribute("name"); type = e->StrAttribute("type"); value = 0; e->QueryIntAttribute("value", &value); stackSize = 1; e->QueryIntAttribute("maxStackSize", &stackSize); sprite = Texture(e->StrAttribute("sprite")); } }; /** * @struct InventoryEntry * Describes a slot in the player's inventory. */ struct InventoryEntry { Item* item; /**< Pointer to info on what item this slot contains */ int count; /**< The quantity of this item stored here */ vec2 loc; /**< Used by render, to determine slot location on screen */ InventoryEntry(void) : item(nullptr), count(0) {} }; /** * @class InventorySystem * Handles the player's inventory system. */ class InventorySystem : public entityx::System, public entityx::Receiver { private: /** * A vector for the player's inventory slots. */ std::vector items; void loadItems(void); public: InventorySystem(int size = 20) { items.resize(size); loadItems(); } void configure(entityx::EventManager &ev); void update(entityx::EntityManager &en, entityx::EventManager &ev, entityx::TimeDelta dt) override; void receive(const KeyDownEvent &kde); void receive(const MouseClickEvent &mce); void receive(const MouseReleaseEvent &mce); void render(void); /** * Adds 'count' 'name's to the inventory. * @param name the name of the item * @param count the quantity of the item to give */ void add(const std::string& name, int count); /** * Takes 'count' 'name's from the inventory. * If the inventory does not contain enough of the item, no items are taken * and false is returned. * @param name the name of the item * @param count the quantity of the item to take * @return true if the operation could be completed */ bool take(const std::string& name, int count); }; #endif // INVENTORY_HPP_