mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 14:26:40 +00:00 
			
		
		
		
	Cleanup, move setup to CameraController class
This commit is contained in:
		
							parent
							
								
									efa2ec21ff
								
							
						
					
					
						commit
						a4cc891383
					
				
					 3 changed files with 33 additions and 30 deletions
				
			
		|  | @ -2,8 +2,11 @@ | ||||||
| 
 | 
 | ||||||
| #include <QKeyEvent> | #include <QKeyEvent> | ||||||
| 
 | 
 | ||||||
|  | #include <osg/BoundingBox> | ||||||
| #include <osg/Camera> | #include <osg/Camera> | ||||||
|  | #include <osg/ComputeBoundsVisitor> | ||||||
| #include <osg/Drawable> | #include <osg/Drawable> | ||||||
|  | #include <osg/Group> | ||||||
| #include <osg/Matrixd> | #include <osg/Matrixd> | ||||||
| #include <osg/Quat> | #include <osg/Quat> | ||||||
| 
 | 
 | ||||||
|  | @ -92,16 +95,38 @@ namespace CSVRender | ||||||
|         mWheelMoveMult = value; |         mWheelMoveMult = value; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void CameraController::setSceneBounds(const osg::BoundingBox& bounds, const osg::Vec3d& up) |     void CameraController::setup(osg::Group* root, unsigned int mask, const osg::Vec3d& up) | ||||||
|     { |     { | ||||||
|         osg::Vec3d minBounds = bounds.corner(0) - bounds.center(); |         // Find World bounds
 | ||||||
|         osg::Vec3d maxBounds = bounds.corner(7) - bounds.center(); |         osg::ComputeBoundsVisitor boundsVisitor; | ||||||
|  |         osg::BoundingBox& boundingBox = boundsVisitor.getBoundingBox(); | ||||||
|  | 
 | ||||||
|  |         boundsVisitor.setNodeMaskOverride(mask); | ||||||
|  |         root->accept(boundsVisitor); | ||||||
|  | 
 | ||||||
|  |         if (!boundingBox.valid()) | ||||||
|  |         { | ||||||
|  |             // Try again without any mask
 | ||||||
|  |             boundsVisitor.reset(); | ||||||
|  |             boundsVisitor.setNodeMaskOverride(~0); | ||||||
|  |             root->accept(boundsVisitor); | ||||||
|  | 
 | ||||||
|  |             // Last resort, set a default
 | ||||||
|  |             if (!boundingBox.valid()) | ||||||
|  |             { | ||||||
|  |                 boundingBox.set(-1, -1, -1, 1, 1, 1); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         // Calculate a good starting position
 | ||||||
|  |         osg::Vec3d minBounds = boundingBox.corner(0) - boundingBox.center(); | ||||||
|  |         osg::Vec3d maxBounds = boundingBox.corner(7) - boundingBox.center(); | ||||||
| 
 | 
 | ||||||
|         osg::Vec3d camOffset = up * maxBounds > 0 ? maxBounds : minBounds; |         osg::Vec3d camOffset = up * maxBounds > 0 ? maxBounds : minBounds; | ||||||
|         camOffset *= 2; |         camOffset *= 2; | ||||||
| 
 | 
 | ||||||
|         osg::Vec3d eye = camOffset + bounds.center(); |         osg::Vec3d eye = camOffset + boundingBox.center(); | ||||||
|         osg::Vec3d center = bounds.center(); |         osg::Vec3d center = boundingBox.center(); | ||||||
| 
 | 
 | ||||||
|         getCamera()->setViewMatrixAsLookAt(eye, center, up); |         getCamera()->setViewMatrixAsLookAt(eye, center, up); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -3,7 +3,6 @@ | ||||||
| 
 | 
 | ||||||
| #include <string> | #include <string> | ||||||
| 
 | 
 | ||||||
| #include <osg/BoundingBox> |  | ||||||
| #include <osg/ref_ptr> | #include <osg/ref_ptr> | ||||||
| #include <osg/Vec3d> | #include <osg/Vec3d> | ||||||
| 
 | 
 | ||||||
|  | @ -12,6 +11,7 @@ class QKeyEvent; | ||||||
| namespace osg | namespace osg | ||||||
| { | { | ||||||
|     class Camera; |     class Camera; | ||||||
|  |     class Group; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| namespace CSVRender | namespace CSVRender | ||||||
|  | @ -43,7 +43,7 @@ namespace CSVRender | ||||||
|             void setWheelMovementMultiplier(double value); |             void setWheelMovementMultiplier(double value); | ||||||
| 
 | 
 | ||||||
|             // moves the camera to an intelligent position
 |             // moves the camera to an intelligent position
 | ||||||
|             void setSceneBounds(const osg::BoundingBox& bounds, const osg::Vec3d& up); |             void setup(osg::Group* root, unsigned int mask, const osg::Vec3d& up); | ||||||
| 
 | 
 | ||||||
|             virtual bool handleKeyEvent(QKeyEvent* event, bool pressed) = 0; |             virtual bool handleKeyEvent(QKeyEvent* event, bool pressed) = 0; | ||||||
|             virtual bool handleMouseMoveEvent(std::string mode, int x, int y) = 0; |             virtual bool handleMouseMoveEvent(std::string mode, int x, int y) = 0; | ||||||
|  |  | ||||||
|  | @ -12,7 +12,6 @@ | ||||||
| #include <osgViewer/ViewerEventHandlers> | #include <osgViewer/ViewerEventHandlers> | ||||||
| #include <osg/LightModel> | #include <osg/LightModel> | ||||||
| #include <osg/BoundingBox> | #include <osg/BoundingBox> | ||||||
| #include <osg/ComputeBoundsVisitor> |  | ||||||
| 
 | 
 | ||||||
| #include <osgGA/TrackballManipulator> | #include <osgGA/TrackballManipulator> | ||||||
| #include <osgGA/FirstPersonManipulator> | #include <osgGA/FirstPersonManipulator> | ||||||
|  | @ -315,28 +314,7 @@ void SceneWidget::update(double dt) | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         osg::ComputeBoundsVisitor boundsVisitor; |         mCurrentCamControl->setup(mRootNode, Mask_Reference | Mask_Terrain, CameraController::WorldUp); | ||||||
|         osg::BoundingBox &boundingBox(boundsVisitor.getBoundingBox()); |  | ||||||
|         boundsVisitor.setNodeMaskOverride(Mask_Reference | Mask_Terrain); |  | ||||||
| 
 |  | ||||||
|         mRootNode->accept(boundsVisitor); |  | ||||||
| 
 |  | ||||||
|         // Remove mask if nothing is found
 |  | ||||||
|         if (!boundingBox.valid()) |  | ||||||
|         { |  | ||||||
|             boundsVisitor.reset(); |  | ||||||
|             boundsVisitor.setNodeMaskOverride(~0); |  | ||||||
|             mRootNode->accept(boundsVisitor); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // Set a default if there is still nothing found
 |  | ||||||
|         if (!boundingBox.valid()) |  | ||||||
|         { |  | ||||||
|             boundingBox.set(-1, -1, -1, 1, 1, 1); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         mCurrentCamControl->setSceneBounds(boundingBox, CameraController::WorldUp); |  | ||||||
| 
 |  | ||||||
|         mCamPositionSet = true; |         mCamPositionSet = true; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue