]> git.tdb.fi Git - libs/gl.git/blobdiff - source/mesh.h
Move vertex buffer management from VertexArray to Mesh
[libs/gl.git] / source / mesh.h
index 1abbefd39746270d6892d83b2fff3f840e22c6de..6181d5fb9bc1b9126248d2e786f826a77c7c92bd 100644 (file)
@@ -1,16 +1,10 @@
-/* $Id$
-
-This file is part of libmspgl
-Copyright © 2007-2011  Mikko Rasa, Mikkosoft Productions
-Distributed under the LGPL
-*/
-
 #ifndef MSP_GL_MESH_H_
 #define MSP_GL_MESH_H_
 
 #include <msp/datafile/objectloader.h>
 #include "batch.h"
 #include "vertexarray.h"
+#include "windingtest.h"
 
 namespace Msp {
 namespace GL {
@@ -18,6 +12,11 @@ namespace GL {
 class Buffer;
 class Renderer;
 
+/**
+Raw mesh data, consisting of a VertexArray and one or more Batches.  Though a
+Mesh can draw itself, it's usually used as part of Renderables rather than on
+its own.
+*/
 class Mesh
 {
        friend class MeshBuilder;
@@ -28,15 +27,18 @@ public:
        public:
                Loader(Mesh &);
        private:
-               void vertices(VertexFormat);
+               void vertices(const std::vector<VertexComponent> &);
                void batch(PrimitiveType);
+               void winding(FaceWinding);
        };
 
 private:
        VertexArray vertices;
        std::list<Batch> batches;
+       Buffer *vbuf;
        Buffer *ibuf;
-       bool defer_ibuf;
+       bool defer_buffers;
+       const WindingTest *winding;
 
 public:
        Mesh();
@@ -45,7 +47,10 @@ public:
 
        void clear();
        void use_buffers(bool);
+private:
+       void create_buffers();
 
+public:
        const VertexArray &get_vertices() const { return vertices; }
        unsigned get_n_vertices() const;
        float *modify_vertex(unsigned);
@@ -53,6 +58,8 @@ public:
        void add_batch(const Batch &b);
        const std::list<Batch> &get_batches() { return batches; }
 
+       void set_winding(const WindingTest *);
+
        void draw() const;
        void draw(Renderer &) const;
 };