mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 07:56:37 +00:00 
			
		
		
		
	
						commit
						b286397dd4
					
				
					 49 changed files with 341 additions and 341 deletions
				
			
		|  | @ -44,7 +44,6 @@ | ||||||
|     Bug #5367: Selecting a spell on an enchanted item per hotkey always plays the equip sound |     Bug #5367: Selecting a spell on an enchanted item per hotkey always plays the equip sound | ||||||
|     Bug #5369: Spawnpoint in the Grazelands doesn't produce oversized creatures |     Bug #5369: Spawnpoint in the Grazelands doesn't produce oversized creatures | ||||||
|     Bug #5370: Opening an unlocked but trapped door uses the key |     Bug #5370: Opening an unlocked but trapped door uses the key | ||||||
|     Bug #5379: Wandering NPCs falling through cantons |  | ||||||
|     Bug #5384: openmw-cs: deleting an instance requires reload of scene window to show in editor |     Bug #5384: openmw-cs: deleting an instance requires reload of scene window to show in editor | ||||||
|     Bug #5387: Move/MoveWorld don't update the object's cell properly |     Bug #5387: Move/MoveWorld don't update the object's cell properly | ||||||
|     Bug #5391: Races Redone 1.2 bodies don't show on the inventory |     Bug #5391: Races Redone 1.2 bodies don't show on the inventory | ||||||
|  |  | ||||||
|  | @ -38,10 +38,10 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Activator::insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const |     void Activator::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|     { |     { | ||||||
|         if(!model.empty()) |         if(!model.empty()) | ||||||
|             physics.addObject(ptr, model, rotation); |             physics.addObject(ptr, model); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::string Activator::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Activator::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|  |  | ||||||
|  | @ -17,7 +17,7 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const override; |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
| 
 | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
|  |  | ||||||
|  | @ -17,12 +17,16 @@ | ||||||
| 
 | 
 | ||||||
| namespace MWClass | namespace MWClass | ||||||
| { | { | ||||||
|  |     Actor::Actor() {} | ||||||
|  | 
 | ||||||
|  |     Actor::~Actor() {} | ||||||
|  | 
 | ||||||
|     void Actor::adjustPosition(const MWWorld::Ptr& ptr, bool force) const |     void Actor::adjustPosition(const MWWorld::Ptr& ptr, bool force) const | ||||||
|     { |     { | ||||||
|         MWBase::Environment::get().getWorld()->adjustPosition(ptr, force); |         MWBase::Environment::get().getWorld()->adjustPosition(ptr, force); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Actor::insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const |     void Actor::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|     { |     { | ||||||
|         if (!model.empty()) |         if (!model.empty()) | ||||||
|         { |         { | ||||||
|  |  | ||||||
|  | @ -15,16 +15,16 @@ namespace MWClass | ||||||
|     { |     { | ||||||
|     protected: |     protected: | ||||||
| 
 | 
 | ||||||
|         Actor() = default; |         Actor(); | ||||||
| 
 | 
 | ||||||
|     public: |     public: | ||||||
|          ~Actor() override = default; |         virtual ~Actor(); | ||||||
| 
 | 
 | ||||||
|         void adjustPosition(const MWWorld::Ptr& ptr, bool force) const override; |         void adjustPosition(const MWWorld::Ptr& ptr, bool force) const override; | ||||||
|         ///< Adjust position to stand on ground. Must be called post model load
 |         ///< Adjust position to stand on ground. Must be called post model load
 | ||||||
|         /// @param force do this even if the ptr is flying
 |         /// @param force do this even if the ptr is flying
 | ||||||
| 
 | 
 | ||||||
|         void insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const override; |         void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
| 
 | 
 | ||||||
|         bool useAnim() const override; |         bool useAnim() const override; | ||||||
| 
 | 
 | ||||||
|  | @ -46,8 +46,8 @@ namespace MWClass | ||||||
|         float getCurrentSpeed(const MWWorld::Ptr& ptr) const override; |         float getCurrentSpeed(const MWWorld::Ptr& ptr) const override; | ||||||
|          |          | ||||||
|         // not implemented
 |         // not implemented
 | ||||||
|         Actor(const Actor&) = delete; |         Actor(const Actor&); | ||||||
|         Actor& operator= (const Actor&) = delete; |         Actor& operator= (const Actor&); | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -26,6 +26,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Apparatus::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Apparatus::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Apparatus::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Apparatus> *ref = ptr.get<ESM::Apparatus>(); |         const MWWorld::LiveCellRef<ESM::Apparatus> *ref = ptr.get<ESM::Apparatus>(); | ||||||
|  |  | ||||||
|  | @ -17,6 +17,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -34,6 +34,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Armor::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Armor::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Armor::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Armor> *ref = ptr.get<ESM::Armor>(); |         const MWWorld::LiveCellRef<ESM::Armor> *ref = ptr.get<ESM::Armor>(); | ||||||
|  |  | ||||||
|  | @ -16,6 +16,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -22,6 +22,10 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void BodyPart::insertObject(const MWWorld::Ptr &ptr, const std::string &model, MWPhysics::PhysicsSystem &physics) const | ||||||
|  |     { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string BodyPart::getName(const MWWorld::ConstPtr &ptr) const |     std::string BodyPart::getName(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         return std::string(); |         return std::string(); | ||||||
|  |  | ||||||
|  | @ -15,6 +15,8 @@ namespace MWClass | ||||||
|         void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |         void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|         ///< Add reference into a cell for rendering
 |         ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |         void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|         std::string getName (const MWWorld::ConstPtr& ptr) const override; |         std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|         ///< \return name or ID; can return an empty string.
 |         ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -31,6 +31,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Book::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Book::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Book::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Book> *ref = ptr.get<ESM::Book>(); |         const MWWorld::LiveCellRef<ESM::Book> *ref = ptr.get<ESM::Book>(); | ||||||
|  |  | ||||||
|  | @ -14,6 +14,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -29,6 +29,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Clothing::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Clothing::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Clothing::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Clothing> *ref = ptr.get<ESM::Clothing>(); |         const MWWorld::LiveCellRef<ESM::Clothing> *ref = ptr.get<ESM::Clothing>(); | ||||||
|  |  | ||||||
|  | @ -14,6 +14,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -111,10 +111,10 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Container::insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const |     void Container::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|     { |     { | ||||||
|         if(!model.empty()) |         if(!model.empty()) | ||||||
|             physics.addObject(ptr, model, rotation); |             physics.addObject(ptr, model); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::string Container::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Container::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|  |  | ||||||
|  | @ -44,7 +44,7 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const override; |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
| 
 | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
|  |  | ||||||
|  | @ -62,10 +62,10 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Door::insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const |     void Door::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|     { |     { | ||||||
|         if(!model.empty()) |         if(!model.empty()) | ||||||
|             physics.addObject(ptr, model, rotation, MWPhysics::CollisionType_Door); |             physics.addObject(ptr, model, MWPhysics::CollisionType_Door); | ||||||
| 
 | 
 | ||||||
|         // Resume the door's opening/closing animation if it wasn't finished
 |         // Resume the door's opening/closing animation if it wasn't finished
 | ||||||
|         if (ptr.getRefData().getCustomData()) |         if (ptr.getRefData().getCustomData()) | ||||||
|  |  | ||||||
|  | @ -18,7 +18,7 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const override; |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
| 
 | 
 | ||||||
|             bool isDoor() const override; |             bool isDoor() const override; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -28,6 +28,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Ingredient::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Ingredient::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Ingredient::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Ingredient> *ref = ptr.get<ESM::Ingredient>(); |         const MWWorld::LiveCellRef<ESM::Ingredient> *ref = ptr.get<ESM::Ingredient>(); | ||||||
|  |  | ||||||
|  | @ -14,6 +14,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -33,7 +33,7 @@ namespace MWClass | ||||||
|         renderingInterface.getObjects().insertModel(ptr, model, true, !(ref->mBase->mData.mFlags & ESM::Light::OffDefault)); |         renderingInterface.getObjects().insertModel(ptr, model, true, !(ref->mBase->mData.mFlags & ESM::Light::OffDefault)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Light::insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const |     void Light::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|     { |     { | ||||||
|         MWWorld::LiveCellRef<ESM::Light> *ref = |         MWWorld::LiveCellRef<ESM::Light> *ref = | ||||||
|             ptr.get<ESM::Light>(); |             ptr.get<ESM::Light>(); | ||||||
|  | @ -41,7 +41,7 @@ namespace MWClass | ||||||
| 
 | 
 | ||||||
|         // TODO: add option somewhere to enable collision for placeable objects
 |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|         if (!model.empty() && (ref->mBase->mData.mFlags & ESM::Light::Carry) == 0) |         if (!model.empty() && (ref->mBase->mData.mFlags & ESM::Light::Carry) == 0) | ||||||
|             physics.addObject(ptr, model, rotation); |             physics.addObject(ptr, model); | ||||||
| 
 | 
 | ||||||
|         if (!ref->mBase->mSound.empty() && !(ref->mBase->mData.mFlags & ESM::Light::OffDefault)) |         if (!ref->mBase->mSound.empty() && !(ref->mBase->mData.mFlags & ESM::Light::OffDefault)) | ||||||
|             MWBase::Environment::get().getSoundManager()->playSound3D(ptr, ref->mBase->mSound, 1.0, 1.0, |             MWBase::Environment::get().getSoundManager()->playSound3D(ptr, ref->mBase->mSound, 1.0, 1.0, | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const override; |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
| 
 | 
 | ||||||
|             bool useAnim() const override; |             bool useAnim() const override; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -28,6 +28,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Lockpick::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Lockpick::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Lockpick::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Lockpick> *ref = ptr.get<ESM::Lockpick>(); |         const MWWorld::LiveCellRef<ESM::Lockpick> *ref = ptr.get<ESM::Lockpick>(); | ||||||
|  |  | ||||||
|  | @ -14,6 +14,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -37,6 +37,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Miscellaneous::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Miscellaneous::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Miscellaneous::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Miscellaneous> *ref = ptr.get<ESM::Miscellaneous>(); |         const MWWorld::LiveCellRef<ESM::Miscellaneous> *ref = ptr.get<ESM::Miscellaneous>(); | ||||||
|  |  | ||||||
|  | @ -14,6 +14,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -30,6 +30,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Potion::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Potion::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Potion::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Potion> *ref = ptr.get<ESM::Potion>(); |         const MWWorld::LiveCellRef<ESM::Potion> *ref = ptr.get<ESM::Potion>(); | ||||||
|  |  | ||||||
|  | @ -14,6 +14,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -28,6 +28,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Probe::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Probe::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Probe::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Probe> *ref = ptr.get<ESM::Probe>(); |         const MWWorld::LiveCellRef<ESM::Probe> *ref = ptr.get<ESM::Probe>(); | ||||||
|  |  | ||||||
|  | @ -14,6 +14,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -25,6 +25,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Repair::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Repair::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Repair::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Repair> *ref = ptr.get<ESM::Repair>(); |         const MWWorld::LiveCellRef<ESM::Repair> *ref = ptr.get<ESM::Repair>(); | ||||||
|  |  | ||||||
|  | @ -14,6 +14,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -23,10 +23,10 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Static::insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const |     void Static::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|     { |     { | ||||||
|         if(!model.empty()) |         if(!model.empty()) | ||||||
|             physics.addObject(ptr, model, rotation); |             physics.addObject(ptr, model); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::string Static::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Static::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|  | @ -63,9 +63,4 @@ namespace MWClass | ||||||
| 
 | 
 | ||||||
|         return MWWorld::Ptr(cell.insert(ref), &cell); |         return MWWorld::Ptr(cell.insert(ref), &cell); | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     bool Static::isStatic() const |  | ||||||
|     { |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const override; |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
| 
 | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
|  | @ -25,8 +25,6 @@ namespace MWClass | ||||||
|             static void registerSelf(); |             static void registerSelf(); | ||||||
| 
 | 
 | ||||||
|             std::string getModel(const MWWorld::ConstPtr &ptr) const override; |             std::string getModel(const MWWorld::ConstPtr &ptr) const override; | ||||||
| 
 |  | ||||||
|             bool isStatic() const override; |  | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -34,6 +34,11 @@ namespace MWClass | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void Weapon::insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const | ||||||
|  |     { | ||||||
|  |         // TODO: add option somewhere to enable collision for placeable objects
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     std::string Weapon::getModel(const MWWorld::ConstPtr &ptr) const |     std::string Weapon::getModel(const MWWorld::ConstPtr &ptr) const | ||||||
|     { |     { | ||||||
|         const MWWorld::LiveCellRef<ESM::Weapon> *ref = ptr.get<ESM::Weapon>(); |         const MWWorld::LiveCellRef<ESM::Weapon> *ref = ptr.get<ESM::Weapon>(); | ||||||
|  |  | ||||||
|  | @ -15,6 +15,8 @@ namespace MWClass | ||||||
|             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; |             void insertObjectRendering (const MWWorld::Ptr& ptr, const std::string& model, MWRender::RenderingInterface& renderingInterface) const override; | ||||||
|             ///< Add reference into a cell for rendering
 |             ///< Add reference into a cell for rendering
 | ||||||
| 
 | 
 | ||||||
|  |             void insertObject(const MWWorld::Ptr& ptr, const std::string& model, MWPhysics::PhysicsSystem& physics) const override; | ||||||
|  | 
 | ||||||
|             std::string getName (const MWWorld::ConstPtr& ptr) const override; |             std::string getName (const MWWorld::ConstPtr& ptr) const override; | ||||||
|             ///< \return name or ID; can return an empty string.
 |             ///< \return name or ID; can return an empty string.
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -67,7 +67,7 @@ Actor::Actor(const MWWorld::Ptr& ptr, const Resource::BulletShape* shape, Physic | ||||||
|     updateScale(); |     updateScale(); | ||||||
| 
 | 
 | ||||||
|     if(!mRotationallyInvariant) |     if(!mRotationallyInvariant) | ||||||
|         setRotation(mPtr.getRefData().getBaseNode()->getAttitude()); |         updateRotation(); | ||||||
| 
 | 
 | ||||||
|     updatePosition(); |     updatePosition(); | ||||||
|     addCollisionMask(getCollisionMask()); |     addCollisionMask(getCollisionMask()); | ||||||
|  | @ -197,10 +197,10 @@ osg::Vec3f Actor::getPreviousPosition() const | ||||||
|     return mPreviousPosition; |     return mPreviousPosition; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Actor::setRotation(osg::Quat quat) | void Actor::updateRotation () | ||||||
| { | { | ||||||
|     std::scoped_lock lock(mPositionMutex); |     std::scoped_lock lock(mPositionMutex); | ||||||
|     mRotation = quat; |     mRotation = mPtr.getRefData().getBaseNode()->getAttitude(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool Actor::isRotationallyInvariant() const | bool Actor::isRotationallyInvariant() const | ||||||
|  |  | ||||||
|  | @ -49,7 +49,7 @@ namespace MWPhysics | ||||||
|         void enableCollisionBody(bool collision); |         void enableCollisionBody(bool collision); | ||||||
| 
 | 
 | ||||||
|         void updateScale(); |         void updateScale(); | ||||||
|         void setRotation(osg::Quat quat); |         void updateRotation(); | ||||||
| 
 | 
 | ||||||
|         /**
 |         /**
 | ||||||
|          * Return true if the collision shape looks the same no matter how its Z rotated. |          * Return true if the collision shape looks the same no matter how its Z rotated. | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ | ||||||
| 
 | 
 | ||||||
| namespace MWPhysics | namespace MWPhysics | ||||||
| { | { | ||||||
|     Object::Object(const MWWorld::Ptr& ptr, osg::ref_ptr<Resource::BulletShapeInstance> shapeInstance, osg::Quat rotation, int collisionType, PhysicsTaskScheduler* scheduler) |     Object::Object(const MWWorld::Ptr& ptr, osg::ref_ptr<Resource::BulletShapeInstance> shapeInstance, int collisionType, PhysicsTaskScheduler* scheduler) | ||||||
|         : mShapeInstance(shapeInstance) |         : mShapeInstance(shapeInstance) | ||||||
|         , mSolid(true) |         , mSolid(true) | ||||||
|         , mTaskScheduler(scheduler) |         , mTaskScheduler(scheduler) | ||||||
|  | @ -27,7 +27,7 @@ namespace MWPhysics | ||||||
|         mCollisionObject->setUserPointer(this); |         mCollisionObject->setUserPointer(this); | ||||||
| 
 | 
 | ||||||
|         setScale(ptr.getCellRef().getScale()); |         setScale(ptr.getCellRef().getScale()); | ||||||
|         setRotation(rotation); |         setRotation(Misc::Convert::toBullet(ptr.getRefData().getBaseNode()->getAttitude())); | ||||||
|         setOrigin(Misc::Convert::toBullet(ptr.getRefData().getPosition().asVec3())); |         setOrigin(Misc::Convert::toBullet(ptr.getRefData().getPosition().asVec3())); | ||||||
|         commitPositionChange(); |         commitPositionChange(); | ||||||
| 
 | 
 | ||||||
|  | @ -51,10 +51,10 @@ namespace MWPhysics | ||||||
|         mScaleUpdatePending = true; |         mScaleUpdatePending = true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Object::setRotation(osg::Quat quat) |     void Object::setRotation(const btQuaternion& quat) | ||||||
|     { |     { | ||||||
|         std::unique_lock<std::mutex> lock(mPositionMutex); |         std::unique_lock<std::mutex> lock(mPositionMutex); | ||||||
|         mLocalTransform.setRotation(Misc::Convert::toBullet(quat)); |         mLocalTransform.setRotation(quat); | ||||||
|         mTransformUpdatePending = true; |         mTransformUpdatePending = true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -26,12 +26,12 @@ namespace MWPhysics | ||||||
|     class Object final : public PtrHolder |     class Object final : public PtrHolder | ||||||
|     { |     { | ||||||
|     public: |     public: | ||||||
|         Object(const MWWorld::Ptr& ptr, osg::ref_ptr<Resource::BulletShapeInstance> shapeInstance, osg::Quat rotation, int collisionType, PhysicsTaskScheduler* scheduler); |         Object(const MWWorld::Ptr& ptr, osg::ref_ptr<Resource::BulletShapeInstance> shapeInstance, int collisionType, PhysicsTaskScheduler* scheduler); | ||||||
|         ~Object() override; |         ~Object() override; | ||||||
| 
 | 
 | ||||||
|         const Resource::BulletShapeInstance* getShapeInstance() const; |         const Resource::BulletShapeInstance* getShapeInstance() const; | ||||||
|         void setScale(float scale); |         void setScale(float scale); | ||||||
|         void setRotation(osg::Quat quat); |         void setRotation(const btQuaternion& quat); | ||||||
|         void setOrigin(const btVector3& vec); |         void setOrigin(const btVector3& vec); | ||||||
|         void commitPositionChange(); |         void commitPositionChange(); | ||||||
|         btCollisionObject* getCollisionObject(); |         btCollisionObject* getCollisionObject(); | ||||||
|  |  | ||||||
|  | @ -456,20 +456,20 @@ namespace MWPhysics | ||||||
|         return heightField->second.get(); |         return heightField->second.get(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void PhysicsSystem::addObject (const MWWorld::Ptr& ptr, const std::string& mesh, osg::Quat rotation, int collisionType) |     void PhysicsSystem::addObject (const MWWorld::Ptr& ptr, const std::string& mesh, int collisionType) | ||||||
|     { |     { | ||||||
|         osg::ref_ptr<Resource::BulletShapeInstance> shapeInstance = mShapeManager->getInstance(mesh); |         osg::ref_ptr<Resource::BulletShapeInstance> shapeInstance = mShapeManager->getInstance(mesh); | ||||||
|         if (!shapeInstance || !shapeInstance->getCollisionShape()) |         if (!shapeInstance || !shapeInstance->getCollisionShape()) | ||||||
|             return; |             return; | ||||||
| 
 | 
 | ||||||
|         auto obj = std::make_shared<Object>(ptr, shapeInstance, rotation, collisionType, mTaskScheduler.get()); |         auto obj = std::make_shared<Object>(ptr, shapeInstance, collisionType, mTaskScheduler.get()); | ||||||
|         mObjects.emplace(ptr, obj); |         mObjects.emplace(ptr, obj); | ||||||
| 
 | 
 | ||||||
|         if (obj->isAnimated()) |         if (obj->isAnimated()) | ||||||
|             mAnimatedObjects.insert(obj.get()); |             mAnimatedObjects.insert(obj.get()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void PhysicsSystem::remove(const MWWorld::Ptr &ptr, bool keepObject) |     void PhysicsSystem::remove(const MWWorld::Ptr &ptr) | ||||||
|     { |     { | ||||||
|         ObjectMap::iterator found = mObjects.find(ptr); |         ObjectMap::iterator found = mObjects.find(ptr); | ||||||
|         if (found != mObjects.end()) |         if (found != mObjects.end()) | ||||||
|  | @ -479,7 +479,6 @@ namespace MWPhysics | ||||||
| 
 | 
 | ||||||
|             mAnimatedObjects.erase(found->second.get()); |             mAnimatedObjects.erase(found->second.get()); | ||||||
| 
 | 
 | ||||||
|             if (!keepObject) |  | ||||||
|             mObjects.erase(found); |             mObjects.erase(found); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -622,12 +621,12 @@ namespace MWPhysics | ||||||
|         mTaskScheduler->updateSingleAabb(foundProjectile->second); |         mTaskScheduler->updateSingleAabb(foundProjectile->second); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void PhysicsSystem::updateRotation(const MWWorld::Ptr &ptr, osg::Quat rotate) |     void PhysicsSystem::updateRotation(const MWWorld::Ptr &ptr) | ||||||
|     { |     { | ||||||
|         ObjectMap::iterator found = mObjects.find(ptr); |         ObjectMap::iterator found = mObjects.find(ptr); | ||||||
|         if (found != mObjects.end()) |         if (found != mObjects.end()) | ||||||
|         { |         { | ||||||
|             found->second->setRotation(rotate); |             found->second->setRotation(Misc::Convert::toBullet(ptr.getRefData().getBaseNode()->getAttitude())); | ||||||
|             mTaskScheduler->updateSingleAabb(found->second); |             mTaskScheduler->updateSingleAabb(found->second); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  | @ -636,7 +635,7 @@ namespace MWPhysics | ||||||
|         { |         { | ||||||
|             if (!foundActor->second->isRotationallyInvariant()) |             if (!foundActor->second->isRotationallyInvariant()) | ||||||
|             { |             { | ||||||
|                 foundActor->second->setRotation(rotate); |                 foundActor->second->updateRotation(); | ||||||
|                 mTaskScheduler->updateSingleAabb(foundActor->second); |                 mTaskScheduler->updateSingleAabb(foundActor->second); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|  |  | ||||||
|  | @ -121,7 +121,7 @@ namespace MWPhysics | ||||||
|             void setWaterHeight(float height); |             void setWaterHeight(float height); | ||||||
|             void disableWater(); |             void disableWater(); | ||||||
| 
 | 
 | ||||||
|             void addObject (const MWWorld::Ptr& ptr, const std::string& mesh, osg::Quat rotation, int collisionType = CollisionType_World); |             void addObject (const MWWorld::Ptr& ptr, const std::string& mesh, int collisionType = CollisionType_World); | ||||||
|             void addActor (const MWWorld::Ptr& ptr, const std::string& mesh); |             void addActor (const MWWorld::Ptr& ptr, const std::string& mesh); | ||||||
| 
 | 
 | ||||||
|             int addProjectile(const MWWorld::Ptr& caster, const osg::Vec3f& position, float radius, bool canTraverseWater); |             int addProjectile(const MWWorld::Ptr& caster, const osg::Vec3f& position, float radius, bool canTraverseWater); | ||||||
|  | @ -138,10 +138,10 @@ namespace MWPhysics | ||||||
|             Projectile* getProjectile(int projectileId) const; |             Projectile* getProjectile(int projectileId) const; | ||||||
| 
 | 
 | ||||||
|             // Object or Actor
 |             // Object or Actor
 | ||||||
|             void remove (const MWWorld::Ptr& ptr, bool keepObject = false); |             void remove (const MWWorld::Ptr& ptr); | ||||||
| 
 | 
 | ||||||
|             void updateScale (const MWWorld::Ptr& ptr); |             void updateScale (const MWWorld::Ptr& ptr); | ||||||
|             void updateRotation (const MWWorld::Ptr& ptr, osg::Quat rotate); |             void updateRotation (const MWWorld::Ptr& ptr); | ||||||
|             void updatePosition (const MWWorld::Ptr& ptr); |             void updatePosition (const MWWorld::Ptr& ptr); | ||||||
| 
 | 
 | ||||||
|             void addHeightField (const float* heights, int x, int y, float triSize, float sqrtVerts, float minH, float maxH, const osg::Object* holdObject); |             void addHeightField (const float* heights, int x, int y, float triSize, float sqrtVerts, float minH, float maxH, const osg::Object* holdObject); | ||||||
|  |  | ||||||
|  | @ -18,20 +18,9 @@ namespace MWWorld | ||||||
|             if (ptr.getRefData().getBaseNode()) |             if (ptr.getRefData().getBaseNode()) | ||||||
|             { |             { | ||||||
|                 ptr.getRefData().setBaseNode(nullptr); |                 ptr.getRefData().setBaseNode(nullptr); | ||||||
|             } |  | ||||||
|                 mObjects.push_back (ptr); |                 mObjects.push_back (ptr); | ||||||
| 
 |  | ||||||
|             return true; |  | ||||||
|             } |             } | ||||||
|     }; |  | ||||||
| 
 | 
 | ||||||
|     struct ListObjectsVisitor |  | ||||||
|     { |  | ||||||
|         std::vector<MWWorld::Ptr> mObjects; |  | ||||||
| 
 |  | ||||||
|         bool operator() (MWWorld::Ptr ptr) |  | ||||||
|         { |  | ||||||
|             mObjects.push_back (ptr); |  | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  | @ -25,12 +25,16 @@ namespace MWWorld | ||||||
| { | { | ||||||
|     std::map<std::string, std::shared_ptr<Class> > Class::sClasses; |     std::map<std::string, std::shared_ptr<Class> > Class::sClasses; | ||||||
| 
 | 
 | ||||||
|  |     Class::Class() {} | ||||||
|  | 
 | ||||||
|  |     Class::~Class() {} | ||||||
|  | 
 | ||||||
|     void Class::insertObjectRendering (const Ptr& ptr, const std::string& mesh, MWRender::RenderingInterface& renderingInterface) const |     void Class::insertObjectRendering (const Ptr& ptr, const std::string& mesh, MWRender::RenderingInterface& renderingInterface) const | ||||||
|     { |     { | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Class::insertObject(const Ptr& ptr, const std::string& mesh, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const |     void Class::insertObject(const Ptr& ptr, const std::string& mesh, MWPhysics::PhysicsSystem& physics) const | ||||||
|     { |     { | ||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -6,7 +6,6 @@ | ||||||
| #include <string> | #include <string> | ||||||
| #include <vector> | #include <vector> | ||||||
| 
 | 
 | ||||||
| #include <osg/Quat> |  | ||||||
| #include <osg/Vec4f> | #include <osg/Vec4f> | ||||||
| 
 | 
 | ||||||
| #include "ptr.hpp" | #include "ptr.hpp" | ||||||
|  | @ -58,9 +57,13 @@ namespace MWWorld | ||||||
| 
 | 
 | ||||||
|             std::string mTypeName; |             std::string mTypeName; | ||||||
| 
 | 
 | ||||||
|  |             // not implemented
 | ||||||
|  |             Class (const Class&); | ||||||
|  |             Class& operator= (const Class&); | ||||||
|  | 
 | ||||||
|         protected: |         protected: | ||||||
| 
 | 
 | ||||||
|             Class() = default; |             Class(); | ||||||
| 
 | 
 | ||||||
|             std::shared_ptr<Action> defaultItemActivate(const Ptr &ptr, const Ptr &actor) const; |             std::shared_ptr<Action> defaultItemActivate(const Ptr &ptr, const Ptr &actor) const; | ||||||
|             ///< Generate default action for activating inventory items
 |             ///< Generate default action for activating inventory items
 | ||||||
|  | @ -69,16 +72,14 @@ namespace MWWorld | ||||||
| 
 | 
 | ||||||
|         public: |         public: | ||||||
| 
 | 
 | ||||||
|             virtual ~Class() = default; |             virtual ~Class(); | ||||||
|             Class (const Class&) = delete; |  | ||||||
|             Class& operator= (const Class&) = delete; |  | ||||||
| 
 | 
 | ||||||
|             const std::string& getTypeName() const { |             const std::string& getTypeName() const { | ||||||
|                 return mTypeName; |                 return mTypeName; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             virtual void insertObjectRendering (const Ptr& ptr, const std::string& mesh, MWRender::RenderingInterface& renderingInterface) const; |             virtual void insertObjectRendering (const Ptr& ptr, const std::string& mesh, MWRender::RenderingInterface& renderingInterface) const; | ||||||
|             virtual void insertObject(const Ptr& ptr, const std::string& mesh, osg::Quat rotation, MWPhysics::PhysicsSystem& physics) const; |             virtual void insertObject(const Ptr& ptr, const std::string& mesh, MWPhysics::PhysicsSystem& physics) const; | ||||||
|             ///< Add reference into a cell for rendering (default implementation: don't render anything).
 |             ///< Add reference into a cell for rendering (default implementation: don't render anything).
 | ||||||
| 
 | 
 | ||||||
|             virtual std::string getName (const ConstPtr& ptr) const = 0; |             virtual std::string getName (const ConstPtr& ptr) const = 0; | ||||||
|  | @ -318,10 +319,6 @@ namespace MWWorld | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             virtual bool isStatic() const { |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             virtual bool isBipedal(const MWWorld::ConstPtr& ptr) const; |             virtual bool isBipedal(const MWWorld::ConstPtr& ptr) const; | ||||||
|             virtual bool canFly(const MWWorld::ConstPtr& ptr) const; |             virtual bool canFly(const MWWorld::ConstPtr& ptr) const; | ||||||
|             virtual bool canSwim(const MWWorld::ConstPtr& ptr) const; |             virtual bool canSwim(const MWWorld::ConstPtr& ptr) const; | ||||||
|  |  | ||||||
|  | @ -75,20 +75,18 @@ namespace | ||||||
|             * osg::Quat(xr, osg::Vec3(-1, 0, 0)); |             * osg::Quat(xr, osg::Vec3(-1, 0, 0)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     osg::Quat makeNodeRotation(const MWWorld::Ptr& ptr, RotationOrder order) |     void setNodeRotation(const MWWorld::Ptr& ptr, MWRender::RenderingManager& rendering, RotationOrder order) | ||||||
|     { |     { | ||||||
|         const auto pos = ptr.getRefData().getPosition(); |         if (!ptr.getRefData().getBaseNode()) | ||||||
|  |             return; | ||||||
| 
 | 
 | ||||||
|         const auto rot = ptr.getClass().isActor() ? makeActorOsgQuat(pos) |         rendering.rotateObject(ptr, | ||||||
|             : (order == RotationOrder::inverse ? makeInversedOrderObjectOsgQuat(pos) : makeObjectOsgQuat(pos)); |             ptr.getClass().isActor() | ||||||
| 
 |             ? makeActorOsgQuat(ptr.getRefData().getPosition()) | ||||||
|         return rot; |             : (order == RotationOrder::inverse | ||||||
|     } |                 ? makeInversedOrderObjectOsgQuat(ptr.getRefData().getPosition()) | ||||||
| 
 |                 : makeObjectOsgQuat(ptr.getRefData().getPosition())) | ||||||
|     void setNodeRotation(const MWWorld::Ptr& ptr, MWRender::RenderingManager& rendering, osg::Quat rotation) |         ); | ||||||
|     { |  | ||||||
|         if (ptr.getRefData().getBaseNode()) |  | ||||||
|             rendering.rotateObject(ptr, rotation); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::string getModel(const MWWorld::Ptr &ptr, const VFS::Manager *vfs) |     std::string getModel(const MWWorld::Ptr &ptr, const VFS::Manager *vfs) | ||||||
|  | @ -105,7 +103,7 @@ namespace | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void addObject(const MWWorld::Ptr& ptr, MWPhysics::PhysicsSystem& physics, |     void addObject(const MWWorld::Ptr& ptr, MWPhysics::PhysicsSystem& physics, | ||||||
|                    MWRender::RenderingManager& rendering, std::set<ESM::RefNum>& pagedRefs, bool onlyPhysics) |                    MWRender::RenderingManager& rendering, std::set<ESM::RefNum>& pagedRefs) | ||||||
|     { |     { | ||||||
|         if (ptr.getRefData().getBaseNode() || physics.getActor(ptr)) |         if (ptr.getRefData().getBaseNode() || physics.getActor(ptr)) | ||||||
|         { |         { | ||||||
|  | @ -113,19 +111,17 @@ namespace | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         std::string model = getModel(ptr, rendering.getResourceSystem()->getVFS()); |  | ||||||
|         const auto rotation = makeNodeRotation(ptr, RotationOrder::direct); |  | ||||||
|         if (!onlyPhysics) |  | ||||||
|         { |  | ||||||
|         bool useAnim = ptr.getClass().useAnim(); |         bool useAnim = ptr.getClass().useAnim(); | ||||||
|  |         std::string model = getModel(ptr, rendering.getResourceSystem()->getVFS()); | ||||||
| 
 | 
 | ||||||
|         const ESM::RefNum& refnum = ptr.getCellRef().getRefNum(); |         const ESM::RefNum& refnum = ptr.getCellRef().getRefNum(); | ||||||
|         if (!refnum.hasContentFile() || pagedRefs.find(refnum) == pagedRefs.end()) |         if (!refnum.hasContentFile() || pagedRefs.find(refnum) == pagedRefs.end()) | ||||||
|             ptr.getClass().insertObjectRendering(ptr, model, rendering); |             ptr.getClass().insertObjectRendering(ptr, model, rendering); | ||||||
|         else |         else | ||||||
|             ptr.getRefData().setBaseNode(new SceneUtil::PositionAttitudeTransform); // FIXME remove this when physics code is fixed not to depend on basenode
 |             ptr.getRefData().setBaseNode(new SceneUtil::PositionAttitudeTransform); // FIXME remove this when physics code is fixed not to depend on basenode
 | ||||||
|  |         setNodeRotation(ptr, rendering, RotationOrder::direct); | ||||||
| 
 | 
 | ||||||
|             setNodeRotation(ptr, rendering, rotation); |         ptr.getClass().insertObject (ptr, model, physics); | ||||||
| 
 | 
 | ||||||
|         if (useAnim) |         if (useAnim) | ||||||
|             MWBase::Environment::get().getMechanicsManager()->add(ptr); |             MWBase::Environment::get().getMechanicsManager()->add(ptr); | ||||||
|  | @ -136,9 +132,6 @@ namespace | ||||||
|         // Restore effect particles
 |         // Restore effect particles
 | ||||||
|         MWBase::Environment::get().getWorld()->applyLoopingParticles(ptr); |         MWBase::Environment::get().getWorld()->applyLoopingParticles(ptr); | ||||||
|     } |     } | ||||||
|         if (!physics.getObject(ptr)) |  | ||||||
|             ptr.getClass().insertObject (ptr, model, rotation, physics); |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     void addObject(const MWWorld::Ptr& ptr, const MWPhysics::PhysicsSystem& physics, DetourNavigator::Navigator& navigator) |     void addObject(const MWWorld::Ptr& ptr, const MWPhysics::PhysicsSystem& physics, DetourNavigator::Navigator& navigator) | ||||||
|     { |     { | ||||||
|  | @ -208,12 +201,11 @@ namespace | ||||||
|     { |     { | ||||||
|         MWWorld::CellStore& mCell; |         MWWorld::CellStore& mCell; | ||||||
|         Loading::Listener& mLoadingListener; |         Loading::Listener& mLoadingListener; | ||||||
|         bool mOnlyStatics; |  | ||||||
|         bool mTest; |         bool mTest; | ||||||
| 
 | 
 | ||||||
|         std::vector<MWWorld::Ptr> mToInsert; |         std::vector<MWWorld::Ptr> mToInsert; | ||||||
| 
 | 
 | ||||||
|         InsertVisitor (MWWorld::CellStore& cell, Loading::Listener& loadingListener, bool onlyStatics, bool test); |         InsertVisitor (MWWorld::CellStore& cell, Loading::Listener& loadingListener, bool test); | ||||||
| 
 | 
 | ||||||
|         bool operator() (const MWWorld::Ptr& ptr); |         bool operator() (const MWWorld::Ptr& ptr); | ||||||
| 
 | 
 | ||||||
|  | @ -221,8 +213,8 @@ namespace | ||||||
|         void insert(AddObject&& addObject); |         void insert(AddObject&& addObject); | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     InsertVisitor::InsertVisitor (MWWorld::CellStore& cell, Loading::Listener& loadingListener, bool onlyStatics, bool test) |     InsertVisitor::InsertVisitor (MWWorld::CellStore& cell, Loading::Listener& loadingListener, bool test) | ||||||
|     : mCell (cell), mLoadingListener (loadingListener), mOnlyStatics(onlyStatics), mTest(test) |     : mCell (cell), mLoadingListener (loadingListener), mTest(test) | ||||||
|     {} |     {} | ||||||
| 
 | 
 | ||||||
|     bool InsertVisitor::operator() (const MWWorld::Ptr& ptr) |     bool InsertVisitor::operator() (const MWWorld::Ptr& ptr) | ||||||
|  | @ -238,7 +230,7 @@ namespace | ||||||
|     { |     { | ||||||
|         for (MWWorld::Ptr& ptr : mToInsert) |         for (MWWorld::Ptr& ptr : mToInsert) | ||||||
|         { |         { | ||||||
|             if (!ptr.getRefData().isDeleted() && ptr.getRefData().isEnabled() && ((mOnlyStatics && ptr.getClass().isStatic()) || !mOnlyStatics)) |             if (!ptr.getRefData().isDeleted() && ptr.getRefData().isEnabled()) | ||||||
|             { |             { | ||||||
|                 try |                 try | ||||||
|                 { |                 { | ||||||
|  | @ -271,16 +263,6 @@ namespace | ||||||
|         return std::abs(cellPosition.first) + std::abs(cellPosition.second); |         return std::abs(cellPosition.first) + std::abs(cellPosition.second); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool isCellInCollection(int x, int y, MWWorld::Scene::CellStoreCollection& collection) |  | ||||||
|     { |  | ||||||
|         for (auto *cell : collection) |  | ||||||
|         { |  | ||||||
|             assert(cell->getCell()->isExterior()); |  | ||||||
|             if (x == cell->getCell()->getGridX() && y == cell->getCell()->getGridY()) |  | ||||||
|                 return true; |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -294,7 +276,7 @@ namespace MWWorld | ||||||
|         { |         { | ||||||
|             if (!ptr.getRefData().getBaseNode()) return; |             if (!ptr.getRefData().getBaseNode()) return; | ||||||
|             ptr.getClass().insertObjectRendering(ptr, getModel(ptr, mRendering.getResourceSystem()->getVFS()), mRendering); |             ptr.getClass().insertObjectRendering(ptr, getModel(ptr, mRendering.getResourceSystem()->getVFS()), mRendering); | ||||||
|             setNodeRotation(ptr, mRendering, makeNodeRotation(ptr, RotationOrder::direct)); |             setNodeRotation(ptr, mRendering, RotationOrder::direct); | ||||||
|             reloadTerrain(); |             reloadTerrain(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | @ -310,9 +292,8 @@ namespace MWWorld | ||||||
| 
 | 
 | ||||||
|     void Scene::updateObjectRotation(const Ptr &ptr, RotationOrder order) |     void Scene::updateObjectRotation(const Ptr &ptr, RotationOrder order) | ||||||
|     { |     { | ||||||
|         const auto rot = makeNodeRotation(ptr, order); |         setNodeRotation(ptr, mRendering, order); | ||||||
|         setNodeRotation(ptr, mRendering, rot); |         mPhysics->updateRotation(ptr); | ||||||
|         mPhysics->updateRotation(ptr, rot); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Scene::updateObjectScale(const Ptr &ptr) |     void Scene::updateObjectScale(const Ptr &ptr) | ||||||
|  | @ -332,41 +313,15 @@ namespace MWWorld | ||||||
|         mRendering.update (duration, paused); |         mRendering.update (duration, paused); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Scene::unloadInactiveCell (CellStore* cell, bool test) |     void Scene::unloadCell (CellStoreCollection::iterator iter, bool test) | ||||||
|     { |     { | ||||||
|         assert(mActiveCells.find(cell) == mActiveCells.end()); |  | ||||||
|         assert(mInactiveCells.find(cell) != mInactiveCells.end()); |  | ||||||
|         if (!test) |         if (!test) | ||||||
|             Log(Debug::Info) << "Unloading cell " << cell->getCell()->getDescription(); |             Log(Debug::Info) << "Unloading cell " << (*iter)->getCell()->getDescription(); | ||||||
| 
 |  | ||||||
|         ListObjectsVisitor visitor; |  | ||||||
| 
 |  | ||||||
|         cell->forEach(visitor); |  | ||||||
|         for (const auto& ptr : visitor.mObjects) |  | ||||||
|             mPhysics->remove(ptr); |  | ||||||
| 
 |  | ||||||
|         if (cell->getCell()->isExterior()) |  | ||||||
|         { |  | ||||||
|             const auto cellX = cell->getCell()->getGridX(); |  | ||||||
|             const auto cellY = cell->getCell()->getGridY(); |  | ||||||
|             mPhysics->removeHeightField(cellX, cellY); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         mInactiveCells.erase(cell); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     void Scene::deactivateCell(CellStore* cell, bool test) |  | ||||||
|     { |  | ||||||
|         assert(mInactiveCells.find(cell) != mInactiveCells.end()); |  | ||||||
|         if (mActiveCells.find(cell) == mActiveCells.end()) |  | ||||||
|             return; |  | ||||||
|         if (!test) |  | ||||||
|             Log(Debug::Info) << "Deactivate cell " << cell->getCell()->getDescription(); |  | ||||||
| 
 | 
 | ||||||
|         const auto navigator = MWBase::Environment::get().getWorld()->getNavigator(); |         const auto navigator = MWBase::Environment::get().getWorld()->getNavigator(); | ||||||
|         ListAndResetObjectsVisitor visitor; |         ListAndResetObjectsVisitor visitor; | ||||||
| 
 | 
 | ||||||
|         cell->forEach(visitor); |         (*iter)->forEach(visitor); | ||||||
|         const auto world = MWBase::Environment::get().getWorld(); |         const auto world = MWBase::Environment::get().getWorld(); | ||||||
|         for (const auto& ptr : visitor.mObjects) |         for (const auto& ptr : visitor.mObjects) | ||||||
|         { |         { | ||||||
|  | @ -377,57 +332,75 @@ namespace MWWorld | ||||||
|                 navigator->removeAgent(world->getPathfindingHalfExtents(ptr)); |                 navigator->removeAgent(world->getPathfindingHalfExtents(ptr)); | ||||||
|                 mRendering.removeActorPath(ptr); |                 mRendering.removeActorPath(ptr); | ||||||
|             } |             } | ||||||
|             mPhysics->remove(ptr, ptr.getClass().isStatic()); |             mPhysics->remove(ptr); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         const auto cellX = cell->getCell()->getGridX(); |         const auto cellX = (*iter)->getCell()->getGridX(); | ||||||
|         const auto cellY = cell->getCell()->getGridY(); |         const auto cellY = (*iter)->getCell()->getGridY(); | ||||||
| 
 | 
 | ||||||
|         if (cell->getCell()->isExterior()) |         if ((*iter)->getCell()->isExterior()) | ||||||
|         { |         { | ||||||
|             if (const auto heightField = mPhysics->getHeightField(cellX, cellY)) |             if (const auto heightField = mPhysics->getHeightField(cellX, cellY)) | ||||||
|                 navigator->removeObject(DetourNavigator::ObjectId(heightField)); |                 navigator->removeObject(DetourNavigator::ObjectId(heightField)); | ||||||
|  |             mPhysics->removeHeightField(cellX, cellY); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (cell->getCell()->hasWater()) |         if ((*iter)->getCell()->hasWater()) | ||||||
|             navigator->removeWater(osg::Vec2i(cellX, cellY)); |             navigator->removeWater(osg::Vec2i(cellX, cellY)); | ||||||
| 
 | 
 | ||||||
|         if (const auto pathgrid = world->getStore().get<ESM::Pathgrid>().search(*cell->getCell())) |         if (const auto pathgrid = world->getStore().get<ESM::Pathgrid>().search(*(*iter)->getCell())) | ||||||
|             navigator->removePathgrid(*pathgrid); |             navigator->removePathgrid(*pathgrid); | ||||||
| 
 | 
 | ||||||
|         const auto player = world->getPlayerPtr(); |         const auto player = world->getPlayerPtr(); | ||||||
|         navigator->update(player.getRefData().getPosition().asVec3()); |         navigator->update(player.getRefData().getPosition().asVec3()); | ||||||
| 
 | 
 | ||||||
|         MWBase::Environment::get().getMechanicsManager()->drop (cell); |         MWBase::Environment::get().getMechanicsManager()->drop (*iter); | ||||||
| 
 | 
 | ||||||
|         mRendering.removeCell(cell); |         mRendering.removeCell(*iter); | ||||||
|         MWBase::Environment::get().getWindowManager()->removeCell(cell); |         MWBase::Environment::get().getWindowManager()->removeCell(*iter); | ||||||
| 
 | 
 | ||||||
|         MWBase::Environment::get().getWorld()->getLocalScripts().clearCell (cell); |         MWBase::Environment::get().getWorld()->getLocalScripts().clearCell (*iter); | ||||||
| 
 | 
 | ||||||
|         MWBase::Environment::get().getSoundManager()->stopSound (cell); |         MWBase::Environment::get().getSoundManager()->stopSound (*iter); | ||||||
|         mActiveCells.erase(cell); |         mActiveCells.erase(*iter); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Scene::activateCell (CellStore *cell, Loading::Listener* loadingListener, bool respawn, bool test) |     void Scene::loadCell (CellStore *cell, Loading::Listener* loadingListener, bool respawn, bool test) | ||||||
|     { |     { | ||||||
|         assert(mActiveCells.find(cell) == mActiveCells.end()); |         std::pair<CellStoreCollection::iterator, bool> result = mActiveCells.insert(cell); | ||||||
|         assert(mInactiveCells.find(cell) != mInactiveCells.end()); |  | ||||||
|         mActiveCells.insert(cell); |  | ||||||
| 
 | 
 | ||||||
|  |         if(result.second) | ||||||
|  |         { | ||||||
|             if (test) |             if (test) | ||||||
|                 Log(Debug::Info) << "Testing cell " << cell->getCell()->getDescription(); |                 Log(Debug::Info) << "Testing cell " << cell->getCell()->getDescription(); | ||||||
|             else |             else | ||||||
|                 Log(Debug::Info) << "Loading cell " << cell->getCell()->getDescription(); |                 Log(Debug::Info) << "Loading cell " << cell->getCell()->getDescription(); | ||||||
| 
 | 
 | ||||||
|  |             float verts = ESM::Land::LAND_SIZE; | ||||||
|  |             float worldsize = ESM::Land::REAL_SIZE; | ||||||
|  | 
 | ||||||
|             const auto world = MWBase::Environment::get().getWorld(); |             const auto world = MWBase::Environment::get().getWorld(); | ||||||
|             const auto navigator = world->getNavigator(); |             const auto navigator = world->getNavigator(); | ||||||
| 
 | 
 | ||||||
|             const int cellX = cell->getCell()->getGridX(); |             const int cellX = cell->getCell()->getGridX(); | ||||||
|             const int cellY = cell->getCell()->getGridY(); |             const int cellY = cell->getCell()->getGridY(); | ||||||
| 
 | 
 | ||||||
|  |             // Load terrain physics first...
 | ||||||
|             if (!test && cell->getCell()->isExterior()) |             if (!test && cell->getCell()->isExterior()) | ||||||
|             { |             { | ||||||
|  |                 osg::ref_ptr<const ESMTerrain::LandObject> land = mRendering.getLandManager()->getLand(cellX, cellY); | ||||||
|  |                 const ESM::Land::LandData* data = land ? land->getData(ESM::Land::DATA_VHGT) : nullptr; | ||||||
|  |                 if (data) | ||||||
|  |                 { | ||||||
|  |                     mPhysics->addHeightField (data->mHeights, cellX, cellY, worldsize / (verts-1), verts, data->mMinHeight, data->mMaxHeight, land.get()); | ||||||
|  |                 } | ||||||
|  |                 else | ||||||
|  |                 { | ||||||
|  |                     static std::vector<float> defaultHeight; | ||||||
|  |                     defaultHeight.resize(verts*verts, ESM::Land::DEFAULT_HEIGHT); | ||||||
|  |                     mPhysics->addHeightField (&defaultHeight[0], cell->getCell()->getGridX(), cell->getCell()->getGridY(), worldsize / (verts-1), verts, ESM::Land::DEFAULT_HEIGHT, ESM::Land::DEFAULT_HEIGHT, land.get()); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|                 if (const auto heightField = mPhysics->getHeightField(cellX, cellY)) |                 if (const auto heightField = mPhysics->getHeightField(cellX, cellY)) | ||||||
|                     navigator->addObject(DetourNavigator::ObjectId(heightField), *heightField->getShape(), |                     navigator->addObject(DetourNavigator::ObjectId(heightField), *heightField->getShape(), | ||||||
|                             heightField->getCollisionObject()->getWorldTransform()); |                             heightField->getCollisionObject()->getWorldTransform()); | ||||||
|  | @ -443,7 +416,8 @@ namespace MWWorld | ||||||
|             if (respawn) |             if (respawn) | ||||||
|                 cell->respawn(); |                 cell->respawn(); | ||||||
| 
 | 
 | ||||||
|         insertCell (*cell, loadingListener, false, test); |             // ... then references. This is important for adjustPosition to work correctly.
 | ||||||
|  |             insertCell (*cell, loadingListener, test); | ||||||
| 
 | 
 | ||||||
|             mRendering.addCell(cell); |             mRendering.addCell(cell); | ||||||
|             if (!test) |             if (!test) | ||||||
|  | @ -476,58 +450,22 @@ namespace MWWorld | ||||||
|                 navigator->update(player.getRefData().getPosition().asVec3()); |                 navigator->update(player.getRefData().getPosition().asVec3()); | ||||||
| 
 | 
 | ||||||
|                 if (!cell->isExterior() && !(cell->getCell()->mData.mFlags & ESM::Cell::QuasiEx)) |                 if (!cell->isExterior() && !(cell->getCell()->mData.mFlags & ESM::Cell::QuasiEx)) | ||||||
|  |                 { | ||||||
|  | 
 | ||||||
|                     mRendering.configureAmbient(cell->getCell()); |                     mRendering.configureAmbient(cell->getCell()); | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         mPreloader->notifyLoaded(cell); |         mPreloader->notifyLoaded(cell); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Scene::loadInactiveCell (CellStore *cell, Loading::Listener* loadingListener, bool test) |  | ||||||
|     { |  | ||||||
|         assert(mActiveCells.find(cell) == mActiveCells.end()); |  | ||||||
|         assert(mInactiveCells.find(cell) == mInactiveCells.end()); |  | ||||||
|         mInactiveCells.insert(cell); |  | ||||||
| 
 |  | ||||||
|         if (test) |  | ||||||
|             Log(Debug::Info) << "Testing inactive cell " << cell->getCell()->getDescription(); |  | ||||||
|         else |  | ||||||
|             Log(Debug::Info) << "Loading inactive cell " << cell->getCell()->getDescription(); |  | ||||||
| 
 |  | ||||||
|         if (!test && cell->getCell()->isExterior()) |  | ||||||
|         { |  | ||||||
|             float verts = ESM::Land::LAND_SIZE; |  | ||||||
|             float worldsize = ESM::Land::REAL_SIZE; |  | ||||||
| 
 |  | ||||||
|             const int cellX = cell->getCell()->getGridX(); |  | ||||||
|             const int cellY = cell->getCell()->getGridY(); |  | ||||||
| 
 |  | ||||||
|             osg::ref_ptr<const ESMTerrain::LandObject> land = mRendering.getLandManager()->getLand(cellX, cellY); |  | ||||||
|             const ESM::Land::LandData* data = land ? land->getData(ESM::Land::DATA_VHGT) : nullptr; |  | ||||||
|             if (data) |  | ||||||
|             { |  | ||||||
|                 mPhysics->addHeightField (data->mHeights, cellX, cellY, worldsize / (verts-1), verts, data->mMinHeight, data->mMaxHeight, land.get()); |  | ||||||
|             } |  | ||||||
|             else |  | ||||||
|             { |  | ||||||
|                 static std::vector<float> defaultHeight; |  | ||||||
|                 defaultHeight.resize(verts*verts, ESM::Land::DEFAULT_HEIGHT); |  | ||||||
|                 mPhysics->addHeightField (&defaultHeight[0], cell->getCell()->getGridX(), cell->getCell()->getGridY(), worldsize / (verts-1), verts, ESM::Land::DEFAULT_HEIGHT, ESM::Land::DEFAULT_HEIGHT, land.get()); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         insertCell (*cell, loadingListener, true, test); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     void Scene::clear() |     void Scene::clear() | ||||||
|     { |     { | ||||||
|         for (auto iter = mInactiveCells.begin(); iter!=mInactiveCells.end(); ) |         CellStoreCollection::iterator active = mActiveCells.begin(); | ||||||
|         { |         while (active!=mActiveCells.end()) | ||||||
|             auto* cell = *iter++; |             unloadCell (active++); | ||||||
|             deactivateCell(cell); |  | ||||||
|             unloadInactiveCell (cell); |  | ||||||
|         } |  | ||||||
|         assert(mActiveCells.empty()); |         assert(mActiveCells.empty()); | ||||||
|         assert(mInactiveCells.empty()); |  | ||||||
|         mCurrentCell = nullptr; |         mCurrentCell = nullptr; | ||||||
| 
 | 
 | ||||||
|         mPreloader->clear(); |         mPreloader->clear(); | ||||||
|  | @ -570,24 +508,20 @@ namespace MWWorld | ||||||
| 
 | 
 | ||||||
|     void Scene::changeCellGrid (const osg::Vec3f &pos, int playerCellX, int playerCellY, bool changeEvent) |     void Scene::changeCellGrid (const osg::Vec3f &pos, int playerCellX, int playerCellY, bool changeEvent) | ||||||
|     { |     { | ||||||
|         for (auto iter = mInactiveCells.begin(); iter != mInactiveCells.end(); ) |         CellStoreCollection::iterator active = mActiveCells.begin(); | ||||||
|  |         while (active!=mActiveCells.end()) | ||||||
|         { |         { | ||||||
|             auto* cell = *iter++; |             if ((*active)->getCell()->isExterior()) | ||||||
|             if (cell->getCell()->isExterior()) |  | ||||||
|             { |             { | ||||||
|                 const auto dx = std::abs(playerCellX - cell->getCell()->getGridX()); |                 if (std::abs (playerCellX-(*active)->getCell()->getGridX())<=mHalfGridSize && | ||||||
|                 const auto dy = std::abs(playerCellY - cell->getCell()->getGridY()); |                     std::abs (playerCellY-(*active)->getCell()->getGridY())<=mHalfGridSize) | ||||||
|                 if (dx > mHalfGridSize || dy > mHalfGridSize) |                 { | ||||||
|                     deactivateCell(cell); |                     // keep cells within the new grid
 | ||||||
| 
 |                     ++active; | ||||||
|                 if (dx > mHalfGridSize+1 || dy > mHalfGridSize+1) |                     continue; | ||||||
|                     unloadInactiveCell(cell); |  | ||||||
|                 } |                 } | ||||||
|             else |  | ||||||
|             { |  | ||||||
|                 deactivateCell(cell); |  | ||||||
|                 unloadInactiveCell(cell); |  | ||||||
|             } |             } | ||||||
|  |             unloadCell (active++); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         mCurrentGridCenter = osg::Vec2i(playerCellX, playerCellY); |         mCurrentGridCenter = osg::Vec2i(playerCellX, playerCellY); | ||||||
|  | @ -599,24 +533,32 @@ namespace MWWorld | ||||||
|         mRendering.getPagedRefnums(newGrid, mPagedRefs); |         mRendering.getPagedRefnums(newGrid, mPagedRefs); | ||||||
| 
 | 
 | ||||||
|         std::size_t refsToLoad = 0; |         std::size_t refsToLoad = 0; | ||||||
|         const auto cellsToLoad = [&playerCellX,&playerCellY,&refsToLoad](CellStoreCollection& collection, int range) -> std::vector<std::pair<int,int>> |  | ||||||
|         { |  | ||||||
|         std::vector<std::pair<int, int>> cellsPositionsToLoad; |         std::vector<std::pair<int, int>> cellsPositionsToLoad; | ||||||
|             for (int x = playerCellX - range; x <= playerCellX + range; ++x) |         // get the number of refs to load
 | ||||||
|  |         for (int x = playerCellX - mHalfGridSize; x <= playerCellX + mHalfGridSize; ++x) | ||||||
|         { |         { | ||||||
|                 for (int y = playerCellY - range; y <= playerCellY + range; ++y) |             for (int y = playerCellY - mHalfGridSize; y <= playerCellY + mHalfGridSize; ++y) | ||||||
|             { |             { | ||||||
|                     if (!isCellInCollection(x, y, collection)) |                 CellStoreCollection::iterator iter = mActiveCells.begin(); | ||||||
|  | 
 | ||||||
|  |                 while (iter!=mActiveCells.end()) | ||||||
|  |                 { | ||||||
|  |                     assert ((*iter)->getCell()->isExterior()); | ||||||
|  | 
 | ||||||
|  |                     if (x==(*iter)->getCell()->getGridX() && | ||||||
|  |                         y==(*iter)->getCell()->getGridY()) | ||||||
|  |                         break; | ||||||
|  | 
 | ||||||
|  |                     ++iter; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 if (iter==mActiveCells.end()) | ||||||
|                 { |                 { | ||||||
|                     refsToLoad += MWBase::Environment::get().getWorld()->getExterior(x, y)->count(); |                     refsToLoad += MWBase::Environment::get().getWorld()->getExterior(x, y)->count(); | ||||||
|                     cellsPositionsToLoad.emplace_back(x, y); |                     cellsPositionsToLoad.emplace_back(x, y); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|             return cellsPositionsToLoad; |  | ||||||
|         }; |  | ||||||
|         auto cellsPositionsToLoad = cellsToLoad(mActiveCells,mHalfGridSize); |  | ||||||
|         auto cellsPositionsToLoadInactive = cellsToLoad(mInactiveCells,mHalfGridSize+1); |  | ||||||
| 
 | 
 | ||||||
|         Loading::Listener* loadingListener = MWBase::Environment::get().getWindowManager()->getLoadingScreen(); |         Loading::Listener* loadingListener = MWBase::Environment::get().getWindowManager()->getLoadingScreen(); | ||||||
|         Loading::ScopedLoad load(loadingListener); |         Loading::ScopedLoad load(loadingListener); | ||||||
|  | @ -640,26 +582,30 @@ namespace MWWorld | ||||||
|                 return getCellPositionPriority(lhs) < getCellPositionPriority(rhs); |                 return getCellPositionPriority(lhs) < getCellPositionPriority(rhs); | ||||||
|             }); |             }); | ||||||
| 
 | 
 | ||||||
|         std::sort(cellsPositionsToLoadInactive.begin(), cellsPositionsToLoadInactive.end(), |  | ||||||
|             [&] (const std::pair<int, int>& lhs, const std::pair<int, int>& rhs) { |  | ||||||
|                 return getCellPositionPriority(lhs) < getCellPositionPriority(rhs); |  | ||||||
|             }); |  | ||||||
| 
 |  | ||||||
|         // Load cells
 |         // Load cells
 | ||||||
|         for (const auto& [x,y] : cellsPositionsToLoadInactive) |         for (const auto& cellPosition : cellsPositionsToLoad) | ||||||
|         { |         { | ||||||
|             if (!isCellInCollection(x, y, mInactiveCells)) |             const auto x = cellPosition.first; | ||||||
|  |             const auto y = cellPosition.second; | ||||||
|  | 
 | ||||||
|  |             CellStoreCollection::iterator iter = mActiveCells.begin(); | ||||||
|  | 
 | ||||||
|  |             while (iter != mActiveCells.end()) | ||||||
|  |             { | ||||||
|  |                 assert ((*iter)->getCell()->isExterior()); | ||||||
|  | 
 | ||||||
|  |                 if (x == (*iter)->getCell()->getGridX() && | ||||||
|  |                     y == (*iter)->getCell()->getGridY()) | ||||||
|  |                     break; | ||||||
|  | 
 | ||||||
|  |                 ++iter; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (iter == mActiveCells.end()) | ||||||
|             { |             { | ||||||
|                 CellStore *cell = MWBase::Environment::get().getWorld()->getExterior(x, y); |                 CellStore *cell = MWBase::Environment::get().getWorld()->getExterior(x, y); | ||||||
|                 loadInactiveCell (cell, loadingListener); | 
 | ||||||
|             } |                 loadCell (cell, loadingListener, changeEvent); | ||||||
|         } |  | ||||||
|         for (const auto& [x,y] : cellsPositionsToLoad) |  | ||||||
|         { |  | ||||||
|             if (!isCellInCollection(x, y, mActiveCells)) |  | ||||||
|             { |  | ||||||
|                 CellStore *cell = MWBase::Environment::get().getWorld()->getExterior(x, y); |  | ||||||
|                 activateCell (cell, loadingListener, changeEvent); |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -692,8 +638,7 @@ namespace MWWorld | ||||||
|             CellStoreCollection::iterator iter = mActiveCells.begin(); |             CellStoreCollection::iterator iter = mActiveCells.begin(); | ||||||
| 
 | 
 | ||||||
|             CellStore *cell = MWBase::Environment::get().getWorld()->getExterior(it->mData.mX, it->mData.mY); |             CellStore *cell = MWBase::Environment::get().getWorld()->getExterior(it->mData.mX, it->mData.mY); | ||||||
|             loadInactiveCell (cell, loadingListener, true); |             loadCell (cell, loadingListener, false, true); | ||||||
|             activateCell (cell, loadingListener, false, true); |  | ||||||
| 
 | 
 | ||||||
|             iter = mActiveCells.begin(); |             iter = mActiveCells.begin(); | ||||||
|             while (iter != mActiveCells.end()) |             while (iter != mActiveCells.end()) | ||||||
|  | @ -701,8 +646,7 @@ namespace MWWorld | ||||||
|                 if (it->isExterior() && it->mData.mX == (*iter)->getCell()->getGridX() && |                 if (it->isExterior() && it->mData.mX == (*iter)->getCell()->getGridX() && | ||||||
|                     it->mData.mY == (*iter)->getCell()->getGridY()) |                     it->mData.mY == (*iter)->getCell()->getGridY()) | ||||||
|                 { |                 { | ||||||
|                     deactivateCell(*iter, true); |                     unloadCell(iter, true); | ||||||
|                     unloadInactiveCell (*iter, true); |  | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|  | @ -740,8 +684,7 @@ namespace MWWorld | ||||||
|             loadingListener->setLabel("Testing interior cells ("+std::to_string(i)+"/"+std::to_string(cells.getIntSize())+")..."); |             loadingListener->setLabel("Testing interior cells ("+std::to_string(i)+"/"+std::to_string(cells.getIntSize())+")..."); | ||||||
| 
 | 
 | ||||||
|             CellStore *cell = MWBase::Environment::get().getWorld()->getInterior(it->mName); |             CellStore *cell = MWBase::Environment::get().getWorld()->getInterior(it->mName); | ||||||
|             loadInactiveCell (cell, loadingListener, true); |             loadCell (cell, loadingListener, false, true); | ||||||
|             activateCell (cell, loadingListener, false, true); |  | ||||||
| 
 | 
 | ||||||
|             CellStoreCollection::iterator iter = mActiveCells.begin(); |             CellStoreCollection::iterator iter = mActiveCells.begin(); | ||||||
|             while (iter != mActiveCells.end()) |             while (iter != mActiveCells.end()) | ||||||
|  | @ -750,8 +693,7 @@ namespace MWWorld | ||||||
| 
 | 
 | ||||||
|                 if (it->mName == (*iter)->getCell()->mName) |                 if (it->mName == (*iter)->getCell()->mName) | ||||||
|                 { |                 { | ||||||
|                     deactivateCell(*iter, true); |                     unloadCell(iter, true); | ||||||
|                     unloadInactiveCell (*iter, true); |  | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|  | @ -874,21 +816,15 @@ namespace MWWorld | ||||||
|         Log(Debug::Info) << "Changing to interior"; |         Log(Debug::Info) << "Changing to interior"; | ||||||
| 
 | 
 | ||||||
|         // unload
 |         // unload
 | ||||||
|         for (auto iter = mInactiveCells.begin(); iter!=mInactiveCells.end(); ) |         CellStoreCollection::iterator active = mActiveCells.begin(); | ||||||
|         { |         while (active!=mActiveCells.end()) | ||||||
|             auto* cell = *iter++; |             unloadCell (active++); | ||||||
|             deactivateCell(cell); |  | ||||||
|             unloadInactiveCell(cell); |  | ||||||
|         } |  | ||||||
|         assert(mActiveCells.empty()); |  | ||||||
|         assert(mInactiveCells.empty()); |  | ||||||
| 
 | 
 | ||||||
|         loadingListener->setProgressRange(cell->count()); |         loadingListener->setProgressRange(cell->count()); | ||||||
| 
 | 
 | ||||||
|         // Load cell.
 |         // Load cell.
 | ||||||
|         mPagedRefs.clear(); |         mPagedRefs.clear(); | ||||||
|         loadInactiveCell (cell, loadingListener); |         loadCell (cell, loadingListener, changeEvent); | ||||||
|         activateCell (cell, loadingListener, changeEvent); |  | ||||||
| 
 | 
 | ||||||
|         changePlayerCell(cell, position, adjustPlayerPos); |         changePlayerCell(cell, position, adjustPlayerPos); | ||||||
| 
 | 
 | ||||||
|  | @ -936,26 +872,23 @@ namespace MWWorld | ||||||
|         mCellChanged = false; |         mCellChanged = false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void Scene::insertCell (CellStore &cell, Loading::Listener* loadingListener, bool onlyStatics, bool test) |     void Scene::insertCell (CellStore &cell, Loading::Listener* loadingListener, bool test) | ||||||
|     { |     { | ||||||
|         InsertVisitor insertVisitor (cell, *loadingListener, onlyStatics, test); |         InsertVisitor insertVisitor (cell, *loadingListener, test); | ||||||
|         cell.forEach (insertVisitor); |         cell.forEach (insertVisitor); | ||||||
|         insertVisitor.insert([&] (const MWWorld::Ptr& ptr) { addObject(ptr, *mPhysics, mRendering, mPagedRefs, onlyStatics); }); |         insertVisitor.insert([&] (const MWWorld::Ptr& ptr) { addObject(ptr, *mPhysics, mRendering, mPagedRefs); }); | ||||||
|         if (!onlyStatics) |  | ||||||
|         { |  | ||||||
|         insertVisitor.insert([&] (const MWWorld::Ptr& ptr) { addObject(ptr, *mPhysics, mNavigator); }); |         insertVisitor.insert([&] (const MWWorld::Ptr& ptr) { addObject(ptr, *mPhysics, mNavigator); }); | ||||||
| 
 | 
 | ||||||
|         // do adjustPosition (snapping actors to ground) after objects are loaded, so we don't depend on the loading order
 |         // do adjustPosition (snapping actors to ground) after objects are loaded, so we don't depend on the loading order
 | ||||||
|         PositionVisitor posVisitor; |         PositionVisitor posVisitor; | ||||||
|         cell.forEach (posVisitor); |         cell.forEach (posVisitor); | ||||||
|     } |     } | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     void Scene::addObjectToScene (const Ptr& ptr) |     void Scene::addObjectToScene (const Ptr& ptr) | ||||||
|     { |     { | ||||||
|         try |         try | ||||||
|         { |         { | ||||||
|             addObject(ptr, *mPhysics, mRendering, mPagedRefs, false); |             addObject(ptr, *mPhysics, mRendering, mPagedRefs); | ||||||
|             addObject(ptr, *mPhysics, mNavigator); |             addObject(ptr, *mPhysics, mNavigator); | ||||||
|             MWBase::Environment::get().getWorld()->scaleObject(ptr, ptr.getCellRef().getScale()); |             MWBase::Environment::get().getWorld()->scaleObject(ptr, ptr.getCellRef().getScale()); | ||||||
|             const auto navigator = MWBase::Environment::get().getWorld()->getNavigator(); |             const auto navigator = MWBase::Environment::get().getWorld()->getNavigator(); | ||||||
|  |  | ||||||
|  | @ -65,13 +65,13 @@ namespace MWWorld | ||||||
|     class Scene |     class Scene | ||||||
|     { |     { | ||||||
|         public: |         public: | ||||||
|             using CellStoreCollection = std::set<CellStore *>; | 
 | ||||||
|  |             typedef std::set<CellStore *> CellStoreCollection; | ||||||
| 
 | 
 | ||||||
|         private: |         private: | ||||||
| 
 | 
 | ||||||
|             CellStore* mCurrentCell; // the cell the player is in
 |             CellStore* mCurrentCell; // the cell the player is in
 | ||||||
|             CellStoreCollection mActiveCells; |             CellStoreCollection mActiveCells; | ||||||
|             CellStoreCollection mInactiveCells; |  | ||||||
|             bool mCellChanged; |             bool mCellChanged; | ||||||
|             MWPhysics::PhysicsSystem *mPhysics; |             MWPhysics::PhysicsSystem *mPhysics; | ||||||
|             MWRender::RenderingManager& mRendering; |             MWRender::RenderingManager& mRendering; | ||||||
|  | @ -92,7 +92,7 @@ namespace MWWorld | ||||||
| 
 | 
 | ||||||
|             std::set<ESM::RefNum> mPagedRefs; |             std::set<ESM::RefNum> mPagedRefs; | ||||||
| 
 | 
 | ||||||
|             void insertCell (CellStore &cell, Loading::Listener* loadingListener, bool onlyStatics, bool test = false); |             void insertCell (CellStore &cell, Loading::Listener* loadingListener, bool test = false); | ||||||
|             osg::Vec2i mCurrentGridCenter; |             osg::Vec2i mCurrentGridCenter; | ||||||
| 
 | 
 | ||||||
|             // Load and unload cells as necessary to create a cell grid with "X" and "Y" in the center
 |             // Load and unload cells as necessary to create a cell grid with "X" and "Y" in the center
 | ||||||
|  | @ -108,11 +108,6 @@ namespace MWWorld | ||||||
|             osg::Vec4i gridCenterToBounds(const osg::Vec2i ¢erCell) const; |             osg::Vec4i gridCenterToBounds(const osg::Vec2i ¢erCell) const; | ||||||
|             osg::Vec2i getNewGridCenter(const osg::Vec3f &pos, const osg::Vec2i *currentGridCenter = nullptr) const; |             osg::Vec2i getNewGridCenter(const osg::Vec3f &pos, const osg::Vec2i *currentGridCenter = nullptr) const; | ||||||
| 
 | 
 | ||||||
|             void unloadInactiveCell (CellStore* cell, bool test = false); |  | ||||||
|             void deactivateCell (CellStore* cell, bool test = false); |  | ||||||
|             void activateCell (CellStore *cell, Loading::Listener* loadingListener, bool respawn, bool test = false); |  | ||||||
|             void loadInactiveCell (CellStore *cell, Loading::Listener* loadingListener, bool test = false); |  | ||||||
| 
 |  | ||||||
|         public: |         public: | ||||||
| 
 | 
 | ||||||
|             Scene (MWRender::RenderingManager& rendering, MWPhysics::PhysicsSystem *physics, |             Scene (MWRender::RenderingManager& rendering, MWPhysics::PhysicsSystem *physics, | ||||||
|  | @ -124,6 +119,10 @@ namespace MWWorld | ||||||
|             void preloadTerrain(const osg::Vec3f& pos, bool sync=false); |             void preloadTerrain(const osg::Vec3f& pos, bool sync=false); | ||||||
|             void reloadTerrain(); |             void reloadTerrain(); | ||||||
| 
 | 
 | ||||||
|  |             void unloadCell (CellStoreCollection::iterator iter, bool test = false); | ||||||
|  | 
 | ||||||
|  |             void loadCell (CellStore *cell, Loading::Listener* loadingListener, bool respawn, bool test = false); | ||||||
|  | 
 | ||||||
|             void playerMoved (const osg::Vec3f& pos); |             void playerMoved (const osg::Vec3f& pos); | ||||||
| 
 | 
 | ||||||
|             void changePlayerCell (CellStore* newCell, const ESM::Position& position, bool adjustPlayerPos); |             void changePlayerCell (CellStore* newCell, const ESM::Position& position, bool adjustPlayerPos); | ||||||
|  |  | ||||||
|  | @ -1420,7 +1420,7 @@ namespace MWWorld | ||||||
|             mWorldScene->removeFromPagedRefs(ptr); |             mWorldScene->removeFromPagedRefs(ptr); | ||||||
| 
 | 
 | ||||||
|             mRendering->rotateObject(ptr, rotate); |             mRendering->rotateObject(ptr, rotate); | ||||||
|             mPhysics->updateRotation(ptr, rotate); |             mPhysics->updateRotation(ptr); | ||||||
| 
 | 
 | ||||||
|             if (const auto object = mPhysics->getObject(ptr)) |             if (const auto object = mPhysics->getObject(ptr)) | ||||||
|                 updateNavigatorObject(object); |                 updateNavigatorObject(object); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue