2013-05-11 18:38:27 +02:00
|
|
|
#ifndef MWGUI_ITEM_MODEL_H
|
|
|
|
#define MWGUI_ITEM_MODEL_H
|
|
|
|
|
|
|
|
#include "../mwworld/ptr.hpp"
|
|
|
|
|
|
|
|
namespace MWGui
|
|
|
|
{
|
|
|
|
|
|
|
|
class ItemModel;
|
|
|
|
|
|
|
|
/// @brief A single item stack managed by an item model
|
|
|
|
struct ItemStack
|
|
|
|
{
|
|
|
|
ItemStack (const MWWorld::Ptr& base, ItemModel* creator, size_t count);
|
|
|
|
ItemStack();
|
|
|
|
///< like operator==, only without checking mType
|
|
|
|
|
|
|
|
enum Type
|
|
|
|
{
|
|
|
|
Type_Barter,
|
|
|
|
Type_Equipped,
|
|
|
|
Type_Normal
|
|
|
|
};
|
|
|
|
Type mType;
|
|
|
|
|
|
|
|
enum Flags
|
|
|
|
{
|
2014-09-11 19:33:45 -04:00
|
|
|
Flag_Enchanted = (1<<0),
|
|
|
|
Flag_Bound = (1<<1)
|
2013-05-11 18:38:27 +02:00
|
|
|
};
|
|
|
|
int mFlags;
|
|
|
|
|
|
|
|
ItemModel* mCreator;
|
|
|
|
size_t mCount;
|
|
|
|
MWWorld::Ptr mBase;
|
|
|
|
};
|
|
|
|
|
|
|
|
bool operator == (const ItemStack& left, const ItemStack& right);
|
|
|
|
|
|
|
|
|
|
|
|
/// @brief The base class that all item models should derive from.
|
|
|
|
class ItemModel
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
ItemModel();
|
|
|
|
virtual ~ItemModel() {}
|
|
|
|
|
2015-02-04 21:18:43 +01:00
|
|
|
typedef int ModelIndex; // -1 means invalid index
|
2013-05-11 18:38:27 +02:00
|
|
|
|
2015-02-04 21:18:43 +01:00
|
|
|
/// Throws for invalid index or out of range index
|
2013-05-11 18:38:27 +02:00
|
|
|
virtual ItemStack getItem (ModelIndex index) = 0;
|
2015-02-04 21:18:43 +01:00
|
|
|
|
|
|
|
/// The number of items in the model, this specifies the range of indices you can pass to
|
|
|
|
/// the getItem function (but this range is only valid until the next call to update())
|
2013-05-11 18:38:27 +02:00
|
|
|
virtual size_t getItemCount() = 0;
|
|
|
|
|
2015-02-04 21:18:43 +01:00
|
|
|
/// Returns an invalid index if the item was not found
|
2013-05-11 18:38:27 +02:00
|
|
|
virtual ModelIndex getIndex (ItemStack item) = 0;
|
|
|
|
|
2015-02-04 21:18:43 +01:00
|
|
|
/// Rebuild the item model, this will invalidate existing model indices
|
2013-05-11 18:38:27 +02:00
|
|
|
virtual void update() = 0;
|
|
|
|
|
2014-04-27 05:40:07 +02:00
|
|
|
/// Move items from this model to \a otherModel.
|
2015-02-04 21:18:43 +01:00
|
|
|
/// @note Derived implementations may return an empty Ptr if the move was unsuccessful.
|
2014-05-15 04:41:31 +02:00
|
|
|
virtual MWWorld::Ptr moveItem (const ItemStack& item, size_t count, ItemModel* otherModel);
|
2014-04-27 05:40:07 +02:00
|
|
|
|
2019-10-28 01:58:23 +03:00
|
|
|
virtual MWWorld::Ptr copyItem (const ItemStack& item, size_t count, bool allowAutoEquip = true) = 0;
|
2013-05-11 18:38:27 +02:00
|
|
|
virtual void removeItem (const ItemStack& item, size_t count) = 0;
|
|
|
|
|
2017-10-03 09:59:31 +04:00
|
|
|
/// Is the player allowed to use items from this item model? (default true)
|
|
|
|
virtual bool allowedToUseItems() const;
|
2017-10-04 23:26:06 +04:00
|
|
|
virtual void onClose()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
virtual bool onDropItem(const MWWorld::Ptr &item, int count);
|
|
|
|
virtual bool onTakeItem(const MWWorld::Ptr &item, int count);
|
2016-03-05 19:53:24 +01:00
|
|
|
|
2013-05-11 18:38:27 +02:00
|
|
|
private:
|
|
|
|
ItemModel(const ItemModel&);
|
|
|
|
ItemModel& operator=(const ItemModel&);
|
|
|
|
};
|
|
|
|
|
|
|
|
/// @brief A proxy item model can be used to filter or rearrange items from a source model (or even add new items to it).
|
|
|
|
/// The neat thing is that this does not actually alter the source model.
|
|
|
|
class ProxyItemModel : public ItemModel
|
|
|
|
{
|
|
|
|
public:
|
2015-08-16 17:49:37 +02:00
|
|
|
ProxyItemModel();
|
2013-05-11 18:38:27 +02:00
|
|
|
virtual ~ProxyItemModel();
|
2017-10-03 09:59:31 +04:00
|
|
|
|
2020-10-16 22:18:54 +04:00
|
|
|
bool allowedToUseItems() const override;
|
2017-10-03 09:59:31 +04:00
|
|
|
|
2020-10-16 22:18:54 +04:00
|
|
|
void onClose() override;
|
|
|
|
bool onDropItem(const MWWorld::Ptr &item, int count) override;
|
|
|
|
bool onTakeItem(const MWWorld::Ptr &item, int count) override;
|
2017-10-04 22:37:08 +04:00
|
|
|
|
2020-10-16 22:18:54 +04:00
|
|
|
MWWorld::Ptr copyItem (const ItemStack& item, size_t count, bool allowAutoEquip = true) override;
|
|
|
|
void removeItem (const ItemStack& item, size_t count) override;
|
|
|
|
ModelIndex getIndex (ItemStack item) override;
|
2013-05-11 18:38:27 +02:00
|
|
|
|
2015-08-16 17:49:37 +02:00
|
|
|
/// @note Takes ownership of the passed pointer.
|
|
|
|
void setSourceModel(ItemModel* sourceModel);
|
|
|
|
|
2013-05-11 18:38:27 +02:00
|
|
|
ModelIndex mapToSource (ModelIndex index);
|
|
|
|
ModelIndex mapFromSource (ModelIndex index);
|
|
|
|
protected:
|
|
|
|
ItemModel* mSourceModel;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|