mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 03:26:37 +00:00 
			
		
		
		
	implemented new equipment functions in MWClass
This commit is contained in:
		
							parent
							
								
									c314cddb1c
								
							
						
					
					
						commit
						cbbc295eb6
					
				
					 12 changed files with 260 additions and 0 deletions
				
			
		|  | @ -2,11 +2,16 @@ | |||
| #include "armor.hpp" | ||||
| 
 | ||||
| #include <components/esm/loadarmo.hpp> | ||||
| #include <components/esm/loadskil.hpp> | ||||
| #include <components/esm/loadgmst.hpp> | ||||
| 
 | ||||
| #include <components/esm_store/cell_store.hpp> | ||||
| 
 | ||||
| #include "../mwworld/ptr.hpp" | ||||
| #include "../mwworld/actiontake.hpp" | ||||
| #include "../mwworld/inventorystore.hpp" | ||||
| #include "../mwworld/environment.hpp" | ||||
| #include "../mwworld/world.hpp" | ||||
| 
 | ||||
| #include "../mwrender/objects.hpp" | ||||
| 
 | ||||
|  | @ -77,6 +82,79 @@ namespace MWClass | |||
|         return ref->base->script; | ||||
|     } | ||||
| 
 | ||||
|     std::pair<std::vector<int>, bool> Armor::getEquipmentSlots (const MWWorld::Ptr& ptr) const | ||||
|     { | ||||
|         ESMS::LiveCellRef<ESM::Armor, MWWorld::RefData> *ref = | ||||
|             ptr.get<ESM::Armor>(); | ||||
| 
 | ||||
|         std::vector<int> slots; | ||||
| 
 | ||||
|         const int size = 11; | ||||
| 
 | ||||
|         static const int sMapping[size][2] = | ||||
|         { | ||||
|             { ESM::Armor::Helmet, MWWorld::InventoryStore::Slot_Helmet }, | ||||
|             { ESM::Armor::Cuirass, MWWorld::InventoryStore::Slot_Cuirass }, | ||||
|             { ESM::Armor::LPauldron, MWWorld::InventoryStore::Slot_LeftPauldron }, | ||||
|             { ESM::Armor::RPauldron, MWWorld::InventoryStore::Slot_RightPauldron }, | ||||
|             { ESM::Armor::Greaves, MWWorld::InventoryStore::Slot_Greaves }, | ||||
|             { ESM::Armor::Boots, MWWorld::InventoryStore::Slot_Boots }, | ||||
|             { ESM::Armor::LGauntlet, MWWorld::InventoryStore::Slot_LeftGauntlet }, | ||||
|             { ESM::Armor::RGauntlet, MWWorld::InventoryStore::Slot_RightGauntlet }, | ||||
|             { ESM::Armor::Shield, MWWorld::InventoryStore::Slot_CarriedLeft }, | ||||
|             { ESM::Armor::LBracer, MWWorld::InventoryStore::Slot_LeftGauntlet }, | ||||
|             { ESM::Armor::RBracer, MWWorld::InventoryStore::Slot_RightGauntlet } | ||||
|         }; | ||||
| 
 | ||||
|         for (int i=0; i<size; ++i) | ||||
|             if (sMapping[i][0]==ref->base->data.type) | ||||
|             { | ||||
|                 slots.push_back (int (sMapping[i][1])); | ||||
|                 break; | ||||
|             } | ||||
| 
 | ||||
|         return std::make_pair (slots, false); | ||||
|     } | ||||
| 
 | ||||
