mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 22:26:37 +00:00 
			
		
		
		
	clipFudge fix
This commit is contained in:
		
							parent
							
								
									682f30ef9c
								
							
						
					
					
						commit
						e3b30baff9
					
				
					 1 changed files with 6 additions and 5 deletions
				
			
		|  | @ -152,12 +152,9 @@ class ClipCullNode : public osg::Group | ||||||
| 
 | 
 | ||||||
|             osg::RefMatrix* modelViewMatrix = new osg::RefMatrix(*cv->getModelViewMatrix()); |             osg::RefMatrix* modelViewMatrix = new osg::RefMatrix(*cv->getModelViewMatrix()); | ||||||
| 
 | 
 | ||||||
|             // move the plane back along its normal a little bit to prevent bleeding at the water shore
 |             // apply the height of the plane
 | ||||||
|             const float clipFudge = -5; |  | ||||||
|             // now apply the height of the plane
 |  | ||||||
|             // we can't apply this height in the addClipPlane() since the "flip the below graph" function would otherwise flip the height as well
 |             // we can't apply this height in the addClipPlane() since the "flip the below graph" function would otherwise flip the height as well
 | ||||||
|             float translate = clipFudge + ((*mCullPlane)[3] * -1); |             modelViewMatrix->preMultTranslate(mCullPlane->getNormal() * ((*mCullPlane)[3] * -1)); | ||||||
|             modelViewMatrix->preMultTranslate(mCullPlane->getNormal() * translate); |  | ||||||
| 
 | 
 | ||||||
|             // flip the below graph if the eye point is above the plane
 |             // flip the below graph if the eye point is above the plane
 | ||||||
|             if (mCullPlane->intersect(osg::BoundingSphere(osg::Vec3d(0,0,eyePoint.z()), 0)) > 0) |             if (mCullPlane->intersect(osg::BoundingSphere(osg::Vec3d(0,0,eyePoint.z()), 0)) > 0) | ||||||
|  | @ -165,6 +162,10 @@ class ClipCullNode : public osg::Group | ||||||
|                 modelViewMatrix->preMultScale(osg::Vec3(1,1,-1)); |                 modelViewMatrix->preMultScale(osg::Vec3(1,1,-1)); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             // move the plane back along its normal a little bit to prevent bleeding at the water shore
 | ||||||
|  |             const float clipFudge = -5; | ||||||
|  |             modelViewMatrix->preMultTranslate(mCullPlane->getNormal() * clipFudge); | ||||||
|  | 
 | ||||||
|             cv->pushModelViewMatrix(modelViewMatrix, osg::Transform::RELATIVE_RF); |             cv->pushModelViewMatrix(modelViewMatrix, osg::Transform::RELATIVE_RF); | ||||||
|             traverse(node, nv); |             traverse(node, nv); | ||||||
|             cv->popModelViewMatrix(); |             cv->popModelViewMatrix(); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue