X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frender%2Frenderer.h;h=51989f7711f8b84bd8a43a1eb8d872cb2a3cf7d2;hb=50492d9a5106b3dd76e3d6fa5ac88d9f97ba3c47;hp=ffaa917dd4f5b8dd772ba5ce008c7f9d1fc372f7;hpb=99ca354f18119f82f1adeca100cd665a8f640317;p=libs%2Fgl.git diff --git a/source/render/renderer.h b/source/render/renderer.h index ffaa917d..51989f77 100644 --- a/source/render/renderer.h +++ b/source/render/renderer.h @@ -4,6 +4,7 @@ #include #include #include "commands.h" +#include "cullface.h" #include "matrix.h" #include "programdata.h" #include "renderer_backend.h" @@ -13,16 +14,20 @@ namespace Msp { namespace GL { class Batch; +class Blend; class Buffer; class Camera; union ClearValue; +class DepthTest; class Material; class Mesh; class Lighting; class Program; class QueryPool; +struct Rect; class Renderable; class Sampler; +class StencilTest; class Texture; class VertexSetup; @@ -64,6 +69,7 @@ private: mutable int binding = -1; const Texture *texture = 0; const Sampler *sampler = 0; + int level = -1; int replaced = -1; }; @@ -107,6 +113,7 @@ private: ProgramData standard_shdata; std::vector shdata_stack; std::vector texture_stack; + const Texture &placeholder_texture; Commands commands; public: @@ -160,6 +167,7 @@ public: void add_shader_data(const ProgramData &data); void set_texture(Tag, const Texture *, const Sampler * = 0); + void set_texture(Tag, const Texture *, int, const Sampler * = 0); private: void flush_shader_data(); @@ -177,7 +185,10 @@ public: void set_object_lod_bias(unsigned); unsigned get_object_lod_bias() const { return get_state().object_lod_bias; } - void clear(const ClearValue *); + /** Clears framebuffer contents. If values is not null, it must contain one + element for each attachment. Otherwise the framebuffer contents are + discarded and become undefined. */ + void clear(const ClearValue *values); /** Draws a batch of primitives. A shader must be active. */ void draw(const Batch &); @@ -193,6 +204,7 @@ public: void end_query(const QueryPool &, unsigned); private: + void apply_framebuffer(); void apply_state(); };