]> git.mxchange.org Git - flightgear.git/commitdiff
CanvasWidget: get new GUI camera on reset.
authorThomas Geymayer <tomgey@gmail.com>
Sun, 1 Dec 2013 11:57:14 +0000 (12:57 +0100)
committerThomas Geymayer <tomgey@gmail.com>
Sun, 1 Dec 2013 11:58:17 +0000 (12:58 +0100)
src/Canvas/canvas_mgr.cxx
src/Canvas/canvas_mgr.hxx

index 113da4f0cf878f660c5aecceb78b7671c72809d6..6bef1f476d083f021aae193a63f4d22038804f64 100644 (file)
@@ -75,6 +75,9 @@ CanvasMgr::CanvasMgr():
 //----------------------------------------------------------------------------
 void CanvasMgr::init()
 {
+  _gui_camera = flightgear::getGUICamera(flightgear::CameraGroup::getDefault());
+  assert(_gui_camera.valid());
+
   sc::Canvas::addPlacementFactory
   (
     "object",
@@ -99,12 +102,17 @@ void CanvasMgr::shutdown()
 
   sc::Canvas::removePlacementFactory("object");
   sc::Canvas::removePlacementFactory("scenery-object");
+
+  _gui_camera = 0;
 }
 
 //------------------------------------------------------------------------------
 unsigned int
 CanvasMgr::getCanvasTexId(const simgear::canvas::CanvasPtr& canvas) const
 {
+  if( !canvas )
+    return 0;
+
   osg::Texture2D* tex = canvas->getTexture();
   if( !tex )
     return 0;
@@ -115,8 +123,9 @@ CanvasMgr::getCanvasTexId(const simgear::canvas::CanvasPtr& canvas) const
 //  if( contexts.empty() )
 //    return 0;
 
-  static osg::Camera* guiCamera =
-    flightgear::getGUICamera(flightgear::CameraGroup::getDefault());
+  osg::ref_ptr<osg::Camera> guiCamera;
+  if( !_gui_camera.lock(guiCamera) )
+    return 0;
 
   osg::State* state = guiCamera->getGraphicsContext()->getState(); //contexts[0]->getState();
   if( !state )
index 4bc712bd9e44c014f7d80c9fb332d2d41c56212e..b14403491b9a1c7a182ce4df27dd34cf61942d0d 100644 (file)
@@ -44,6 +44,7 @@ class CanvasMgr:
 
   protected:
 
+    osg::observer_ptr<osg::Camera>      _gui_camera;
     SGPropertyChangeCallback<CanvasMgr> _cb_model_reinit;
 
     void handleModelReinit(SGPropertyNode*);