2019-12-12 17:32:41 +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
|
|
|
|
|
2021-08-27 17:03:34 +02:00
|
|
|
#ifndef IRR_I_DYNAMIC_MESH_BUFFER_H_INCLUDED
|
|
|
|
#define IRR_I_DYNAMIC_MESH_BUFFER_H_INCLUDED
|
2019-12-12 17:32:41 +01:00
|
|
|
|
|
|
|
#include "IMeshBuffer.h"
|
|
|
|
#include "IVertexBuffer.h"
|
|
|
|
#include "IIndexBuffer.h"
|
|
|
|
|
|
|
|
namespace irr
|
|
|
|
{
|
|
|
|
namespace scene
|
|
|
|
{
|
|
|
|
|
|
|
|
/** a dynamic meshBuffer */
|
|
|
|
class IDynamicMeshBuffer : public IMeshBuffer
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual IVertexBuffer &getVertexBuffer() const =0;
|
|
|
|
virtual IIndexBuffer &getIndexBuffer() const =0;
|
|
|
|
|
|
|
|
virtual void setVertexBuffer(IVertexBuffer *vertexBuffer) =0;
|
|
|
|
virtual void setIndexBuffer(IIndexBuffer *indexBuffer) =0;
|
|
|
|
|
|
|
|
//! Get the material of this meshbuffer
|
|
|
|
/** \return Material of this buffer. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual video::SMaterial& getMaterial() IRR_OVERRIDE =0;
|
2019-12-12 17:32:41 +01:00
|
|
|
|
|
|
|
//! Get the material of this meshbuffer
|
|
|
|
/** \return Material of this buffer. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual const video::SMaterial& getMaterial() const IRR_OVERRIDE =0;
|
2019-12-12 17:32:41 +01:00
|
|
|
|
|
|
|
//! Get the axis aligned bounding box of this meshbuffer.
|
|
|
|
/** \return Axis aligned bounding box of this buffer. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual const core::aabbox3df& getBoundingBox() const IRR_OVERRIDE =0;
|
2019-12-12 17:32:41 +01:00
|
|
|
|
|
|
|
//! Set axis aligned bounding box
|
|
|
|
/** \param box User defined axis aligned bounding box to use
|
|
|
|
for this buffer. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual void setBoundingBox(const core::aabbox3df& box) IRR_OVERRIDE =0;
|
2019-12-12 17:32:41 +01:00
|
|
|
|
|
|
|
//! Recalculates the bounding box. Should be called if the mesh changed.
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual void recalculateBoundingBox() IRR_OVERRIDE =0;
|
2019-12-12 17:32:41 +01:00
|
|
|
|
|
|
|
//! Append the vertices and indices to the current buffer
|
|
|
|
/** Only works for compatible vertex types.
|
|
|
|
\param vertices Pointer to a vertex array.
|
|
|
|
\param numVertices Number of vertices in the array.
|
|
|
|
\param indices Pointer to index array.
|
|
|
|
\param numIndices Number of indices in array. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual void append(const void* const vertices, u32 numVertices, const u16* const indices, u32 numIndices) IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Append the meshbuffer to the current buffer
|
|
|
|
/** Only works for compatible vertex types
|
|
|
|
\param other Buffer to append to this one. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual void append(const IMeshBuffer* const other) IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------- To be removed? ------------------- //
|
|
|
|
|
|
|
|
//! get the current hardware mapping hint
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual E_HARDWARE_MAPPING getHardwareMappingHint_Vertex() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer().getHardwareMappingHint();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! get the current hardware mapping hint
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual E_HARDWARE_MAPPING getHardwareMappingHint_Index() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getIndexBuffer().getHardwareMappingHint();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! set the hardware mapping hint, for driver
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual void setHardwareMappingHint( E_HARDWARE_MAPPING NewMappingHint, E_BUFFER_TYPE Buffer=EBT_VERTEX_AND_INDEX ) IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
if (Buffer==EBT_VERTEX_AND_INDEX || Buffer==EBT_VERTEX)
|
|
|
|
getVertexBuffer().setHardwareMappingHint(NewMappingHint);
|
|
|
|
if (Buffer==EBT_VERTEX_AND_INDEX || Buffer==EBT_INDEX)
|
|
|
|
getIndexBuffer().setHardwareMappingHint(NewMappingHint);
|
|
|
|
}
|
|
|
|
|
|
|
|
//! flags the mesh as changed, reloads hardware buffers
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual void setDirty(E_BUFFER_TYPE Buffer=EBT_VERTEX_AND_INDEX) IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
if (Buffer==EBT_VERTEX_AND_INDEX || Buffer==EBT_VERTEX)
|
|
|
|
getVertexBuffer().setDirty();
|
|
|
|
if (Buffer==EBT_VERTEX_AND_INDEX || Buffer==EBT_INDEX)
|
|
|
|
getIndexBuffer().setDirty();
|
|
|
|
}
|
|
|
|
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual u32 getChangedID_Vertex() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer().getChangedID();
|
|
|
|
}
|
|
|
|
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual u32 getChangedID_Index() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getIndexBuffer().getChangedID();
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------- Old interface ------------------- //
|
|
|
|
|
|
|
|
//! Get type of vertex data which is stored in this meshbuffer.
|
|
|
|
/** \return Vertex type of this buffer. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual video::E_VERTEX_TYPE getVertexType() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer().getType();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Get access to vertex data. The data is an array of vertices.
|
|
|
|
/** Which vertex type is used can be determined by getVertexType().
|
|
|
|
\return Pointer to array of vertices. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual const void* getVertices() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer().getData();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Get access to vertex data. The data is an array of vertices.
|
|
|
|
/** Which vertex type is used can be determined by getVertexType().
|
|
|
|
\return Pointer to array of vertices. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual void* getVertices() IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer().getData();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Get amount of vertices in meshbuffer.
|
|
|
|
/** \return Number of vertices in this buffer. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual u32 getVertexCount() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer().size();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Get type of index data which is stored in this meshbuffer.
|
|
|
|
/** \return Index type of this buffer. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual video::E_INDEX_TYPE getIndexType() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getIndexBuffer().getType();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Get access to indices.
|
|
|
|
/** \return Pointer to indices array. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual const u16* getIndices() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return (u16*)getIndexBuffer().getData();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Get access to indices.
|
|
|
|
/** \return Pointer to indices array. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual u16* getIndices() IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return (u16*)getIndexBuffer().getData();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! Get amount of indices in this meshbuffer.
|
|
|
|
/** \return Number of indices in this buffer. */
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual u32 getIndexCount() const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getIndexBuffer().size();
|
|
|
|
}
|
|
|
|
|
|
|
|
//! returns position of vertex i
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual const core::vector3df& getPosition(u32 i) const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer()[i].Pos;
|
|
|
|
}
|
|
|
|
|
|
|
|
//! returns position of vertex i
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual core::vector3df& getPosition(u32 i) IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer()[i].Pos;
|
|
|
|
}
|
|
|
|
|
|
|
|
//! returns texture coords of vertex i
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual const core::vector2df& getTCoords(u32 i) const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer()[i].TCoords;
|
|
|
|
}
|
|
|
|
|
|
|
|
//! returns texture coords of vertex i
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual core::vector2df& getTCoords(u32 i) IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer()[i].TCoords;
|
|
|
|
}
|
|
|
|
|
|
|
|
//! returns normal of vertex i
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual const core::vector3df& getNormal(u32 i) const IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer()[i].Normal;
|
|
|
|
}
|
|
|
|
|
|
|
|
//! returns normal of vertex i
|
2021-08-27 14:55:10 +02:00
|
|
|
virtual core::vector3df& getNormal(u32 i) IRR_OVERRIDE
|
2019-12-12 17:32:41 +01:00
|
|
|
{
|
|
|
|
return getVertexBuffer()[i].Normal;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // end namespace scene
|
|
|
|
} // end namespace irr
|
|
|
|
|
|
|
|
#endif
|