X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frender%2Frenderer.cpp;h=5262d09a90ee2862e6c0db07dcd02e71044241fd;hb=99ca354f18119f82f1adeca100cd665a8f640317;hp=6c8f1b67b29c0deb30161db2acfb19f6cffb2b79;hpb=b95aa29809038b39e6729f4e53af0dfb545bfcdc;p=libs%2Fgl.git diff --git a/source/render/renderer.cpp b/source/render/renderer.cpp index 6c8f1b67..5262d09a 100644 --- a/source/render/renderer.cpp +++ b/source/render/renderer.cpp @@ -27,21 +27,19 @@ Renderer::Renderer() texture_stack.reserve(32); } -Renderer::~Renderer() -{ -} - void Renderer::begin() { if(current_state) throw invalid_operation("Renderer::begin"); - state_stack.push_back(State()); + ++frame_index; + state_stack.emplace_back(); current_state = &state_stack.back(); RendererBackend::begin(); add_shader_data(standard_shdata); + commands.begin_frame(frame_index); } void Renderer::end() @@ -167,7 +165,7 @@ void Renderer::set_texture(Tag tag, const Texture *tex, const Sampler *samp) break; } - texture_stack.push_back(BoundTexture()); + texture_stack.emplace_back(); BoundTexture &bound_tex = texture_stack.back(); bound_tex.tag = tag; bound_tex.texture = tex; @@ -244,6 +242,7 @@ void Renderer::draw(const Batch &batch) { apply_state(); batch.refresh(); + pipeline_state.set_primitive_type(batch.get_type()); commands.use_pipeline(&pipeline_state); commands.draw(batch); } @@ -252,6 +251,7 @@ void Renderer::draw_instanced(const Batch &batch, unsigned count) { apply_state(); batch.refresh(); + pipeline_state.set_primitive_type(batch.get_type()); commands.use_pipeline(&pipeline_state); commands.draw_instanced(batch, count); }