X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frenderer.h;h=3d561b4fd8f0daea3cc69afa0fc0d1c7b8be86f1;hb=9885c5465db78b6a1d9cc8bf7ffa7a79fb116afc;hp=dd9464127d025ee0ae4ba9612084f91617f8ad67;hpb=d41ec7dfaa635bbaea9e902d5f5c60bd4a887891;p=libs%2Fgl.git diff --git a/source/renderer.h b/source/renderer.h index dd946412..3d561b4f 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; @@ -69,6 +70,8 @@ private: const Material *material; const Lighting *lighting; Matrix lighting_matrix; + const Clipping *clipping; + Matrix clipping_matrix; const Program *shprog; unsigned shdata_count; const Mesh *mesh; @@ -95,7 +98,8 @@ private: MODERN_MATRIX = 2, MATRIX = LEGACY_MATRIX|MODERN_MATRIX, LIGHTING = 4, - SHADER_DATA = 8 + CLIPPING = 8, + SHADER_DATA = 16 }; MtxStack mtx_stack; @@ -107,15 +111,29 @@ private: State *state; ProgramData standard_shdata; std::vector shdata_stack; - const Buffer *element_buffer; std::set excluded; public: Renderer(const Camera *); ~Renderer(); + /** 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(). */ + void begin(const Camera *); + + /** Deprecated as unsafe. Use set_matrix() or transform() instead. */ 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 mtx_stack.top(); } + const Camera *get_camera() const { return camera; } void set_texture(const Texture *); @@ -124,6 +142,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. */ @@ -135,7 +154,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); @@ -151,8 +169,9 @@ public: Renderer. DEPRECATED. */ void escape(); - /** Ends rendering, unbinding all objects and resetting state. There must - be no unpopped state in the stack. */ + /** 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. */ void end(); void exclude(const Renderable &); @@ -163,6 +182,7 @@ public: private: void apply_state(); + void reset_state(); }; } // namespace GL