2013-11-02 01:48:30 +00:00
# include "scenewidget.hpp"
# include <QEvent>
# include <QResizeEvent>
2014-02-25 12:09:37 +00:00
# include <QTimer>
2014-07-14 09:19:59 +00:00
# include <QShortcut>
2015-03-19 22:27:14 +00:00
# include <QLayout>
2013-11-02 01:48:30 +00:00
2015-03-28 19:15:17 +00:00
# include <osgQt/GraphicsWindowQt>
# include <osg/GraphicsContext>
# include <osgViewer/CompositeViewer>
# include <osgViewer/ViewerEventHandlers>
# include <components/resource/scenemanager.hpp>
2014-07-08 10:39:12 +00:00
# include "../widget/scenetoolmode.hpp"
2014-09-23 12:33:49 +00:00
# include "../../model/settings/usersettings.hpp"
2014-03-23 14:14:26 +00:00
2014-02-27 14:23:14 +00:00
# include "navigation.hpp"
2014-03-23 14:14:26 +00:00
# include "lighting.hpp"
2014-02-27 14:23:14 +00:00
2015-03-19 22:27:14 +00:00
namespace CSVRender
{
2013-11-02 01:48:30 +00:00
2015-03-28 19:15:17 +00:00
RenderWidget : : RenderWidget ( QWidget * parent , Qt : : WindowFlags f )
2015-03-19 22:27:14 +00:00
: QWidget ( parent , f )
2015-03-19 23:39:24 +00:00
, mRootNode ( 0 )
2015-03-19 22:27:14 +00:00
{
2013-11-02 01:48:30 +00:00
2015-03-23 14:55:57 +00:00
osgViewer : : CompositeViewer & viewer = CompositeViewer : : get ( ) ;
2014-02-27 14:23:14 +00:00
2015-03-19 22:27:14 +00:00
osg : : DisplaySettings * ds = osg : : DisplaySettings : : instance ( ) . get ( ) ;
2015-03-19 23:39:24 +00:00
//ds->setNumMultiSamples(8);
2015-03-23 14:55:57 +00:00
2015-03-19 22:27:14 +00:00
osg : : ref_ptr < osg : : GraphicsContext : : Traits > traits = new osg : : GraphicsContext : : Traits ;
traits - > windowName = " " ;
traits - > windowDecoration = true ;
traits - > x = 0 ;
traits - > y = 0 ;
traits - > width = width ( ) ;
traits - > height = height ( ) ;
traits - > doubleBuffer = true ;
traits - > alpha = ds - > getMinimumNumAlphaBits ( ) ;
traits - > stencil = ds - > getMinimumNumStencilBits ( ) ;
traits - > sampleBuffers = ds - > getMultiSamples ( ) ;
traits - > samples = ds - > getNumMultiSamples ( ) ;
2015-03-19 23:39:24 +00:00
// Doesn't make much sense as we're running on demand updates, and there seems to be a bug with the refresh rate when running multiple QGLWidgets
traits - > vsync = false ;
2014-02-25 12:09:37 +00:00
2015-03-23 14:55:57 +00:00
mView = new osgViewer : : View ;
osg : : ref_ptr < osgQt : : GraphicsWindowQt > window = new osgQt : : GraphicsWindowQt ( traits . get ( ) ) ;
2015-03-19 22:27:14 +00:00
QLayout * layout = new QHBoxLayout ( this ) ;
layout - > addWidget ( window - > getGLWidget ( ) ) ;
setLayout ( layout ) ;
2014-02-25 12:39:49 +00:00
2015-03-23 14:55:57 +00:00
mView - > getCamera ( ) - > setGraphicsContext ( window ) ;
mView - > getCamera ( ) - > setClearColor ( osg : : Vec4 ( 0.2 , 0.2 , 0.6 , 1.0 ) ) ;
mView - > getCamera ( ) - > setViewport ( new osg : : Viewport ( 0 , 0 , traits - > width , traits - > height ) ) ;
mView - > getCamera ( ) - > setProjectionMatrixAsPerspective ( 30.0f , static_cast < double > ( traits - > width ) / static_cast < double > ( traits - > height ) , 1.0f , 10000.0f ) ;
2014-02-25 13:09:07 +00:00
2015-03-19 23:39:24 +00:00
mRootNode = new osg : : Group ;
2015-03-28 19:15:17 +00:00
addDefaultRootState ( mRootNode - > getOrCreateStateSet ( ) ) ;
2015-03-25 22:35:10 +00:00
2015-03-23 14:55:57 +00:00
mView - > setSceneData ( mRootNode ) ;
2015-03-19 23:39:24 +00:00
// Press S to reveal profiling stats
2015-03-23 14:55:57 +00:00
mView - > addEventHandler ( new osgViewer : : StatsHandler ) ;
mView - > getCamera ( ) - > setCullMask ( ~ ( 0x1 ) ) ;
viewer . addView ( mView ) ;
viewer . setDone ( false ) ;
viewer . realize ( ) ;
}
2015-03-28 19:15:17 +00:00
void RenderWidget : : addDefaultRootState ( osg : : StateSet * stateset )
{
stateset - > setMode ( GL_NORMALIZE , osg : : StateAttribute : : ON ) ;
stateset - > setMode ( GL_CULL_FACE , osg : : StateAttribute : : ON ) ;
}
RenderWidget : : ~ RenderWidget ( )
2015-03-23 14:55:57 +00:00
{
CompositeViewer : : get ( ) . removeView ( mView ) ;
}
2015-03-28 19:15:17 +00:00
void RenderWidget : : flagAsModified ( )
2015-03-23 14:55:57 +00:00
{
mView - > requestRedraw ( ) ;
}
2015-03-28 19:15:17 +00:00
void RenderWidget : : setVisibilityMask ( int mask )
2015-03-25 23:27:39 +00:00
{
// 0x1 reserved for separating cull and update visitors
mView - > getCamera ( ) - > setCullMask ( mask < < 1 ) ;
}
2015-03-28 19:15:17 +00:00
// --------------------------------------------------
2015-03-23 14:55:57 +00:00
CompositeViewer : : CompositeViewer ( )
{
# if QT_VERSION >= 0x050000
// Qt5 is currently crashing and reporting "Cannot make QOpenGLContext current in a different thread" when the viewer is run multi-threaded, this is regression from Qt4
osgViewer : : ViewerBase : : ThreadingModel threadingModel = osgViewer : : ViewerBase : : SingleThreaded ;
# else
osgViewer : : ViewerBase : : ThreadingModel threadingModel = osgViewer : : ViewerBase : : CullDrawThreadPerContext ;
# endif
setThreadingModel ( threadingModel ) ;
// disable the default setting of viewer.done() by pressing Escape.
setKeyEventSetsDone ( 0 ) ;
2014-02-25 13:09:07 +00:00
2015-03-19 22:27:14 +00:00
// Only render when the camera position changed, or content flagged dirty
//setRunFrameScheme(osgViewer::ViewerBase::ON_DEMAND);
2015-03-19 23:39:24 +00:00
setRunFrameScheme ( osgViewer : : ViewerBase : : CONTINUOUS ) ;
2014-02-25 12:09:37 +00:00
2015-03-19 22:27:14 +00:00
connect ( & mTimer , SIGNAL ( timeout ( ) ) , this , SLOT ( update ( ) ) ) ;
2015-03-28 19:15:17 +00:00
mTimer . start ( 10 ) ;
2015-03-19 22:27:14 +00:00
}
2014-09-28 04:08:14 +00:00
2015-03-23 14:55:57 +00:00
CompositeViewer & CompositeViewer : : get ( )
2015-03-19 22:27:14 +00:00
{
2015-03-23 14:55:57 +00:00
static CompositeViewer sThis ;
return sThis ;
2015-03-19 22:27:14 +00:00
}
2014-09-28 05:43:33 +00:00
2015-03-23 14:55:57 +00:00
void CompositeViewer : : update ( )
2015-03-19 22:27:14 +00:00
{
2015-03-23 14:55:57 +00:00
frame ( ) ;
2015-03-19 22:27:14 +00:00
}
2014-09-28 20:27:54 +00:00
2015-03-28 19:15:17 +00:00
// ---------------------------------------------------
SceneWidget : : SceneWidget ( Resource : : SceneManager * sceneManager , QWidget * parent , Qt : : WindowFlags f )
: RenderWidget ( parent , f )
, mSceneManager ( sceneManager )
, mLighting ( NULL )
{
//mView->setLightingMode(osgViewer::View::NO_LIGHT);
setLighting ( & mLightingDay ) ;
}
SceneWidget : : ~ SceneWidget ( )
{
// Since we're holding on to the scene templates past the existance of this graphics context, we'll need to manually release the created objects
mSceneManager - > releaseGLObjects ( mView - > getCamera ( ) - > getGraphicsContext ( ) - > getState ( ) ) ;
}
void SceneWidget : : setLighting ( Lighting * lighting )
{
if ( mLighting )
mLighting - > deactivate ( ) ;
mLighting = lighting ;
mLighting - > activate ( mView . get ( ) , mHasDefaultAmbient ? & mDefaultAmbient : 0 ) ;
flagAsModified ( ) ;
}
void SceneWidget : : selectLightingMode ( const std : : string & mode )
{
if ( mode = = " day " )
setLighting ( & mLightingDay ) ;
else if ( mode = = " night " )
setLighting ( & mLightingNight ) ;
else if ( mode = = " bright " )
setLighting ( & mLightingBright ) ;
}
CSVWidget : : SceneToolMode * SceneWidget : : makeLightingSelector ( CSVWidget : : SceneToolbar * parent )
{
CSVWidget : : SceneToolMode * tool = new CSVWidget : : SceneToolMode ( parent , " Lighting Mode " ) ;
/// \todo replace icons
tool - > addButton ( " :scenetoolbar/day " , " day " ,
" Day "
" <ul><li>Cell specific ambient in interiors</li> "
" <li>Low ambient in exteriors</li> "
" <li>Strong directional light source</li> "
" <li>This mode closely resembles day time in-game</li></ul> " ) ;
tool - > addButton ( " :scenetoolbar/night " , " night " ,
" Night "
" <ul><li>Cell specific ambient in interiors</li> "
" <li>Low ambient in exteriors</li> "
" <li>Weak directional light source</li> "
" <li>This mode closely resembles night time in-game</li></ul> " ) ;
tool - > addButton ( " :scenetoolbar/bright " , " bright " ,
" Bright "
" <ul><li>Maximum ambient</li> "
" <li>Strong directional light source</li></ul> " ) ;
connect ( tool , SIGNAL ( modeChanged ( const std : : string & ) ) ,
this , SLOT ( selectLightingMode ( const std : : string & ) ) ) ;
return tool ;
}
void SceneWidget : : setDefaultAmbient ( const osg : : Vec4f & colour )
{
mDefaultAmbient = colour ;
mHasDefaultAmbient = true ;
if ( mLighting )
mLighting - > setDefaultAmbient ( colour ) ;
}
2013-11-02 01:48:30 +00:00
}