- more vertex buffer stuff for models, still not tested.

This commit is contained in:
Christoph Oelckers 2014-06-19 22:24:33 +02:00
parent 5944894138
commit ca76c2525e
3 changed files with 82 additions and 25 deletions

View file

@ -30,7 +30,7 @@ public:
virtual bool Load(const char * fn, int lumpnum, const char * buffer, int length) = 0; virtual bool Load(const char * fn, int lumpnum, const char * buffer, int length) = 0;
virtual int FindFrame(const char * name) = 0; virtual int FindFrame(const char * name) = 0;
virtual void RenderFrame(FTexture * skin, int frame, int frame2, double inter, int translation=0) = 0; virtual void RenderFrame(FTexture * skin, int frame, int frame2, double inter, int translation=0) = 0;
virtual void BuildVertexBuffer(FModelVertexBuffer *buf); virtual void BuildVertexBuffer(FModelVertexBuffer *buf) = 0;
@ -193,11 +193,15 @@ class FMD3Model : public FModel
MD3TexCoord * texcoords; MD3TexCoord * texcoords;
MD3Vertex * vertices; MD3Vertex * vertices;
unsigned int vindex; // contains numframes arrays of vertices
unsigned int iindex;
MD3Surface() MD3Surface()
{ {
tris=NULL; tris=NULL;
vertices=NULL; vertices=NULL;
texcoords=NULL; texcoords=NULL;
vindex = iindex = UINT_MAX;
} }
~MD3Surface() ~MD3Surface()
@ -233,20 +237,13 @@ public:
virtual bool Load(const char * fn, int lumpnum, const char * buffer, int length); virtual bool Load(const char * fn, int lumpnum, const char * buffer, int length);
virtual int FindFrame(const char * name); virtual int FindFrame(const char * name);
virtual void RenderFrame(FTexture * skin, int frame, int frame2, double inter, int translation=0); virtual void RenderFrame(FTexture * skin, int frame, int frame2, double inter, int translation=0);
}; virtual void BuildVertexBuffer(FModelVertexBuffer *buf);
class FVoxelVertexBuffer;
struct FVoxelVertex
{
float x,y,z;
float u,v;
}; };
struct FVoxelVertexHash struct FVoxelVertexHash
{ {
// Returns the hash value for a key. // Returns the hash value for a key.
hash_t Hash(const FVoxelVertex &key) hash_t Hash(const FModelVertex &key)
{ {
int ix = xs_RoundToInt(key.x); int ix = xs_RoundToInt(key.x);
int iy = xs_RoundToInt(key.y); int iy = xs_RoundToInt(key.y);
@ -255,7 +252,7 @@ struct FVoxelVertexHash
} }
// Compares two keys, returning zero if they are the same. // Compares two keys, returning zero if they are the same.
int Compare(const FVoxelVertex &left, const FVoxelVertex &right) int Compare(const FModelVertex &left, const FModelVertex &right)
{ {
return left.x != right.x || left.y != right.y || left.z != right.z || left.u != right.u || left.v != right.v; return left.x != right.x || left.y != right.y || left.z != right.z || left.u != right.u || left.v != right.v;
} }
@ -269,7 +266,7 @@ struct FIndexInit
} }
}; };
typedef TMap<FVoxelVertex, unsigned int, FVoxelVertexHash, FIndexInit> FVoxelMap; typedef TMap<FModelVertex, unsigned int, FVoxelVertexHash, FIndexInit> FVoxelMap;
class FVoxelModel : public FModel class FVoxelModel : public FModel
@ -277,13 +274,15 @@ class FVoxelModel : public FModel
protected: protected:
FVoxel *mVoxel; FVoxel *mVoxel;
bool mOwningVoxel; // if created through MODELDEF deleting this object must also delete the voxel object bool mOwningVoxel; // if created through MODELDEF deleting this object must also delete the voxel object
TArray<FVoxelVertex> mVertices; TArray<FModelVertex> mVertices;
TArray<unsigned int> mIndices; TArray<unsigned int> mIndices;
FTexture *mPalette; FTexture *mPalette;
unsigned int vindex;
unsigned int iindex;
void MakeSlabPolys(int x, int y, kvxslab_t *voxptr, FVoxelMap &check); void MakeSlabPolys(int x, int y, kvxslab_t *voxptr, FVoxelMap &check);
void AddFace(int x1, int y1, int z1, int x2, int y2, int z2, int x3, int y3, int z3, int x4, int y4, int z4, BYTE color, FVoxelMap &check); void AddFace(int x1, int y1, int z1, int x2, int y2, int z2, int x3, int y3, int z3, int x4, int y4, int z4, BYTE color, FVoxelMap &check);
void AddVertex(FVoxelVertex &vert, FVoxelMap &check); unsigned int AddVertex(FModelVertex &vert, FVoxelMap &check);
public: public:
FVoxelModel(FVoxel *voxel, bool owned); FVoxelModel(FVoxel *voxel, bool owned);
@ -293,6 +292,7 @@ public:
virtual int FindFrame(const char * name); virtual int FindFrame(const char * name);
virtual void RenderFrame(FTexture * skin, int frame, int frame2, double inter, int translation=0); virtual void RenderFrame(FTexture * skin, int frame, int frame2, double inter, int translation=0);
FTexture *GetPaletteTexture() const { return mPalette; } FTexture *GetPaletteTexture() const { return mPalette; }
void BuildVertexBuffer(FModelVertexBuffer *buf);
}; };

