X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frender%2Frenderer.h;h=575dbe67ee8af1e9adf758c3be0c7ca0caea3045;hb=175153f224916b92d02a325aac5628956cda8daf;hp=0371e8374a6a9207faf913f13c16f653cf75fac1;hpb=3930e89d1dab90a27542c3798782216499b3ab44;p=libs%2Fgl.git diff --git a/source/render/renderer.h b/source/render/renderer.h index 0371e837..575dbe67 100644 --- a/source/render/renderer.h +++ b/source/render/renderer.h @@ -100,7 +100,7 @@ private: unsigned char changed = 0; std::vector state_stack; - State *state; + State *current_state = 0; ProgramData standard_shdata; std::vector shdata_stack; std::vector texture_stack; @@ -111,10 +111,11 @@ public: Renderer(); ~Renderer(); + /** Begins rendering, allowing commands to be issued. */ + void begin(); - /** Unbinds all objects and resets related state. There must be no unpopped - state in the stack. The Renderer remains valid and may be reused for - further rendering. */ + /** Ends rendering. Any global state is reset to defaults. No further + commands are allowed before the next call to begin(). */ void end(); /** Saves the current state so it can be restored later. */ @@ -124,25 +125,26 @@ public: push_state call. */ void pop_state(); +private: + State &get_state() const; + +public: /** Sets the camera to render from. The model matrix is reset to identity. */ void set_camera(const Camera &); - const Camera *get_camera() const { return state->camera; } + const Camera *get_camera() const { return get_state().camera; } /** Replaces the Renderer's model matrix. */ void set_matrix(const Matrix &); - /** Applies a transform to the Renderer's model matrix. */ - void transform(const Matrix &); - /** Returns the current model matrix. */ - const Matrix &get_matrix() const { return state->model_matrix; } + const Matrix &get_matrix() const { return get_state().model_matrix; } void set_framebuffer(const Framebuffer *); void set_viewport(const Rect *); void set_scissor(const Rect *); - const Framebuffer *get_framebuffer() const { return state->framebuffer; } + const Framebuffer *get_framebuffer() const { return get_state().framebuffer; } /** Sets the shader program to use. As a convenience, uniform values may be specified at the same time. */ @@ -169,7 +171,7 @@ public: void set_blend(const Blend *); void set_object_lod_bias(unsigned); - unsigned get_object_lod_bias() const { return state->object_lod_bias; } + unsigned get_object_lod_bias() const { return get_state().object_lod_bias; } void clear(const ClearValue *);