|     int Armor::getEuqipmentSkill (const MWWorld::Ptr& ptr, const MWWorld::Environment& environment) const | ||||
|     { | ||||
|         ESMS::LiveCellRef<ESM::Armor, MWWorld::RefData> *ref = | ||||
|             ptr.get<ESM::Armor>(); | ||||
| 
 | ||||
|         std::string typeGmst; | ||||
| 
 | ||||
|         switch (ref->base->data.type) | ||||
|         { | ||||
|             case ESM::Armor::Helmet: typeGmst = "iHelmWeight"; break; | ||||
|             case ESM::Armor::Cuirass: typeGmst = "iCuirassWeight"; break; | ||||
|             case ESM::Armor::LPauldron: | ||||
|             case ESM::Armor::RPauldron: typeGmst = "iPauldronWeight"; break; | ||||
|             case ESM::Armor::Greaves: typeGmst = "iGreavesWeight"; break; | ||||
|             case ESM::Armor::Boots: typeGmst = "iBootsWeight"; break; | ||||
|             case ESM::Armor::LGauntlet: | ||||
|             case ESM::Armor::RGauntlet: typeGmst = "iGauntletWeight"; break; | ||||
| /// \todo how to determine if shield light, medium or heavy?
 | ||||
| //            case ESM::Armor::Shield:
 | ||||
|             case ESM::Armor::LBracer: | ||||
|             case ESM::Armor::RBracer: typeGmst = "iGauntletWeight"; break; | ||||
|         } | ||||
| 
 | ||||
|         if (typeGmst.empty()) | ||||
|             return -1; | ||||
| 
 | ||||
|         float iWeight = environment.mWorld->getStore().gameSettings.find (typeGmst)->f; | ||||
| 
 | ||||
|         if (iWeight * environment.mWorld->getStore().gameSettings.find ("fLightMaxMod")->f<= | ||||
|             ref->base->data.weight) | ||||
|             return ESM::Skill::LightArmor; | ||||
| 
 | ||||
|         if (iWeight * environment.mWorld->getStore().gameSettings.find ("fMedMaxMod")->f<= | ||||
|             ref->base->data.weight) | ||||
|             return ESM::Skill::MediumArmor; | ||||
| 
 | ||||
|         return ESM::Skill::HeavyArmor; | ||||
|     } | ||||
| 
 | ||||
|     void Armor::registerSelf() | ||||
|     { | ||||
|         boost::shared_ptr<Class> instance (new Armor); | ||||
|  |  | |||
|  | @ -31,6 +31,15 @@ namespace MWClass | |||
|             virtual std::string getScript (const MWWorld::Ptr& ptr) const; | ||||
|             ///< Return name of the script attached to ptr
 | ||||
| 
 | ||||
|             virtual std::pair<std::vector<int>, bool> getEquipmentSlots (const MWWorld::Ptr& ptr) const; | ||||
|             ///< \return first: Return IDs of the slot this object can be equipped in; second: can object
 | ||||
|             /// stay stacked when equipped?
 | ||||
| 
 | ||||
|             virtual int getEuqipmentSkill (const MWWorld::Ptr& ptr, | ||||
|                 const MWWorld::Environment& environment) const; | ||||
|             /// Return the index of the skill this item corresponds to when equiopped or -1, if there is
 | ||||
|             /// no such skill.
 | ||||
| 
 | ||||
|             static void registerSelf(); | ||||
|     }; | ||||
| } | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ | |||
| 
 | ||||
| #include "../mwworld/ptr.hpp" | ||||
| #include "../mwworld/actiontake.hpp" | ||||
| #include "../mwworld/inventorystore.hpp" | ||||
| 
 | ||||
| #include "../mwrender/objects.hpp" | ||||
| 
 | ||||
|  | @ -65,6 +66,58 @@ namespace MWClass | |||
|         return ref->base->script; | ||||
|     } | ||||
| 
 | ||||
|     std::pair<std::vector<int>, bool> Clothing::getEquipmentSlots (const MWWorld::Ptr& ptr) const | ||||
|     { | ||||
|         ESMS::LiveCellRef<ESM::Clothing, MWWorld::RefData> *ref = | ||||
|             ptr.get<ESM::Clothing>(); | ||||
| 
 | ||||
|         std::vector<int> slots; | ||||
| 
 | ||||
|         if (ref->base->data.type==ESM::Clothing::Ring) | ||||
|         { | ||||
|             slots.push_back (int (MWWorld::InventoryStore::Slot_LeftRing)); | ||||
|             slots.push_back (int (MWWorld::InventoryStore::Slot_RightRing)); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             const int size = 9; | ||||
| 
 | ||||
|             static const int sMapping[size][2] = | ||||
|             { | ||||
|                 { ESM::Clothing::Shirt, MWWorld::InventoryStore::Slot_Cuirass }, | ||||
|                 { ESM::Clothing::Belt, MWWorld::InventoryStore::Slot_Belt }, | ||||
|                 { ESM::Clothing::Robe, MWWorld::InventoryStore::Slot_Robe }, | ||||
|                 { ESM::Clothing::Pants, MWWorld::InventoryStore::Slot_Pants }, | ||||
|                 { ESM::Clothing::Shoes, MWWorld::InventoryStore::Slot_Boots }, | ||||
|                 { ESM::Clothing::LGlove, MWWorld::InventoryStore::Slot_LeftGauntlet }, | ||||
|                 { ESM::Clothing::RGlove, MWWorld::InventoryStore::Slot_RightGauntlet }, | ||||
|                 { ESM::Clothing::Skirt, MWWorld::InventoryStore::Slot_Skirt }, | ||||
|                 { ESM::Clothing::Amulet, MWWorld::InventoryStore::Slot_Amulet } | ||||
|             }; | ||||
| 
 | ||||
|             for (int i=0; i<size; ++i) | ||||
|                 if (sMapping[i][0]==ref->base->data.type) | ||||
|                 { | ||||
|                     slots.push_back (int (sMapping[i][1])); | ||||
|                     break; | ||||
|                 } | ||||
|         } | ||||
| 
 | ||||
|         return std::make_pair (slots, false); | ||||
|     } | ||||
| 
 | ||||