View file

@ -206,6 +206,37 @@ bool FMD3Model::Load(const char * path, int, const char * buffer, int length)
return true; return true;
} }
void FMD3Model::BuildVertexBuffer(FModelVertexBuffer *buf)
{
for (int i = 0; i < numSurfaces; i++)
{
MD3Surface * surf = &surfaces[i];
surf->vindex = buf->vbo_shadowdata.Size();
surf->iindex = buf->ibo_shadowdata.Size();
for (int j = 0; j < numFrames * surf->numVertices; j++)
{
MD3Vertex* vert = surf->vertices + j;
FModelVertex bvert;
int tc = j % surf->numVertices;
bvert.Set(vert->x, vert->z, vert->y, surf->texcoords[tc].s, surf->texcoords[tc].t);
bvert.SetNormal(vert->nx, vert->nz, vert->ny);
buf->vbo_shadowdata.Push(bvert);
}
for (int k = 0; k < surf->numTriangles; k++)
{
for (int l = 0; l < 3; l++)
{
buf->ibo_shadowdata.Push(surf->tris[k].VertIndex[l]);
}
}
}
}
int FMD3Model::FindFrame(const char * name) int FMD3Model::FindFrame(const char * name)
{ {
for (int i=0;i<numFrames;i++) for (int i=0;i<numFrames;i++)

View file

@ -215,6 +215,7 @@ FVoxelModel::FVoxelModel(FVoxel *voxel, bool owned)
mOwningVoxel = owned; mOwningVoxel = owned;
mPalette = new FVoxelTexture(voxel); mPalette = new FVoxelTexture(voxel);
Initialize(); Initialize();
iindex = vindex = UINT_MAX;
} }
//=========================================================================== //===========================================================================
@ -229,20 +230,39 @@ FVoxelModel::~FVoxelModel()
if (mOwningVoxel) delete mVoxel; if (mOwningVoxel) delete mVoxel;
} }
//=========================================================================== //===========================================================================
// //
// //
// //
//=========================================================================== //===========================================================================
void FVoxelModel::AddVertex(FVoxelVertex &vert, FVoxelMap &check) void FVoxelModel::BuildVertexBuffer(FModelVertexBuffer *buf)
{
vindex = buf->vbo_shadowdata.Size();
iindex = buf->ibo_shadowdata.Size();
FModelVertex *mv = &buf->vbo_shadowdata[buf->vbo_shadowdata.Reserve(mVertices.Size())];
unsigned int *mi = &buf->ibo_shadowdata[buf->ibo_shadowdata.Reserve(mIndices.Size())];
memcpy(mv, &mVertices[0], sizeof(FModelVertex)* mVertices.Size());
memcpy(mi, &mIndices[0], sizeof(unsigned int)* mIndices.Size());
}
//===========================================================================
//
//
//
//===========================================================================
unsigned int FVoxelModel::AddVertex(FModelVertex &vert, FVoxelMap &check)
{ {
unsigned int index = check[vert]; unsigned int index = check[vert];
if (index == 0xffffffff) if (index == 0xffffffff)
{ {
index = check[vert] =mVertices.Push(vert); index = check[vert] =mVertices.Push(vert);
} }
mIndices.Push(index); return index;
} }
//=========================================================================== //===========================================================================
@ -257,8 +277,8 @@ void FVoxelModel::AddFace(int x1, int y1, int z1, int x2, int y2, int z2, int x3
float PivotY = mVoxel->Mips[0].PivotY / 256.f; float PivotY = mVoxel->Mips[0].PivotY / 256.f;
float PivotZ = mVoxel->Mips[0].PivotZ / 256.f; float PivotZ = mVoxel->Mips[0].PivotZ / 256.f;
int h = mVoxel->Mips[0].SizeZ; int h = mVoxel->Mips[0].SizeZ;
FVoxelVertex vert; FModelVertex vert;
unsigned int indx[4];
vert.u = (((col & 15) * 255 / 16) + 7) / 255.f; vert.u = (((col & 15) * 255 / 16) + 7) / 255.f;
vert.v = (((col / 16) * 255 / 16) + 7) / 255.f; vert.v = (((col / 16) * 255 / 16) + 7) / 255.f;
@ -266,23 +286,29 @@ void FVoxelModel::AddFace(int x1, int y1, int z1, int x2, int y2, int z2, int x3
vert.x = x1 - PivotX; vert.x = x1 - PivotX;
vert.z = -y1 + PivotY; vert.z = -y1 + PivotY;
vert.y = -z1 + PivotZ; vert.y = -z1 + PivotZ;
AddVertex(vert, check); indx[0] = AddVertex(vert, check);
vert.x = x2 - PivotX; vert.x = x2 - PivotX;
vert.z = -y2 + PivotY; vert.z = -y2 + PivotY;
vert.y = -z2 + PivotZ; vert.y = -z2 + PivotZ;
AddVertex(vert, check); indx[1] = AddVertex(vert, check);
vert.x = x4 - PivotX; vert.x = x4 - PivotX;
vert.z = -y4 + PivotY; vert.z = -y4 + PivotY;
vert.y = -z4 + PivotZ; vert.y = -z4 + PivotZ;
AddVertex(vert, check); indx[2] = AddVertex(vert, check);
vert.x = x3 - PivotX; vert.x = x3 - PivotX;
vert.z = -y3 + PivotY; vert.z = -y3 + PivotY;
vert.y = -z3 + PivotZ; vert.y = -z3 + PivotZ;
AddVertex(vert, check); indx[3] = AddVertex(vert, check);
mIndices.Push(indx[0]);
mIndices.Push(indx[1]);
mIndices.Push(indx[2]);
mIndices.Push(indx[1]);
mIndices.Push(indx[3]);
mIndices.Push(indx[2]);
} }
//=========================================================================== //===========================================================================
@ -384,7 +410,7 @@ int FVoxelModel::FindFrame(const char * name)
//=========================================================================== //===========================================================================
// //
// Voxels never interpolate between frames // Voxels never interpolate between frames, they only have one.
// //
//=========================================================================== //===========================================================================
@ -394,10 +420,10 @@ void FVoxelModel::RenderFrame(FTexture * skin, int frame, int frame2, double int
tex->Bind(0, translation); tex->Bind(0, translation);
gl_RenderState.Apply(); gl_RenderState.Apply();
glBegin(GL_QUADS); glBegin(GL_TRIANGLES);
for (unsigned i = 0; i < mIndices.Size(); i++) for (unsigned i = 0; i < mIndices.Size(); i++)
{ {
FVoxelVertex *vert = &mVertices[mIndices[i]]; FModelVertex *vert = &mVertices[mIndices[i]];
glTexCoord2fv(&vert->u); glTexCoord2fv(&vert->u);
glVertex3fv(&vert->x); glVertex3fv(&vert->x);
} }