2010-08-03 12:14:04 +00:00
|
|
|
|
|
|
|
#include "weapon.hpp"
|
|
|
|
|
|
|
|
#include <components/esm/loadweap.hpp>
|
|
|
|
|
|
|
|
#include <components/esm_store/cell_store.hpp>
|
|
|
|
|
|
|
|
#include "../mwworld/ptr.hpp"
|
2010-08-07 18:25:17 +00:00
|
|
|
#include "../mwworld/actiontake.hpp"
|
2012-03-13 14:35:06 +00:00
|
|
|
#include "../mwworld/inventorystore.hpp"
|
2010-08-03 12:14:04 +00:00
|
|
|
|
2012-01-27 14:11:02 +00:00
|
|
|
#include "../mwrender/objects.hpp"
|
2010-08-14 08:02:54 +00:00
|
|
|
|
2010-08-03 12:14:04 +00:00
|
|
|
namespace MWClass
|
|
|
|
{
|
2011-11-12 04:01:12 +00:00
|
|
|
void Weapon::insertObjectRendering (const MWWorld::Ptr& ptr, MWRender::RenderingInterface& renderingInterface) const
|
2010-08-14 08:02:54 +00:00
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Weapon, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Weapon>();
|
|
|
|
|
|
|
|
assert (ref->base != NULL);
|
|
|
|
const std::string &model = ref->base->model;
|
2012-01-27 14:11:02 +00:00
|
|
|
|
2010-08-14 08:02:54 +00:00
|
|
|
if (!model.empty())
|
|
|
|
{
|
2011-11-19 06:01:19 +00:00
|
|
|
MWRender::Objects& objects = renderingInterface.getObjects();
|
2011-11-12 04:01:12 +00:00
|
|
|
objects.insertBegin(ptr, ptr.getRefData().isEnabled(), false);
|
|
|
|
objects.insertMesh(ptr, "meshes\\" + model);
|
2010-08-14 08:02:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-11-12 04:01:12 +00:00
|
|
|
void Weapon::insertObject(const MWWorld::Ptr& ptr, MWWorld::PhysicsSystem& physics, MWWorld::Environment& environment) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Weapon, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Weapon>();
|
|
|
|
|
|
|
|
|
|
|
|
const std::string &model = ref->base->model;
|
|
|
|
assert (ref->base != NULL);
|
|
|
|
if(!model.empty()){
|
2011-11-18 00:38:52 +00:00
|
|
|
physics.insertObjectPhysics(ptr, "meshes\\" + model);
|
2011-11-12 04:01:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2010-08-03 15:11:41 +00:00
|
|
|
std::string Weapon::getName (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Weapon, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Weapon>();
|
|
|
|
|
|
|
|
return ref->base->name;
|
|
|
|
}
|
|
|
|
|
2010-08-07 18:25:17 +00:00
|
|
|
boost::shared_ptr<MWWorld::Action> Weapon::activate (const MWWorld::Ptr& ptr,
|
|
|
|
const MWWorld::Ptr& actor, const MWWorld::Environment& environment) const
|
|
|
|
{
|
|
|
|
return boost::shared_ptr<MWWorld::Action> (
|
|
|
|
new MWWorld::ActionTake (ptr));
|
|
|
|
}
|
|
|
|
|
2010-08-03 12:14:04 +00:00
|
|
|
bool Weapon::hasItemHealth (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
int Weapon::getItemMaxHealth (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Weapon, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Weapon>();
|
|
|
|
|
|
|
|
return ref->base->data.health;
|
|
|
|
}
|
|
|
|
|
2010-08-05 13:40:03 +00:00
|
|
|
std::string Weapon::getScript (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Weapon, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Weapon>();
|
|
|
|
|
|
|
|
return ref->base->script;
|
|
|
|
}
|
|
|
|
|
2012-03-13 14:35:06 +00:00
|
|
|
std::pair<std::vector<int>, bool> Weapon::getEquipmentSlots (const MWWorld::Ptr& ptr) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Weapon, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Weapon>();
|
|
|
|
|
|
|
|
std::vector<int> slots;
|
|
|
|
bool stack = false;
|
|
|
|
|
|
|
|
if (ref->base->data.type==ESM::Weapon::Arrow || ref->base->data.type==ESM::Weapon::Bolt)
|
|
|
|
{
|
|
|
|
slots.push_back (int (MWWorld::InventoryStore::Slot_Ammunition));
|
|
|
|
stack = true;
|
|
|
|
}
|
|
|
|
else if (ref->base->data.type==ESM::Weapon::MarksmanThrown)
|
|
|
|
{
|
|
|
|
slots.push_back (int (MWWorld::InventoryStore::Slot_CarriedRight));
|
|
|
|
stack = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
slots.push_back (int (MWWorld::InventoryStore::Slot_CarriedRight));
|
|
|
|
|
|
|
|
return std::make_pair (slots, stack);
|
|
|
|
}
|
|
|
|
|
|
|
|
int Weapon::getEuqipmentSkill (const MWWorld::Ptr& ptr,
|
|
|
|
const MWWorld::Environment& environment) const
|
|
|
|
{
|
|
|
|
ESMS::LiveCellRef<ESM::Weapon, MWWorld::RefData> *ref =
|
|
|
|
ptr.get<ESM::Weapon>();
|
|
|
|
|
|
|
|
const int size = 12;
|
|
|
|
|
|
|
|
static const int sMapping[size][2] =
|
|
|
|
{
|
|
|
|
{ ESM::Weapon::ShortBladeOneHand, ESM::Skill::ShortBlade },
|
|
|
|
{ ESM::Weapon::LongBladeOneHand, ESM::Skill::LongBlade },
|
|
|
|
{ ESM::Weapon::LongBladeTwoHand, ESM::Skill::LongBlade },
|
|
|
|
{ ESM::Weapon::BluntOneHand, ESM::Skill::BluntWeapon },
|
|
|
|
{ ESM::Weapon::BluntTwoClose, ESM::Skill::BluntWeapon },
|
|
|
|
{ ESM::Weapon::BluntTwoWide, ESM::Skill::BluntWeapon },
|
|
|
|
{ ESM::Weapon::SpearTwoWide, ESM::Skill::Spear },
|
|
|
|
{ ESM::Weapon::AxeOneHand, ESM::Skill::Axe },
|
|
|
|
{ ESM::Weapon::AxeTwoHand, ESM::Skill::Axe },
|
|
|
|
{ ESM::Weapon::MarksmanBow, ESM::Skill::Marksman },
|
|
|
|
{ ESM::Weapon::MarksmanCrossbow, ESM::Skill::Marksman },
|
|
|
|
{ ESM::Weapon::MarksmanThrown, ESM::Skill::Marksman }
|
|
|
|
};
|
|
|
|
|
|
|
|
for (int i=0; i<size; ++i)
|
|
|
|
if (sMapping[i][0]==ref->base->data.type)
|
|
|
|
return sMapping[i][1];
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2010-08-03 12:14:04 +00:00
|
|
|
void Weapon::registerSelf()
|
|
|
|
{
|
|
|
|
boost::shared_ptr<Class> instance (new Weapon);
|
|
|
|
|
|
|
|
registerClass (typeid (ESM::Weapon).name(), instance);
|
|
|
|
}
|
|
|
|
}
|