1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-22 07:53:51 +00:00
openmw-tes3mp/apps/openmw/mwgui/itemmodel.cpp

187 lines
5.1 KiB
C++
Raw Normal View History

2013-05-11 16:38:27 +00:00
#include "itemmodel.hpp"
#include "../mwworld/class.hpp"
#include "../mwworld/containerstore.hpp"
#include "../mwworld/esmstore.hpp"
#include "../mwbase/environment.hpp"
2017-11-10 05:43:22 +00:00
#include "../mwbase/mechanicsmanager.hpp"
2013-05-11 16:38:27 +00:00
namespace MWGui
{
ItemStack::ItemStack(const MWWorld::Ptr &base, ItemModel *creator, size_t count)
: mType(Type_Normal)
2013-05-11 16:38:27 +00:00
, mFlags(0)
, mCreator(creator)
, mCount(count)
2013-05-11 16:38:27 +00:00
, mBase(base)
{
if (base.getClass().getEnchantment(base) != "")
2013-05-11 16:38:27 +00:00
mFlags |= Flag_Enchanted;
2017-11-10 05:43:22 +00:00
if (MWBase::Environment::get().getMechanicsManager()->isBoundItem(base))
mFlags |= Flag_Bound;
2013-05-11 16:38:27 +00:00
}
ItemStack::ItemStack()
: mType(Type_Normal)
2013-05-11 16:38:27 +00:00
, mFlags(0)
2018-10-09 06:21:12 +00:00
, mCreator(nullptr)
, mCount(0)
2013-05-11 16:38:27 +00:00
{
}
bool ItemStack::stacks(const ItemStack &other)
{
if(mBase == other.mBase)
return true;
2013-05-27 00:18:36 +00:00
// If one of the items is in an inventory and currently equipped, we need to check stacking both ways to be sure
if (mBase.getContainerStore() && other.mBase.getContainerStore())
return mBase.getContainerStore()->stacks(mBase, other.mBase)
&& other.mBase.getContainerStore()->stacks(mBase, other.mBase);
if (mBase.getContainerStore())
return mBase.getContainerStore()->stacks(mBase, other.mBase);
if (other.mBase.getContainerStore())
return other.mBase.getContainerStore()->stacks(mBase, other.mBase);
MWWorld::ContainerStore store;
return store.stacks(mBase, other.mBase);
2013-05-11 16:38:27 +00:00
}
bool operator == (const ItemStack& left, const ItemStack& right)
{
if (left.mType != right.mType)
return false;
2013-05-27 00:18:36 +00:00
2013-05-11 16:38:27 +00:00
if(left.mBase == right.mBase)
return true;
2013-05-27 00:18:36 +00:00
// If one of the items is in an inventory and currently equipped, we need to check stacking both ways to be sure
if (left.mBase.getContainerStore() && right.mBase.getContainerStore())
return left.mBase.getContainerStore()->stacks(left.mBase, right.mBase)
&& right.mBase.getContainerStore()->stacks(left.mBase, right.mBase);
if (left.mBase.getContainerStore())
return left.mBase.getContainerStore()->stacks(left.mBase, right.mBase);
if (right.mBase.getContainerStore())
return right.mBase.getContainerStore()->stacks(left.mBase, right.mBase);
MWWorld::ContainerStore store;
return store.stacks(left.mBase, right.mBase);
2013-05-11 16:38:27 +00:00
}
ItemModel::ItemModel()
{
}
MWWorld::Ptr ItemModel::moveItem(const ItemStack &item, size_t count, ItemModel *otherModel)
{
MWWorld::Ptr ret = otherModel->copyItem(item, count);
removeItem(item, count);
return ret;
}
bool ItemModel::allowedToUseItems() const
{
return true;
}
2017-10-04 19:26:06 +00:00
bool ItemModel::onDropItem(const MWWorld::Ptr &item, int count)
2017-10-04 18:37:08 +00:00
{
return true;
}
2017-10-04 19:26:06 +00:00
bool ItemModel::onTakeItem(const MWWorld::Ptr &item, int count)
2017-10-04 17:25:22 +00:00
{
return true;
}
2013-05-11 16:38:27 +00:00
ProxyItemModel::ProxyItemModel()
2018-10-09 06:21:12 +00:00
: mSourceModel(nullptr)
{
}
2013-05-11 16:38:27 +00:00
ProxyItemModel::~ProxyItemModel()
{
delete mSourceModel;
}
bool ProxyItemModel::allowedToUseItems() const
{
return mSourceModel->allowedToUseItems();
}
MWWorld::Ptr ProxyItemModel::copyItem (const ItemStack& item, size_t count, bool allowAutoEquip)
2013-05-11 16:38:27 +00:00
{
return mSourceModel->copyItem (item, count, allowAutoEquip);
2013-05-11 16:38:27 +00:00
}
void ProxyItemModel::removeItem (const ItemStack& item, size_t count)
{
mSourceModel->removeItem (item, count);
}
ItemModel::ModelIndex ProxyItemModel::mapToSource (ModelIndex index)
{
const ItemStack& itemToSearch = getItem(index);
for (size_t i=0; i<mSourceModel->getItemCount(); ++i)
{
const ItemStack& item = mSourceModel->getItem(i);
if (item.mBase == itemToSearch.mBase)
2013-05-11 16:38:27 +00:00
return i;
}
return -1;
}
ItemModel::ModelIndex ProxyItemModel::mapFromSource (ModelIndex index)
{
const ItemStack& itemToSearch = mSourceModel->getItem(index);
for (size_t i=0; i<getItemCount(); ++i)
{
const ItemStack& item = getItem(i);
if (item.mBase == itemToSearch.mBase)
2013-05-11 16:38:27 +00:00
return i;
}
return -1;
}
ItemModel::ModelIndex ProxyItemModel::getIndex (ItemStack item)
{
return mSourceModel->getIndex(item);
}
void ProxyItemModel::setSourceModel(ItemModel *sourceModel)
{
if (mSourceModel == sourceModel)
return;
if (mSourceModel)
{
delete mSourceModel;
2018-10-09 06:21:12 +00:00
mSourceModel = nullptr;
}
mSourceModel = sourceModel;
}
2017-10-04 19:26:06 +00:00
void ProxyItemModel::onClose()
2017-10-04 18:37:08 +00:00
{
2017-10-04 19:26:06 +00:00
mSourceModel->onClose();
2017-10-04 18:37:08 +00:00
}
2017-10-04 19:26:06 +00:00
bool ProxyItemModel::onDropItem(const MWWorld::Ptr &item, int count)
2017-10-04 17:25:22 +00:00
{
2017-10-04 19:26:06 +00:00
return mSourceModel->onDropItem(item, count);
}
bool ProxyItemModel::onTakeItem(const MWWorld::Ptr &item, int count)
{
return mSourceModel->onTakeItem(item, count);
2017-10-04 17:25:22 +00:00
}
2013-05-11 16:38:27 +00:00
}