2020-01-03 20:05:16 +01:00
|
|
|
// Copyright (C) 2008-2012 Nikolaus Gebhardt
|
|
|
|
// This file is part of the "Irrlicht Engine".
|
|
|
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
|
|
|
|
|
|
|
#ifndef __C_VERTEX_BUFFER_H_INCLUDED__
|
|
|
|
#define __C_VERTEX_BUFFER_H_INCLUDED__
|
|
|
|
|
|
|
|
#include "IVertexBuffer.h"
|
|
|
|
|
|
|
|
|
|
|
|
namespace irr
|
|
|
|
{
|
|
|
|
namespace scene
|
|
|
|
{
|
|
|
|
|
|
|
|
class CVertexBuffer : public IVertexBuffer
|
|
|
|
{
|
|
|
|
class IVertexList
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual ~IVertexList(){};
|
|
|
|
|
|
|
|
virtual u32 stride() const =0;
|
|
|
|
|
|
|
|
virtual u32 size() const =0;
|
|
|
|
|
|
|
|
virtual void push_back (const video::S3DVertex &element) =0;
|
|
|
|
virtual video::S3DVertex& operator [](const u32 index) const =0;
|
|
|
|
virtual video::S3DVertex& getLast() =0;
|
|
|
|
virtual void set_used(u32 usedNow) =0;
|
|
|
|
virtual void reallocate(u32 new_size) =0;
|
|
|
|
virtual u32 allocated_size() const =0;
|
|
|
|
virtual video::S3DVertex* pointer() =0;
|
|
|
|
virtual video::E_VERTEX_TYPE getType() const =0;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
class CSpecificVertexList : public IVertexList
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
core::array<T> Vertices;
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
u32 stride() const override {return sizeof(T);}
|
2020-01-03 20:05:16 +01:00
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
u32 size() const override {return Vertices.size();}
|
2020-01-03 20:05:16 +01:00
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
void push_back (const video::S3DVertex &element) override
|
2020-01-03 20:05:16 +01:00
|
|
|
{Vertices.push_back((T&)element);}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
video::S3DVertex& operator [](const u32 index) const override
|
2020-01-03 20:05:16 +01:00
|
|
|
{return (video::S3DVertex&)Vertices[index];}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
video::S3DVertex& getLast() override
|
2020-01-03 20:05:16 +01:00
|
|
|
{return (video::S3DVertex&)Vertices.getLast();}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
void set_used(u32 usedNow) override
|
2020-01-03 20:05:16 +01:00
|
|
|
{Vertices.set_used(usedNow);}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
void reallocate(u32 new_size) override
|
2020-01-03 20:05:16 +01:00
|
|
|
{Vertices.reallocate(new_size);}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
u32 allocated_size() const override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
return Vertices.allocated_size();
|
|
|
|
}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
video::S3DVertex* pointer() override {return Vertices.pointer();}
|
2020-01-03 20:05:16 +01:00
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
video::E_VERTEX_TYPE getType() const override {return T::getType();}
|
2020-01-03 20:05:16 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
public:
|
|
|
|
IVertexList *Vertices;
|
|
|
|
|
|
|
|
CVertexBuffer(video::E_VERTEX_TYPE vertexType) : Vertices(0),
|
|
|
|
MappingHint(EHM_NEVER), ChangedID(1)
|
|
|
|
{
|
2023-01-20 00:26:20 +01:00
|
|
|
CVertexBuffer::setType(vertexType);
|
2020-01-03 20:05:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
CVertexBuffer(const IVertexBuffer &VertexBufferCopy) :
|
|
|
|
Vertices(0), MappingHint(EHM_NEVER),
|
|
|
|
ChangedID(1)
|
|
|
|
{
|
2023-01-20 00:26:20 +01:00
|
|
|
CVertexBuffer::setType(VertexBufferCopy.getType());
|
|
|
|
CVertexBuffer::reallocate(VertexBufferCopy.size());
|
2020-01-03 20:05:16 +01:00
|
|
|
|
|
|
|
for (u32 n=0;n<VertexBufferCopy.size();++n)
|
2023-01-20 00:26:20 +01:00
|
|
|
CVertexBuffer::push_back(VertexBufferCopy[n]);
|
2020-01-03 20:05:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
virtual ~CVertexBuffer()
|
|
|
|
{
|
|
|
|
delete Vertices;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
void setType(video::E_VERTEX_TYPE vertexType) override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
2022-04-19 14:21:44 +02:00
|
|
|
if ( Vertices && Vertices->getType() == vertexType )
|
|
|
|
return;
|
|
|
|
|
2020-01-03 20:05:16 +01:00
|
|
|
IVertexList *NewVertices=0;
|
|
|
|
|
|
|
|
switch (vertexType)
|
|
|
|
{
|
|
|
|
case video::EVT_STANDARD:
|
|
|
|
{
|
|
|
|
NewVertices=new CSpecificVertexList<video::S3DVertex>;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case video::EVT_2TCOORDS:
|
|
|
|
{
|
|
|
|
NewVertices=new CSpecificVertexList<video::S3DVertex2TCoords>;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case video::EVT_TANGENTS:
|
|
|
|
{
|
|
|
|
NewVertices=new CSpecificVertexList<video::S3DVertexTangents>;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (Vertices)
|
|
|
|
{
|
|
|
|
NewVertices->reallocate( Vertices->size() );
|
|
|
|
|
|
|
|
for(u32 n=0;n<Vertices->size();++n)
|
|
|
|
NewVertices->push_back((*Vertices)[n]);
|
|
|
|
|
|
|
|
delete Vertices;
|
|
|
|
}
|
|
|
|
|
|
|
|
Vertices=NewVertices;
|
|
|
|
}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
void* getData() override {return Vertices->pointer();}
|
2020-01-03 20:05:16 +01:00
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
video::E_VERTEX_TYPE getType() const override {return Vertices->getType();}
|
2020-01-03 20:05:16 +01:00
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
u32 stride() const override {return Vertices->stride();}
|
2020-01-03 20:05:16 +01:00
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
u32 size() const override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
return Vertices->size();
|
|
|
|
}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
void push_back (const video::S3DVertex &element) override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
Vertices->push_back(element);
|
|
|
|
}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
video::S3DVertex& operator [](const u32 index) const override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
return (*Vertices)[index];
|
|
|
|
}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
video::S3DVertex& getLast() override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
return Vertices->getLast();
|
|
|
|
}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
void set_used(u32 usedNow) override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
Vertices->set_used(usedNow);
|
|
|
|
}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
void reallocate(u32 new_size) override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
Vertices->reallocate(new_size);
|
|
|
|
}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
u32 allocated_size() const override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
return Vertices->allocated_size();
|
|
|
|
}
|
|
|
|
|
2022-10-09 20:57:28 +02:00
|
|
|
video::S3DVertex* pointer() override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
return Vertices->pointer();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! get the current hardware mapping hint
|
2022-10-09 20:57:28 +02:00
|
|
|
E_HARDWARE_MAPPING getHardwareMappingHint() const override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
return MappingHint;
|
|
|
|
}
|
|
|
|
|
|
|
|
//! set the hardware mapping hint, for driver
|
2022-10-09 20:57:28 +02:00
|
|
|
void setHardwareMappingHint( E_HARDWARE_MAPPING NewMappingHint ) override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
MappingHint=NewMappingHint;
|
|
|
|
}
|
|
|
|
|
|
|
|
//! flags the mesh as changed, reloads hardware buffers
|
2022-10-09 20:57:28 +02:00
|
|
|
void setDirty() override
|
2020-01-03 20:05:16 +01:00
|
|
|
{
|
|
|
|
++ChangedID;
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Get the currently used ID for identification of changes.
|
|
|
|
/** This shouldn't be used for anything outside the VideoDriver. */
|
2022-10-09 20:57:28 +02:00
|
|
|
u32 getChangedID() const override {return ChangedID;}
|
2020-01-03 20:05:16 +01:00
|
|
|
|
|
|
|
E_HARDWARE_MAPPING MappingHint;
|
|
|
|
u32 ChangedID;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // end namespace scene
|
|
|
|
} // end namespace irr
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|