X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FMain%2Frenderer.hxx;h=5fd8e9b36f652fdb91735920215e276017602ca3;hb=c053de6b4c4c3a9b22648d3c7e798cfd087887c7;hp=de21b932e3c501657b48b23539a8fef1c41cc0f2;hpb=8f64d4820cbe92d90eedcdb4714ffcfa95f96f24;p=flightgear.git diff --git a/src/Main/renderer.hxx b/src/Main/renderer.hxx index de21b932e..5fd8e9b36 100644 --- a/src/Main/renderer.hxx +++ b/src/Main/renderer.hxx @@ -2,25 +2,38 @@ #ifndef __FG_RENDERER_HXX #define __FG_RENDERER_HXX 1 -#include -#include #include -#include -#include +#include -#include "FGManipulator.hxx" +namespace osg +{ +class Camera; +class Group; +} -#define FG_ENABLE_MULTIPASS_CLOUDS 1 +namespace osgGA +{ +class GUIEventAdapter; +} -class SGSky; -extern SGSky *thesky; +namespace osgShadow +{ +class ShadowedScene; +} + +namespace osgViewer +{ +class Viewer; +} -extern glPointParameterfProc glPointParameterfPtr; -extern glPointParameterfvProc glPointParameterfvPtr; -extern bool glPointParameterIsSupported; -extern bool glPointSpriteIsSupported; +namespace flightgear +{ +class FGEventHandler; +} +class SGSky; +extern SGSky *thesky; class FGRenderer { @@ -40,36 +53,21 @@ public: static void update( bool refresh_camera_settings ); inline static void update() { update( true ); } - - /** FlightGear code should use this routine to set the FOV rather - * than calling the ssg routine directly - */ - static void setFOV( float w, float h ); - - - /** FlightGear code should use this routine to set the Near/Far - * clip planes rather than calling the ssg routine directly - */ - static void setNearFar( float n, float f ); - /** Just pick into the scene and return the pick callbacks on the way ... */ - static bool pick( unsigned x, unsigned y, - std::vector& pickList, + static bool pick( std::vector& pickList, const osgGA::GUIEventAdapter* ea ); /** Get and set the OSG Viewer object, if any. */ osgViewer::Viewer* getViewer() { return viewer.get(); } const osgViewer::Viewer* getViewer() const { return viewer.get(); } - void setViewer(osgViewer::Viewer* viewer) { this->viewer = viewer; } + void setViewer(osgViewer::Viewer* viewer); /** Get and set the manipulator object, if any. */ - FGManipulator* getManipulator() { return manipulator.get(); } - const FGManipulator* getManipulator() const { return manipulator.get(); } - void setManipulator(FGManipulator* manipulator) { - this->manipulator = manipulator; - } + flightgear::FGEventHandler* getEventHandler() { return eventHandler.get(); } + const flightgear::FGEventHandler* getEventHandler() const { return eventHandler.get(); } + void setEventHandler(flightgear::FGEventHandler* manipulator); /** Add a top level camera. */ @@ -77,7 +75,7 @@ public: protected: osg::ref_ptr viewer; - osg::ref_ptr manipulator; + osg::ref_ptr eventHandler; }; bool fgDumpSceneGraphToFile(const char* filename);