#include "weapon.hpp" #include #include #include "../mwworld/ptr.hpp" #include "../mwworld/actiontake.hpp" #include "../mwworld/inventorystore.hpp" #include "../mwrender/objects.hpp" namespace MWClass { void Weapon::insertObjectRendering (const MWWorld::Ptr& ptr, MWRender::RenderingInterface& renderingInterface) const { ESMS::LiveCellRef *ref = ptr.get(); assert (ref->base != NULL); const std::string &model = ref->base->model; if (!model.empty()) { MWRender::Objects& objects = renderingInterface.getObjects(); objects.insertBegin(ptr, ptr.getRefData().isEnabled(), false); objects.insertMesh(ptr, "meshes\\" + model); } } void Weapon::insertObject(const MWWorld::Ptr& ptr, MWWorld::PhysicsSystem& physics, MWWorld::Environment& environment) const { ESMS::LiveCellRef *ref = ptr.get(); const std::string &model = ref->base->model; assert (ref->base != NULL); if(!model.empty()){ physics.insertObjectPhysics(ptr, "meshes\\" + model); } } std::string Weapon::getName (const MWWorld::Ptr& ptr) const { ESMS::LiveCellRef *ref = ptr.get(); return ref->base->name; } boost::shared_ptr Weapon::activate (const MWWorld::Ptr& ptr, const MWWorld::Ptr& actor, const MWWorld::Environment& environment) const { return boost::shared_ptr ( new MWWorld::ActionTake (ptr)); } bool Weapon::hasItemHealth (const MWWorld::Ptr& ptr) const { return true; } int Weapon::getItemMaxHealth (const MWWorld::Ptr& ptr) const { ESMS::LiveCellRef *ref = ptr.get(); return ref->base->data.health; } std::string Weapon::getScript (const MWWorld::Ptr& ptr) const { ESMS::LiveCellRef *ref = ptr.get(); return ref->base->script; } std::pair, bool> Weapon::getEquipmentSlots (const MWWorld::Ptr& ptr) const { ESMS::LiveCellRef *ref = ptr.get(); std::vector 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 *ref = ptr.get(); 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; ibase->data.type) return sMapping[i][1]; return -1; } void Weapon::registerSelf() { boost::shared_ptr instance (new Weapon); registerClass (typeid (ESM::Weapon).name(), instance); } }