mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 15:56:37 +00:00 
			
		
		
		
	Use moveObjectBy in SetPos
This commit is contained in:
		
							parent
							
								
									03b86c232b
								
							
						
					
					
						commit
						cb39f8fb01
					
				
					 1 changed files with 8 additions and 10 deletions
				
			
		|  | @ -270,20 +270,17 @@ namespace MWScript | ||||||
|                     Interpreter::Type_Float pos = runtime[0].mFloat; |                     Interpreter::Type_Float pos = runtime[0].mFloat; | ||||||
|                     runtime.pop(); |                     runtime.pop(); | ||||||
| 
 | 
 | ||||||
|                     float ax = ptr.getRefData().getPosition().pos[0]; |  | ||||||
|                     float ay = ptr.getRefData().getPosition().pos[1]; |  | ||||||
|                     float az = ptr.getRefData().getPosition().pos[2]; |  | ||||||
| 
 |  | ||||||
|                     // Note: SetPos does not skip weather transitions in vanilla engine, so we do not call setTeleported(true) here.
 |                     // Note: SetPos does not skip weather transitions in vanilla engine, so we do not call setTeleported(true) here.
 | ||||||
| 
 | 
 | ||||||
|                     MWWorld::Ptr updated = ptr; |                     const auto curPos = ptr.getRefData().getPosition().asVec3(); | ||||||
|  |                     auto newPos = curPos; | ||||||
|                     if(axis == "x") |                     if(axis == "x") | ||||||
|                     { |                     { | ||||||
|                         updated = MWBase::Environment::get().getWorld()->moveObject(ptr,pos,ay,az,true); |                         newPos[0] = pos; | ||||||
|                     } |                     } | ||||||
|                     else if(axis == "y") |                     else if(axis == "y") | ||||||
|                     { |                     { | ||||||
|                         updated = MWBase::Environment::get().getWorld()->moveObject(ptr,ax,pos,az,true); |                         newPos[1] = pos; | ||||||
|                     } |                     } | ||||||
|                     else if(axis == "z") |                     else if(axis == "z") | ||||||
|                     { |                     { | ||||||
|  | @ -292,20 +289,21 @@ namespace MWScript | ||||||
|                         { |                         { | ||||||
|                             float terrainHeight = -std::numeric_limits<float>::max(); |                             float terrainHeight = -std::numeric_limits<float>::max(); | ||||||
|                             if (ptr.getCell()->isExterior()) |                             if (ptr.getCell()->isExterior()) | ||||||
|                                 terrainHeight = MWBase::Environment::get().getWorld()->getTerrainHeightAt(osg::Vec3f(ax, ay, az)); |                                 terrainHeight = MWBase::Environment::get().getWorld()->getTerrainHeightAt(curPos); | ||||||
| 
 | 
 | ||||||
|                             if (pos < terrainHeight) |                             if (pos < terrainHeight) | ||||||
|                                 pos = terrainHeight; |                                 pos = terrainHeight; | ||||||
|                         } |                         } | ||||||
| 
 | 
 | ||||||
|                         updated = MWBase::Environment::get().getWorld()->moveObject(ptr,ax,ay,pos,true); |                         newPos[2] = pos; | ||||||
|                     } |                     } | ||||||
|                     else |                     else | ||||||
|                     { |                     { | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
| 
 | 
 | ||||||
|                     dynamic_cast<MWScript::InterpreterContext&>(runtime.getContext()).updatePtr(ptr,updated); |                     dynamic_cast<MWScript::InterpreterContext&>(runtime.getContext()).updatePtr(ptr, | ||||||
|  |                         MWBase::Environment::get().getWorld()->moveObjectBy(ptr, newPos - curPos)); | ||||||
|                 } |                 } | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue