X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbatch.h;h=6fb013af68e8de626757392a2e4644d9c734d2d8;hb=a2a00bdc96a7d2aa4c95c5a125c0c438147d7495;hp=92a10e6b4923a4d82678794e3ce7653766b9ca7f;hpb=d58a3bd12fb8c6331bb9208aa68f8c082be48863;p=libs%2Fgl.git diff --git a/source/batch.h b/source/batch.h index 92a10e6b..6fb013af 100644 --- a/source/batch.h +++ b/source/batch.h @@ -33,8 +33,8 @@ public: private: PrimitiveType prim_type; - DataType data_type; - std::vector data; + DataType index_type; + std::vector data; unsigned min_index; unsigned max_index; bool restart; @@ -46,16 +46,21 @@ public: ~Batch(); PrimitiveType get_type() const { return prim_type; } - void set_data_type(DataType); - DataType get_data_type() const { return data_type; } + void set_index_type(DataType); + DataType get_index_type() const { return index_type; } + + DEPRECATED void set_data_type(DataType t) { set_index_type(t); } + DEPRECATED DataType get_data_type() const { return index_type; } Batch &append(unsigned); - void append(const std::vector &); - void append(const Batch &); + Batch &append(const std::vector &); + bool can_append(PrimitiveType); + Batch &append(const Batch &); private: void append_index(unsigned); virtual unsigned get_data_size() const { return data.size(); } - virtual void upload_data() const; + virtual const void *get_data_pointer() const { return &data[0]; } + virtual unsigned get_alignment() const { return get_index_size(); } unsigned get_index_size() const; public: unsigned size() const { return data.size()/get_index_size(); } @@ -63,6 +68,10 @@ public: unsigned get_index(unsigned) const; void draw() const; + void draw_instanced(unsigned) const; +private: + const void *setup_draw() const; + static void set_restart_index(unsigned); }; } // namespace GL