X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fmesh.h;h=57c87b7e42986ac31f94092612c373159b633a7a;hb=344dd6a52b55d847f3346e94ec266a8864764b9d;hp=1ee58a6227ea52427f93113bf9e631582f076467;hpb=b0059bd068c99dadfc922584911fcb25a21b737b;p=libs%2Fgl.git diff --git a/source/mesh.h b/source/mesh.h index 1ee58a62..57c87b7e 100644 --- a/source/mesh.h +++ b/source/mesh.h @@ -5,6 +5,7 @@ #include "batch.h" #include "resource.h" #include "vertexarray.h" +#include "vertexsetup.h" #include "windingtest.h" namespace Msp { @@ -12,22 +13,24 @@ namespace GL { class Buffer; class Renderer; -class VertexSetup; /** 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: public Bindable, public Resource +class Mesh: public Resource { friend class MeshBuilder; public: class Loader: public DataFile::ObjectLoader { + private: + bool allow_gl_calls; + public: - Loader(Mesh &); + Loader(Mesh &, bool = true); private: void vertices(const std::vector &); void batch(PrimitiveType); @@ -52,13 +55,18 @@ private: virtual bool process(); }; + enum BufferMask + { + VERTEX_BUFFER = 1, + INDEX_BUFFER = 2 + }; + VertexArray vertices; std::vector batches; Buffer *vbuf; Buffer *ibuf; - VertexSetup *vtx_setup; - bool defer_buffers; - mutable bool dirty; + VertexSetup vtx_setup; + mutable unsigned short dirty; bool disallow_rendering; const WindingTest *winding; @@ -71,13 +79,12 @@ public: ~Mesh(); void clear(); - void use_buffers(bool); private: - void create_buffers(); + void check_buffers(unsigned); public: const VertexArray &get_vertices() const { return vertices; } - const VertexSetup *get_vertex_setup() const { return vtx_setup; } + const VertexSetup &get_vertex_setup() const { return vtx_setup; } const Buffer *get_index_buffer() const { return ibuf; } unsigned get_n_vertices() const; float *modify_vertex(unsigned); @@ -87,16 +94,13 @@ public: void set_winding(const WindingTest *); - void draw() const; void draw(Renderer &) const; void draw_instanced(Renderer &, const VertexSetup &, unsigned) const; +private: + void draw(Renderer &, const VertexSetup *, unsigned) const; + void resize_buffers() const; - /** Binds the mesh for rendering. The vertex array is applied using generic - attributes only. Uses vertex array object if possible. */ - void bind() const; - - static void unbind(); - +public: virtual int get_load_priority() const { return 1; } virtual Resource::AsyncLoader *load(IO::Seekable &, const Resources * = 0); virtual UInt64 get_data_size() const;