X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fmesh.h;h=b23510e10b14485e8b9c531aee28f8a171d7bea3;hb=5bc9c7214feaf4ea4797fc0d4a906e5e59b75839;hp=b4ba0c45151534fab16a0023b05c00cce636d5da;hpb=22f0f95981f17524587f5f2c5e3e91005240ddb7;p=libs%2Fgl.git diff --git a/source/mesh.h b/source/mesh.h index b4ba0c45..b23510e1 100644 --- a/source/mesh.h +++ b/source/mesh.h @@ -52,13 +52,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 +77,7 @@ public: void clear(); private: - void create_buffers(); + void check_buffers(unsigned); public: const VertexArray &get_vertices() const { return vertices; } @@ -88,7 +93,11 @@ public: void draw(Renderer &) const; 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; } virtual Resource::AsyncLoader *load(IO::Seekable &, const Resources * = 0); virtual UInt64 get_data_size() const;