X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FMain%2Frenderer.hxx;h=5fd8e9b36f652fdb91735920215e276017602ca3;hb=c053de6b4c4c3a9b22648d3c7e798cfd087887c7;hp=7cfbfd354c57f2d0494d9f67a1c0270b77199120;hpb=cdb725528ddc7338281c3818c831adc11b571800;p=flightgear.git diff --git a/src/Main/renderer.hxx b/src/Main/renderer.hxx index 7cfbfd354..5fd8e9b36 100644 --- a/src/Main/renderer.hxx +++ b/src/Main/renderer.hxx @@ -2,19 +2,38 @@ #ifndef __FG_RENDERER_HXX #define __FG_RENDERER_HXX 1 -#include -#include +#include -#define FG_ENABLE_MULTIPASS_CLOUDS 1 +#include -class SGSky; -extern SGSky *thesky; +namespace osg +{ +class Camera; +class Group; +} + +namespace osgGA +{ +class GUIEventAdapter; +} + +namespace osgShadow +{ +class ShadowedScene; +} -extern glPointParameterfProc glPointParameterfPtr; -extern glPointParameterfvProc glPointParameterfvPtr; -extern bool glPointParameterIsSupported; -extern bool glPointSpriteIsSupported; +namespace osgViewer +{ +class Viewer; +} +namespace flightgear +{ +class FGEventHandler; +} + +class SGSky; +extern SGSky *thesky; class FGRenderer { @@ -23,9 +42,9 @@ public: FGRenderer(); ~FGRenderer(); + void splashinit(); void init(); - void build_states(); static void resize(int width, int height ); // calling update( refresh_camera_settings = false ) will not @@ -34,23 +53,32 @@ 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 + /** Just pick into the scene and return the pick callbacks on the way ... */ - static void setFOV( float w, float h ); - + static bool pick( std::vector& pickList, + const osgGA::GUIEventAdapter* ea ); - /** FlightGear code should use this routine to set the Near/Far - * clip planes rather than calling the ssg routine directly + /** Get and set the OSG Viewer object, if any. */ - static void setNearFar( float n, float f ); - - /** Get the pick start point and direction in global coordinates. - * The inputs are expected to be the x and y coordinates of the - * screen point relative to the window. + osgViewer::Viewer* getViewer() { return viewer.get(); } + const osgViewer::Viewer* getViewer() const { return viewer.get(); } + void setViewer(osgViewer::Viewer* viewer); + /** Get and set the manipulator object, if any. */ - static bool getPickInfo( SGVec3d& p, SGVec3d& d, unsigned x, unsigned y ); + flightgear::FGEventHandler* getEventHandler() { return eventHandler.get(); } + const flightgear::FGEventHandler* getEventHandler() const { return eventHandler.get(); } + void setEventHandler(flightgear::FGEventHandler* manipulator); + + /** Add a top level camera. + */ + void addCamera(osg::Camera* camera, bool useSceneData); + +protected: + osg::ref_ptr viewer; + osg::ref_ptr eventHandler; }; +bool fgDumpSceneGraphToFile(const char* filename); +bool fgDumpTerrainBranchToFile(const char* filename); + #endif