X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;ds=sidebyside;f=source%2Fmesh.h;h=57c87b7e42986ac31f94092612c373159b633a7a;hb=bec07999d95b76f4b47cffcc564d0cd0afc0435e;hp=9e086e8770502778167702a3bebaa6cc935f6148;hpb=f5469600171c951438fb62df6427bf968adda28c;p=libs%2Fgl.git diff --git a/source/mesh.h b/source/mesh.h index 9e086e87..57c87b7e 100644 --- a/source/mesh.h +++ b/source/mesh.h @@ -26,8 +26,11 @@ class Mesh: public Resource 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; + mutable unsigned short dirty; bool disallow_rendering; const WindingTest *winding; @@ -72,7 +80,7 @@ public: void clear(); private: - void create_buffers(); + void check_buffers(unsigned); public: const VertexArray &get_vertices() const { return vertices; } @@ -90,6 +98,7 @@ public: void draw_instanced(Renderer &, const VertexSetup &, unsigned) const; private: void draw(Renderer &, const VertexSetup *, unsigned) const; + void resize_buffers() const; public: virtual int get_load_priority() const { return 1; }