|     int Clothing::getEuqipmentSkill (const MWWorld::Ptr& ptr, | ||||
|         const MWWorld::Environment& environment) const | ||||
|     { | ||||
|         ESMS::LiveCellRef<ESM::Clothing, MWWorld::RefData> *ref = | ||||
|             ptr.get<ESM::Clothing>(); | ||||
| 
 | ||||
|         if (ref->base->data.type==ESM::Clothing::Shoes) | ||||
|             return ESM::Skill::Unarmored; | ||||
| 
 | ||||
|         return -1; | ||||
|     } | ||||
| 
 | ||||
|     void Clothing::registerSelf() | ||||
|     { | ||||
|         boost::shared_ptr<Class> instance (new Clothing); | ||||
|  |  | |||
|  | @ -25,6 +25,15 @@ namespace MWClass | |||
|             virtual std::string getScript (const MWWorld::Ptr& ptr) const; | ||||
|             ///< Return name of the script attached to ptr
 | ||||
| 
 | ||||
|             virtual std::pair<std::vector<int>, bool> getEquipmentSlots (const MWWorld::Ptr& ptr) const; | ||||
|             ///< \return first: Return IDs of the slot this object can be equipped in; second: can object
 | ||||
|             /// stay stacked when equipped?
 | ||||
| 
 | ||||
|             virtual int getEuqipmentSkill (const MWWorld::Ptr& ptr, | ||||
|                 const MWWorld::Environment& environment) const; | ||||
|             /// Return the index of the skill this item corresponds to when equiopped or -1, if there is
 | ||||
|             /// no such skill.
 | ||||
| 
 | ||||
|             static void registerSelf(); | ||||
|     }; | ||||
| } | ||||
|  |  | |||
|  | @ -9,6 +9,7 @@ | |||
| #include "../mwworld/actiontake.hpp" | ||||
| #include "../mwworld/nullaction.hpp" | ||||
| #include "../mwworld/environment.hpp" | ||||
| #include "../mwworld/inventorystore.hpp" | ||||
| 
 | ||||
| #include "../mwsound/soundmanager.hpp" | ||||
| 
 | ||||
|  | @ -94,6 +95,19 @@ namespace MWClass | |||
|         return ref->base->script; | ||||
|     } | ||||
| 
 | ||||
|     std::pair<std::vector<int>, bool> Light::getEquipmentSlots (const MWWorld::Ptr& ptr) const | ||||
|     { | ||||
|         ESMS::LiveCellRef<ESM::Light, MWWorld::RefData> *ref = | ||||
|             ptr.get<ESM::Light>(); | ||||
| 
 | ||||
|         std::vector<int> slots; | ||||
| 
 | ||||
|         if (ref->base->data.flags & ESM::Light::Carry) | ||||
|             slots.push_back (int (MWWorld::InventoryStore::Slot_CarriedLeft)); | ||||
| 
 | ||||
|         return std::make_pair (slots, false); | ||||
|     } | ||||
| 
 | ||||
|     void Light::registerSelf() | ||||
|     { | ||||
|         boost::shared_ptr<Class> instance (new Light); | ||||
|  |  | |||
|  | @ -30,6 +30,10 @@ namespace MWClass | |||
|             virtual std::string getScript (const MWWorld::Ptr& ptr) const; | ||||
|             ///< Return name of the script attached to ptr
 | ||||
| 
 | ||||
|             virtual std::pair<std::vector<int>, bool> getEquipmentSlots (const MWWorld::Ptr& ptr) const; | ||||
|             ///< \return first: Return IDs of the slot this object can be equipped in; second: can object
 | ||||
|             /// stay stacked when equipped?
 | ||||
| 
 | ||||
|             static void registerSelf(); | ||||
|     }; | ||||
| } | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ | |||
| 
 | ||||
| #include "../mwworld/ptr.hpp" | ||||
| #include "../mwworld/actiontake.hpp" | ||||
| #include "../mwworld/inventorystore.hpp" | ||||
| 
 | ||||
| #include "../mwrender/objects.hpp" | ||||
| 
 | ||||
|  | @ -66,6 +67,15 @@ namespace MWClass | |||
|         return ref->base->script; | ||||
|     } | ||||
| 
 | ||||
