X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Frenderer.h;h=af4bd65b594beb85c53bf76905e47698fb577f07;hp=a4c5ef03ca93ad316bb7af61723ac103456c657c;hb=42c1534d95e1551c37e64a1dae288e8b75e8d8ba;hpb=b781d8d1d713e28ec21a66a9d78eb3fc01f327e5 diff --git a/source/renderer.h b/source/renderer.h index a4c5ef03..af4bd65b 100644 --- a/source/renderer.h +++ b/source/renderer.h @@ -64,6 +64,8 @@ public: private: struct State { + const Camera *camera; + Matrix modelview_matrix; const Texture *texture; const Texturing *texturing; unsigned lowest_effect_texunit; @@ -81,34 +83,21 @@ private: State(); }; - class MtxStack: public MatrixStack - { - private: - Renderer &renderer; - - public: - MtxStack(Renderer &); - private: - virtual void update(); - }; - enum ChangeMask { LEGACY_MATRIX = 1, MODERN_MATRIX = 2, MATRIX = LEGACY_MATRIX|MODERN_MATRIX, - LIGHTING = 4, - CLIPPING = 8, + LEGACY_LIGHTING = 4, + LEGACY_CLIPPING = 8, SHADER_DATA = 16, MATERIAL_SHDATA = 32, - STANDARD_SHDATA = 64 + STANDARD_SHDATA = 64, + LEGACY_PROJECTION = 128 }; - MtxStack mtx_stack; unsigned char changed; bool matrices_loaded; - unsigned shdata_applied; - const Camera *camera; std::vector state_stack; State *state; ProgramData standard_shdata; @@ -121,11 +110,16 @@ public: /** Resets all internal state and restarts rendering. There must be no unpopped state in the stack. It is permissible to call begin() multiple - times without an intervening end(). */ + times without an intervening end(). + + Deprecated; use end() and set_camera() instead.*/ void begin(const Camera *); - /** Deprecated as unsafe. Use set_matrix() or transform() instead. */ - MatrixStack &matrix_stack() { return mtx_stack; } + /** Sets the camera to render from. The modelview matrix is reset to the + camera's view matrix. */ + void set_camera(const Camera &); + + const Camera *get_camera() const { return state->camera; } /** Replaces the Renderer's modelview matrix. */ void set_matrix(const Matrix &); @@ -134,9 +128,7 @@ public: void transform(const Matrix &); /** Returns the current modelview matrix. */ - const Matrix &get_matrix() const { return mtx_stack.top(); } - - const Camera *get_camera() const { return camera; } + const Matrix &get_matrix() const { return state->modelview_matrix; } void set_texture(const Texture *); void set_texturing(const Texturing *); @@ -166,14 +158,9 @@ public: push_state call. */ void pop_state(); - /** Prepares for temporarily bypassing the Renderer by synchronizing the - current state with GL. No additional call is necessary to resume using the - Renderer. DEPRECATED. */ - void escape(); - /** Unbinds all objects and resets related state. There must be no unpopped - state in the stack. Rendering with the same camera can be restarted without - an explicit begin() call. */ + state in the stack. The Renderer remains valid and may be reused for + further rendering. */ void end(); void exclude(const Renderable &); @@ -184,7 +171,6 @@ public: private: void apply_state(); - void reset_state(); }; } // namespace GL