X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Fmesh.cpp;h=b5535039b44109a2f31ca8cd9c57105001966b64;hb=9be04243c92f024327e74ad8d48861581d83b7ed;hp=4b247e8d4f759aa6f68287590207076ff0dbf5cc;hpb=a1c39449fccf03ec08787bf51d62bf3b4cb60f69;p=libs%2Fgl.git diff --git a/source/mesh.cpp b/source/mesh.cpp index 4b247e8d..b5535039 100644 --- a/source/mesh.cpp +++ b/source/mesh.cpp @@ -116,18 +116,7 @@ void Mesh::set_winding(const WindingTest *w) void Mesh::draw(Renderer &renderer) const { - if(manager) - { - manager->resource_used(*this); - if(disallow_rendering) - return; - } - - renderer.set_mesh(this); - renderer.set_winding_test(winding); - - for(vector::const_iterator i=batches.begin(); i!=batches.end(); ++i) - renderer.draw(*i); + draw(renderer, 0, 0); } void Mesh::draw_instanced(Renderer &renderer, const VertexSetup &vs, unsigned count) const @@ -135,6 +124,11 @@ void Mesh::draw_instanced(Renderer &renderer, const VertexSetup &vs, unsigned co if(vs.get_vertex_array()!=&vertices) throw invalid_argument("Mesh::draw_instanced"); + draw(renderer, &vs, count); +} + +void Mesh::draw(Renderer &renderer, const VertexSetup *vs, unsigned count) const +{ if(manager) { manager->resource_used(*this); @@ -142,26 +136,19 @@ void Mesh::draw_instanced(Renderer &renderer, const VertexSetup &vs, unsigned co return; } - renderer.set_vertex_setup(&vs); + renderer.set_vertex_setup(vs ? vs : &vtx_setup); renderer.set_winding_test(winding); - for(vector::const_iterator i=batches.begin(); i!=batches.end(); ++i) - renderer.draw_instanced(*i, count); -} - -void Mesh::bind() const -{ - if(set_current(this)) + if(!count) { - vtx_setup.bind(); - vertices.refresh(); + for(vector::const_iterator i=batches.begin(); i!=batches.end(); ++i) + renderer.draw(*i); + } + else + { + for(vector::const_iterator i=batches.begin(); i!=batches.end(); ++i) + renderer.draw_instanced(*i, count); } -} - -void Mesh::unbind() -{ - if(set_current(0)) - VertexSetup::unbind(); } Resource::AsyncLoader *Mesh::load(IO::Seekable &io, const Resources *)