X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fmesh.cpp;h=67f9698cfa36468d5fb6955f49b5ce5774b95e0f;hp=05be2c3745b8562b32f9c9b5a69e722fb4af5058;hb=635d00bc1a9ba43ef1224681a14d0710a098cf87;hpb=0e8ffd3b59e9b5c52c66c22c9ae4f9d3544aa6bf diff --git a/source/mesh.cpp b/source/mesh.cpp index 05be2c37..67f9698c 100644 --- a/source/mesh.cpp +++ b/source/mesh.cpp @@ -18,13 +18,15 @@ namespace GL { Mesh::Mesh(): vertices(VERTEX3), ibuf(0), - defer_ibuf(true) + defer_ibuf(true), + winding(0) { } Mesh::Mesh(const VertexFormat &f): vertices(f), ibuf(0), - defer_ibuf(true) + defer_ibuf(true), + winding(0) { } Mesh::~Mesh() @@ -94,12 +96,18 @@ void Mesh::add_batch(const Batch &b) } } +void Mesh::set_winding(const WindingTest *w) +{ + winding = w; +} + void Mesh::draw() const { vertices.apply(); if(ibuf) ibuf->bind_to(ELEMENT_ARRAY_BUFFER); + Bind bind_winding(winding); for(list::const_iterator i=batches.begin(); i!=batches.end(); ++i) i->draw(); @@ -112,6 +120,7 @@ void Mesh::draw(Renderer &renderer) const { renderer.set_vertex_array(&vertices); renderer.set_element_buffer(ibuf); + renderer.set_winding_test(winding); for(list::const_iterator i=batches.begin(); i!=batches.end(); ++i) renderer.draw(*i); @@ -121,8 +130,9 @@ void Mesh::draw(Renderer &renderer) const Mesh::Loader::Loader(Mesh &m): DataFile::ObjectLoader(m) { - add("vertices", &Loader::vertices); add("batch", &Loader::batch); + add("vertices", &Loader::vertices); + add("winding", &Loader::winding); } void Mesh::Loader::vertices(VertexFormat f) @@ -138,5 +148,13 @@ void Mesh::Loader::batch(PrimitiveType p) obj.add_batch(btc); } +void Mesh::Loader::winding(FaceWinding w) +{ + if(w==CLOCKWISE) + obj.winding = &WindingTest::clockwise(); + else if(w==COUNTERCLOCKWISE) + obj.winding = &WindingTest::counterclockwise(); +} + } // namespace GL } // namespace Msp