X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frenderer.h;h=157282a5398f6a18a23f0f80684a9765a16e7a3e;hb=f632bf388a58b036e265f3789c797beff5ab063a;hp=1f198dae7007b00db30d4c699f0832ce06d0cca1;hpb=5df9e64424dd157da1410b4498f53a4ac21e6aee;p=libs%2Fgl.git diff --git a/source/renderer.h b/source/renderer.h index 1f198dae..157282a5 100644 --- a/source/renderer.h +++ b/source/renderer.h @@ -13,6 +13,7 @@ namespace GL { class Batch; class Buffer; class Camera; +class Clipping; class Material; class Mesh; class Lighting; @@ -63,12 +64,15 @@ public: private: struct State { + Matrix modelview_matrix; const Texture *texture; const Texturing *texturing; unsigned lowest_effect_texunit; const Material *material; const Lighting *lighting; Matrix lighting_matrix; + const Clipping *clipping; + Matrix clipping_matrix; const Program *shprog; unsigned shdata_count; const Mesh *mesh; @@ -78,27 +82,18 @@ 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, - SHADER_DATA = 8 + LEGACY_LIGHTING = 4, + LEGACY_CLIPPING = 8, + SHADER_DATA = 16, + MATERIAL_SHDATA = 32, + STANDARD_SHDATA = 64 }; - MtxStack mtx_stack; unsigned char changed; bool matrices_loaded; unsigned shdata_applied; @@ -107,7 +102,6 @@ private: State *state; ProgramData standard_shdata; std::vector shdata_stack; - const Buffer *element_buffer; std::set excluded; public: @@ -119,7 +113,14 @@ public: times without an intervening end(). */ void begin(const Camera *); - MatrixStack &matrix_stack() { return mtx_stack; } + /** Replaces the Renderer's modelview matrix. */ + void set_matrix(const Matrix &); + + /** Applies a transform to the Renderer's modelview matrix. */ + void transform(const Matrix &); + + /** Returns the current modelview matrix. */ + const Matrix &get_matrix() const { return state->modelview_matrix; } const Camera *get_camera() const { return camera; } @@ -129,6 +130,7 @@ public: void set_material(const Material *); void set_lighting(const Lighting *); + void set_clipping(const Clipping *); /** Sets the shader program to use. An initial set of data can be set as well, with the same semantics as add_shader_data. */ @@ -140,7 +142,6 @@ public: void add_shader_data(const ProgramData &data); void set_mesh(const Mesh *); - void set_element_buffer(const Buffer *); void set_winding_test(const WindingTest *); void set_reverse_winding(bool);