mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 07:56:37 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			92 lines
		
	
	
		
			No EOL
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			No EOL
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef OPENMW_ESM_CELLREF_H
 | |
| #define OPENMW_ESM_CELLREF_H
 | |
| 
 | |
| #include <string>
 | |
| 
 | |
| #include "defs.hpp"
 | |
| 
 | |
| namespace ESM
 | |
| {
 | |
|     class ESMWriter;
 | |
| 
 | |
|     /* Cell reference. This represents ONE object (of many) inside the
 | |
|     cell. The cell references are not loaded as part of the normal
 | |
|     loading process, but are rather loaded later on demand when we are
 | |
|     setting up a specific cell.
 | |
|     */
 | |
| 
 | |
|     class CellRef
 | |
|     {
 | |
|         public:
 | |
| 
 | |
|             int mRefnum;           // Reference number
 | |
|             std::string mRefID;    // ID of object being referenced
 | |
| 
 | |
|             float mScale;          // Scale applied to mesh
 | |
| 
 | |
|             // The NPC that owns this object (and will get angry if you steal
 | |
|             // it)
 | |
|             std::string mOwner;
 | |
| 
 | |
|             // I have no idea, looks like a link to a global variable?
 | |
|             std::string mGlob;
 | |
| 
 | |
|             // ID of creature trapped in this soul gem (?)
 | |
|             std::string mSoul;
 | |
| 
 | |
|             // ?? CNAM has a faction name, might be for objects/beds etc
 | |
|             // belonging to a faction.
 | |
|             std::string mFaction;
 | |
| 
 | |
|             // INDX might be PC faction rank required to use the item? Sometimes
 | |
|             // is -1, which I assume means "any rank".
 | |
|             int mFactIndex;
 | |
| 
 | |
|             // For weapon or armor, this is the remaining item health.
 | |
|             // For tools (lockpicks, probes, repair hammer) it is the remaining uses.
 | |
|             int mCharge;
 | |
| 
 | |
|             // Remaining enchantment charge
 | |
|             float mEnchantmentCharge;
 | |
| 
 | |
|             // This is 5 for Gold_005 references, 100 for Gold_100 and so on.
 | |
|             int mGoldValue;
 | |
| 
 | |
|             // For doors - true if this door teleports to somewhere else, false
 | |
|             // if it should open through animation.
 | |
|             bool mTeleport;
 | |
| 
 | |
|             // Teleport location for the door, if this is a teleporting door.
 | |
|             Position mDoorDest;
 | |
| 
 | |
|             // Destination cell for doors (optional)
 | |
|             std::string mDestCell;
 | |
| 
 | |
|             // Lock level for doors and containers
 | |
|             int mLockLevel;
 | |
|             std::string mKey, mTrap; // Key and trap ID names, if any
 | |
| 
 | |
|             // This corresponds to the "Reference Blocked" checkbox in the construction set,
 | |
|             // which prevents editing that reference.
 | |
|             // -1 is not blocked, otherwise it is blocked.
 | |
|             signed char mReferenceBlocked;
 | |
| 
 | |
|             // Track deleted references. 0 - not deleted, 1 - deleted, but respawns, 2 - deleted and does not respawn.
 | |
|             int mDeleted;
 | |
| 
 | |
|             // Occurs in Tribunal.esm, eg. in the cell "Mournhold, Plaza
 | |
|             // Brindisi Dorom", where it has the value 100. Also only for
 | |
|             // activators.
 | |
|             int mFltv;
 | |
|             int mNam0;
 | |
| 
 | |
|             // Position and rotation of this object within the cell
 | |
|             Position mPos;
 | |
| 
 | |
|             void save(ESMWriter &esm) const;
 | |
| 
 | |
|             void blank();
 | |
|     };
 | |
| }
 | |
| 
 | |
| #endif |