mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 18:26:37 +00:00 
			
		
		
		
	Fix actor models incorrectly being rotated on X/Y axes
This commit is contained in:
		
							parent
							
								
									0966755a0c
								
							
						
					
					
						commit
						5660f283dd
					
				
					 2 changed files with 12 additions and 15 deletions
				
			
		|  | @ -54,17 +54,12 @@ void Actors::insertBegin(const MWWorld::Ptr &ptr) | ||||||
|     // Convert MW rotation to a quaternion:
 |     // Convert MW rotation to a quaternion:
 | ||||||
|     f = ptr.getCellRef().getPosition().rot; |     f = ptr.getCellRef().getPosition().rot; | ||||||
| 
 | 
 | ||||||
|     // Rotate around X axis
 |     // For rendering purposes, actors should only rotate around the Z axis.
 | ||||||
|     Ogre::Quaternion xr(Ogre::Radian(-f[0]), Ogre::Vector3::UNIT_X); |     // X rotation is used for camera rotation (for the player) and for
 | ||||||
| 
 |     // ranged magic / ranged weapon aiming.
 | ||||||
|     // Rotate around Y axis
 |  | ||||||
|     Ogre::Quaternion yr(Ogre::Radian(-f[1]), Ogre::Vector3::UNIT_Y); |  | ||||||
| 
 |  | ||||||
|     // Rotate around Z axis
 |  | ||||||
|     Ogre::Quaternion zr(Ogre::Radian(-f[2]), Ogre::Vector3::UNIT_Z); |     Ogre::Quaternion zr(Ogre::Radian(-f[2]), Ogre::Vector3::UNIT_Z); | ||||||
| 
 | 
 | ||||||
|    // Rotates first around z, then y, then x
 |     insert->setOrientation(zr); | ||||||
|     insert->setOrientation(xr*yr*zr); |  | ||||||
|     ptr.getRefData().setBaseNode(insert); |     ptr.getRefData().setBaseNode(insert); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1116,13 +1116,15 @@ namespace MWWorld | ||||||
|             while(ptr.getRefData().getLocalRotation().rot[2]<=-fullRotateRad) |             while(ptr.getRefData().getLocalRotation().rot[2]<=-fullRotateRad) | ||||||
|                 ptr.getRefData().getLocalRotation().rot[2]+=fullRotateRad; |                 ptr.getRefData().getLocalRotation().rot[2]+=fullRotateRad; | ||||||
| 
 | 
 | ||||||
|             Ogre::Quaternion worldRotQuat(Ogre::Quaternion(Ogre::Radian(ptr.getRefData().getPosition().rot[0]), Ogre::Vector3::NEGATIVE_UNIT_X)* |             Ogre::Quaternion worldRotQuat(Ogre::Radian(ptr.getRefData().getPosition().rot[2]), Ogre::Vector3::NEGATIVE_UNIT_Z); | ||||||
|             Ogre::Quaternion(Ogre::Radian(ptr.getRefData().getPosition().rot[1]), Ogre::Vector3::NEGATIVE_UNIT_Y)* |             if (!ptr.getClass().isActor()) | ||||||
|             Ogre::Quaternion(Ogre::Radian(ptr.getRefData().getPosition().rot[2]), Ogre::Vector3::NEGATIVE_UNIT_Z)); |                 worldRotQuat = Ogre::Quaternion(Ogre::Radian(ptr.getRefData().getPosition().rot[0]), Ogre::Vector3::NEGATIVE_UNIT_X)* | ||||||
|  |                         Ogre::Quaternion(Ogre::Radian(ptr.getRefData().getPosition().rot[1]), Ogre::Vector3::NEGATIVE_UNIT_Y)* worldRotQuat; | ||||||
| 
 | 
 | ||||||
|             Ogre::Quaternion rot(Ogre::Quaternion(Ogre::Degree(x), Ogre::Vector3::NEGATIVE_UNIT_X)* |             Ogre::Quaternion rot(Ogre::Degree(z), Ogre::Vector3::NEGATIVE_UNIT_Z); | ||||||
|             Ogre::Quaternion(Ogre::Degree(y), Ogre::Vector3::NEGATIVE_UNIT_Y)* |             if (!ptr.getClass().isActor()) | ||||||
|             Ogre::Quaternion(Ogre::Degree(z), Ogre::Vector3::NEGATIVE_UNIT_Z)); |                 rot = Ogre::Quaternion(Ogre::Degree(x), Ogre::Vector3::NEGATIVE_UNIT_X)* | ||||||
|  |                 Ogre::Quaternion(Ogre::Degree(y), Ogre::Vector3::NEGATIVE_UNIT_Y)*rot; | ||||||
| 
 | 
 | ||||||
|             ptr.getRefData().getBaseNode()->setOrientation(worldRotQuat*rot); |             ptr.getRefData().getBaseNode()->setOrientation(worldRotQuat*rot); | ||||||
|             mPhysics->rotateObject(ptr); |             mPhysics->rotateObject(ptr); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue