X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fmesh.cpp;h=c6543f01cee322bbaa465ea492b2cd15e800bb66;hb=ed7ca8892daceebb963950945fed5e75bd96a8a1;hp=e901536535cd04716d973594200700cb8829807a;hpb=e65e7dabfc1d3b2c87345df75fc942fb1fe47581;p=libs%2Fgl.git diff --git a/source/mesh.cpp b/source/mesh.cpp index e9015365..c6543f01 100644 --- a/source/mesh.cpp +++ b/source/mesh.cpp @@ -114,27 +114,6 @@ void Mesh::set_winding(const WindingTest *w) winding = w; } -void Mesh::draw() const -{ - const Mesh *cur = current(); - if(cur && cur!=this) - throw invalid_operation("Mesh::draw"); - - if(manager) - { - manager->resource_used(*this); - if(disallow_rendering) - return; - } - - BindRestore bind_vtxs(vtx_setup); - BindRestore bind_ibuf(ibuf, ELEMENT_ARRAY_BUFFER); - Bind bind_winding(winding); - - for(vector::const_iterator i=batches.begin(); i!=batches.end(); ++i) - i->draw(); -} - void Mesh::draw(Renderer &renderer) const { if(manager) @@ -144,7 +123,7 @@ void Mesh::draw(Renderer &renderer) const return; } - renderer.set_mesh(this); + renderer.set_vertex_setup(&vtx_setup); renderer.set_winding_test(winding); for(vector::const_iterator i=batches.begin(); i!=batches.end(); ++i) @@ -170,21 +149,6 @@ void Mesh::draw_instanced(Renderer &renderer, const VertexSetup &vs, unsigned co renderer.draw_instanced(*i, count); } -void Mesh::bind() const -{ - if(set_current(this)) - { - vtx_setup.bind(); - vertices.refresh(); - } -} - -void Mesh::unbind() -{ - if(set_current(0)) - VertexSetup::unbind(); -} - Resource::AsyncLoader *Mesh::load(IO::Seekable &io, const Resources *) { return new AsyncLoader(*this, io);