|     std::pair<std::vector<int>, bool> Lockpick::getEquipmentSlots (const MWWorld::Ptr& ptr) const | ||||
|     { | ||||
|         std::vector<int> slots; | ||||
| 
 | ||||
|         slots.push_back (int (MWWorld::InventoryStore::Slot_CarriedRight)); | ||||
| 
 | ||||
|         return std::make_pair (slots, false); | ||||
|     } | ||||
| 
 | ||||
|     void Lockpick::registerSelf() | ||||
|     { | ||||
|         boost::shared_ptr<Class> instance (new Lockpick); | ||||
|  |  | |||
|  | @ -25,6 +25,10 @@ namespace MWClass | |||
|             virtual std::string getScript (const MWWorld::Ptr& ptr) const; | ||||
|             ///< Return name of the script attached to ptr
 | ||||
| 
 | ||||
|             virtual std::pair<std::vector<int>, bool> getEquipmentSlots (const MWWorld::Ptr& ptr) const; | ||||
|             ///< \return first: Return IDs of the slot this object can be equipped in; second: can object
 | ||||
|             /// stay stacked when equipped?
 | ||||
| 
 | ||||
|             static void registerSelf(); | ||||
|     }; | ||||
| } | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ | |||
| 
 | ||||
| #include "../mwworld/ptr.hpp" | ||||
| #include "../mwworld/actiontake.hpp" | ||||
| #include "../mwworld/inventorystore.hpp" | ||||
| 
 | ||||
| #include "../mwrender/objects.hpp" | ||||
| 
 | ||||
|  | @ -65,6 +66,15 @@ namespace MWClass | |||
|         return ref->base->script; | ||||
|     } | ||||
| 
 | ||||
|     std::pair<std::vector<int>, bool> Probe::getEquipmentSlots (const MWWorld::Ptr& ptr) const | ||||
|     { | ||||
|         std::vector<int> slots; | ||||
| 
 | ||||
|         slots.push_back (int (MWWorld::InventoryStore::Slot_CarriedRight)); | ||||
| 
 | ||||
|         return std::make_pair (slots, false); | ||||
|     } | ||||
| 
 | ||||
|     void Probe::registerSelf() | ||||
|     { | ||||
|         boost::shared_ptr<Class> instance (new Probe); | ||||
|  |  | |||
|  | @ -25,6 +25,10 @@ namespace MWClass | |||
|             virtual std::string getScript (const MWWorld::Ptr& ptr) const; | ||||
|             ///< Return name of the script attached to ptr
 | ||||
| 
 | ||||
|             virtual std::pair<std::vector<int>, bool> getEquipmentSlots (const MWWorld::Ptr& ptr) const; | ||||
|             ///< \return first: Return IDs of the slot this object can be equipped in; second: can object
 | ||||
|             /// stay stacked when equipped?
 | ||||
| 
 | ||||
|             static void registerSelf(); | ||||
|     }; | ||||
| } | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ | |||
| 
 | ||||
| #include "../mwworld/ptr.hpp" | ||||
| #include "../mwworld/actiontake.hpp" | ||||
| #include "../mwworld/inventorystore.hpp" | ||||
| 
 | ||||
| #include "../mwrender/objects.hpp" | ||||
| 
 | ||||
|  | @ -78,6 +79,61 @@ namespace MWClass | |||
|         return ref->base->script; | ||||
|     } | ||||
| 
 | ||||
|     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; | ||||
|     } | ||||
| 
 | ||||
|     void Weapon::registerSelf() | ||||
|     { | ||||
|         boost::shared_ptr<Class> instance (new Weapon); | ||||
|  |  | |||
|  | @ -31,6 +31,15 @@ namespace MWClass | |||
|             virtual std::string getScript (const MWWorld::Ptr& ptr) const; | ||||
|             ///< Return name of the script attached to ptr
 | ||||
| 
 | ||||
|             virtual std::pair<std::vector<int>, bool> getEquipmentSlots (const MWWorld::Ptr& ptr) const; | ||||
|             ///< \return first: Return IDs of the slot this object can be equipped in; second: can object
 | ||||
|             /// stay stacked when equipped?
 | ||||
| 
 | ||||
|             virtual int getEuqipmentSkill (const MWWorld::Ptr& ptr, | ||||
|                 const MWWorld::Environment& environment) const; | ||||
|             /// Return the index of the skill this item corresponds to when equiopped or -1, if there is
 | ||||
|             /// no such skill.
 | ||||
| 
 | ||||
|             static void registerSelf(); | ||||
|     }; | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue