1
// Copyright (C) 2008-2011 Nikolaus Gebhardt
2
// This file is part of the "Irrlicht Engine".
3
// For conditions of distribution and use, see copyright notice in irrlicht.h
5
#ifndef __C_VERTEX_BUFFER_H_INCLUDED__
6
#define __C_VERTEX_BUFFER_H_INCLUDED__
8
#include "IVertexBuffer.h"
16
class CVertexBuffer : public IVertexBuffer
21
virtual ~IVertexList(){};
23
virtual u32 stride() const =0;
25
virtual u32 size() const =0;
27
virtual void push_back (const video::S3DVertex &element) =0;
28
virtual video::S3DVertex& operator [](const u32 index) const =0;
29
virtual video::S3DVertex& getLast() =0;
30
virtual void set_used(u32 usedNow) =0;
31
virtual void reallocate(u32 new_size) =0;
32
virtual u32 allocated_size() const =0;
33
virtual video::S3DVertex* pointer() =0;
34
virtual video::E_VERTEX_TYPE getType() const =0;
38
class CSpecificVertexList : public IVertexList
41
core::array<T> Vertices;
43
virtual u32 stride() const {return sizeof(T);}
45
virtual u32 size() const {return Vertices.size();}
47
virtual void push_back (const video::S3DVertex &element)
48
{Vertices.push_back((T&)element);}
50
virtual video::S3DVertex& operator [](const u32 index) const
51
{return (video::S3DVertex&)Vertices[index];}
53
virtual video::S3DVertex& getLast()
54
{return (video::S3DVertex&)Vertices.getLast();}
56
virtual void set_used(u32 usedNow)
57
{Vertices.set_used(usedNow);}
59
virtual void reallocate(u32 new_size)
60
{Vertices.reallocate(new_size);}
62
virtual u32 allocated_size() const
64
return Vertices.allocated_size();
67
virtual video::S3DVertex* pointer() {return Vertices.pointer();}
69
virtual video::E_VERTEX_TYPE getType() const {return T().getType();}
73
IVertexList *Vertices;
75
CVertexBuffer(video::E_VERTEX_TYPE vertexType) : Vertices(0),
76
MappingHint(EHM_NEVER), ChangedID(1)
81
CVertexBuffer(const IVertexBuffer &VertexBufferCopy) :
82
Vertices(0), MappingHint(EHM_NEVER),
85
setType(VertexBufferCopy.getType());
86
reallocate(VertexBufferCopy.size());
88
for (u32 n=0;n<VertexBufferCopy.size();++n)
89
push_back(VertexBufferCopy[n]);
92
virtual ~CVertexBuffer()
98
virtual void setType(video::E_VERTEX_TYPE vertexType)
100
IVertexList *NewVertices=0;
104
case video::EVT_STANDARD:
106
NewVertices=new CSpecificVertexList<video::S3DVertex>;
109
case video::EVT_2TCOORDS:
111
NewVertices=new CSpecificVertexList<video::S3DVertex2TCoords>;
114
case video::EVT_TANGENTS:
116
NewVertices=new CSpecificVertexList<video::S3DVertexTangents>;
122
NewVertices->reallocate( Vertices->size() );
124
for(u32 n=0;n<Vertices->size();++n)
125
NewVertices->push_back((*Vertices)[n]);
130
Vertices=NewVertices;
133
virtual void* getData() {return Vertices->pointer();}
135
virtual video::E_VERTEX_TYPE getType() const {return Vertices->getType();}
137
virtual u32 stride() const {return Vertices->stride();}
139
virtual u32 size() const
141
return Vertices->size();
144
virtual void push_back (const video::S3DVertex &element)
146
Vertices->push_back(element);
149
virtual video::S3DVertex& operator [](const u32 index) const
151
return (*Vertices)[index];
154
virtual video::S3DVertex& getLast()
156
return Vertices->getLast();
159
virtual void set_used(u32 usedNow)
161
Vertices->set_used(usedNow);
164
virtual void reallocate(u32 new_size)
166
Vertices->reallocate(new_size);
169
virtual u32 allocated_size() const
171
return Vertices->allocated_size();
174
virtual video::S3DVertex* pointer()
176
return Vertices->pointer();
179
//! get the current hardware mapping hint
180
virtual E_HARDWARE_MAPPING getHardwareMappingHint() const
185
//! set the hardware mapping hint, for driver
186
virtual void setHardwareMappingHint( E_HARDWARE_MAPPING NewMappingHint )
188
MappingHint=NewMappingHint;
191
//! flags the mesh as changed, reloads hardware buffers
192
virtual void setDirty()
197
//! Get the currently used ID for identification of changes.
198
/** This shouldn't be used for anything outside the VideoDriver. */
199
virtual u32 getChangedID() const {return ChangedID;}
201
E_HARDWARE_MAPPING MappingHint;
206
} // end namespace scene
207
} // end namespace irr