mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-21 00:41:20 +00:00
Support for 'tinyframes', and lots more optimization
This commit is contained in:
parent
295ca25171
commit
9f0b121b15
5 changed files with 183 additions and 136 deletions
|
@ -58,7 +58,7 @@ EXPORT void HWRAPI(ClearMipMapCache) (void);
|
||||||
EXPORT void HWRAPI(SetSpecialState) (hwdspecialstate_t IdState, INT32 Value);
|
EXPORT void HWRAPI(SetSpecialState) (hwdspecialstate_t IdState, INT32 Value);
|
||||||
|
|
||||||
//Hurdler: added for new development
|
//Hurdler: added for new development
|
||||||
EXPORT void HWRAPI(DrawModel) (model_t *model, mdlframe_t *frame, INT32 duration, INT32 tics, mdlframe_t *nextframe, FTransform *pos, float scale, UINT8 flipped, UINT8 *color);
|
EXPORT void HWRAPI(DrawModel) (model_t *model, INT32 frameIndex, INT32 duration, INT32 tics, INT32 nextFrameIndex, FTransform *pos, float scale, UINT8 flipped, UINT8 *color);
|
||||||
EXPORT void HWRAPI(SetTransform) (FTransform *ptransform);
|
EXPORT void HWRAPI(SetTransform) (FTransform *ptransform);
|
||||||
EXPORT INT32 HWRAPI(GetTextureUsed) (void);
|
EXPORT INT32 HWRAPI(GetTextureUsed) (void);
|
||||||
EXPORT INT32 HWRAPI(GetRenderVersion) (void);
|
EXPORT INT32 HWRAPI(GetRenderVersion) (void);
|
||||||
|
|
|
@ -832,7 +832,8 @@ void HWR_DrawMD2(gr_vissprite_t *spr)
|
||||||
FSurfaceInfo Surf;
|
FSurfaceInfo Surf;
|
||||||
|
|
||||||
char filename[64];
|
char filename[64];
|
||||||
INT32 frame;
|
INT32 frame = 0;
|
||||||
|
INT32 nextFrame = -1;
|
||||||
FTransform p;
|
FTransform p;
|
||||||
md2_t *md2;
|
md2_t *md2;
|
||||||
UINT8 color[4];
|
UINT8 color[4];
|
||||||
|
@ -1074,7 +1075,7 @@ void HWR_DrawMD2(gr_vissprite_t *spr)
|
||||||
p.flip = atransform.flip;
|
p.flip = atransform.flip;
|
||||||
p.mirror = atransform.mirror;
|
p.mirror = atransform.mirror;
|
||||||
|
|
||||||
HWD.pfnDrawModel(md2->model, curr, durs, tics, next, &p, finalscale, flip, color);
|
HWD.pfnDrawModel(md2->model, frame, durs, tics, nextFrame, &p, finalscale, flip, color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -233,8 +233,6 @@ typedef struct
|
||||||
// Load the model
|
// Load the model
|
||||||
model_t *MD2_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
model_t *MD2_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
||||||
{
|
{
|
||||||
useFloat = true; // Right now we always useFloat = true, because the GL subsystem needs some work for the other option to work.
|
|
||||||
|
|
||||||
model_t *retModel = NULL;
|
model_t *retModel = NULL;
|
||||||
md2header_t *header;
|
md2header_t *header;
|
||||||
|
|
||||||
|
@ -397,17 +395,17 @@ model_t *MD2_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
||||||
framePtr--;
|
framePtr--;
|
||||||
for (j = 0; j < header->numXYZ; j++, vertex++)
|
for (j = 0; j < header->numXYZ; j++, vertex++)
|
||||||
{
|
{
|
||||||
*vertptr = (short)(((vertex->v[1] * framePtr->scale[1]) + framePtr->translate[1]) / dataScale);
|
*vertptr = (short)(((vertex->v[0] * framePtr->scale[0]) + framePtr->translate[0]) / dataScale);
|
||||||
vertptr++;
|
vertptr++;
|
||||||
*vertptr = (short)(((vertex->v[2] * framePtr->scale[2]) + framePtr->translate[2]) / dataScale);
|
*vertptr = (short)(((vertex->v[2] * framePtr->scale[2]) + framePtr->translate[2]) / dataScale);
|
||||||
vertptr++;
|
vertptr++;
|
||||||
*vertptr = (short)(((vertex->v[0] * framePtr->scale[0]) + framePtr->translate[0]) / dataScale);
|
*vertptr = -1.0f * (short)(((vertex->v[1] * framePtr->scale[1]) + framePtr->translate[1]) / dataScale);
|
||||||
vertptr++;
|
vertptr++;
|
||||||
|
|
||||||
// Normal
|
// Normal
|
||||||
|
*normptr++ = (byte)(avertexnormals[vertex->lightNormalIndex][0] * 127);
|
||||||
*normptr++ = (byte)(avertexnormals[vertex->lightNormalIndex][1] * 127);
|
*normptr++ = (byte)(avertexnormals[vertex->lightNormalIndex][1] * 127);
|
||||||
*normptr++ = (byte)(avertexnormals[vertex->lightNormalIndex][2] * 127);
|
*normptr++ = (byte)(avertexnormals[vertex->lightNormalIndex][2] * 127);
|
||||||
*normptr++ = (byte)(avertexnormals[vertex->lightNormalIndex][0] * 127);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -419,17 +417,17 @@ model_t *MD2_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
||||||
{
|
{
|
||||||
*indexptr = trisPtr->meshIndex[0];
|
*indexptr = trisPtr->meshIndex[0];
|
||||||
indexptr++;
|
indexptr++;
|
||||||
*indexptr = trisPtr->meshIndex[2];
|
|
||||||
indexptr++;
|
|
||||||
*indexptr = trisPtr->meshIndex[1];
|
*indexptr = trisPtr->meshIndex[1];
|
||||||
indexptr++;
|
indexptr++;
|
||||||
|
*indexptr = trisPtr->meshIndex[2];
|
||||||
|
indexptr++;
|
||||||
|
|
||||||
|
uvptr[trisPtr->meshIndex[0] * 2] = texcoords[trisPtr->stIndex[0]].s / (float)header->skinwidth;
|
||||||
|
uvptr[trisPtr->meshIndex[0] * 2 + 1] = (texcoords[trisPtr->stIndex[0]].t / (float)header->skinheight);
|
||||||
uvptr[trisPtr->meshIndex[1] * 2] = texcoords[trisPtr->stIndex[1]].s / (float)header->skinwidth;
|
uvptr[trisPtr->meshIndex[1] * 2] = texcoords[trisPtr->stIndex[1]].s / (float)header->skinwidth;
|
||||||
uvptr[trisPtr->meshIndex[1] * 2 + 1] = (texcoords[trisPtr->stIndex[1]].t / (float)header->skinheight);
|
uvptr[trisPtr->meshIndex[1] * 2 + 1] = (texcoords[trisPtr->stIndex[1]].t / (float)header->skinheight);
|
||||||
uvptr[trisPtr->meshIndex[2] * 2] = texcoords[trisPtr->stIndex[2]].s / (float)header->skinwidth;
|
uvptr[trisPtr->meshIndex[2] * 2] = texcoords[trisPtr->stIndex[2]].s / (float)header->skinwidth;
|
||||||
uvptr[trisPtr->meshIndex[2] * 2 + 1] = (texcoords[trisPtr->stIndex[2]].t / (float)header->skinheight);
|
uvptr[trisPtr->meshIndex[2] * 2 + 1] = (texcoords[trisPtr->stIndex[2]].t / (float)header->skinheight);
|
||||||
uvptr[trisPtr->meshIndex[0] * 2] = texcoords[trisPtr->stIndex[0]].s / (float)header->skinwidth;
|
|
||||||
uvptr[trisPtr->meshIndex[0] * 2 + 1] = (texcoords[trisPtr->stIndex[0]].t / (float)header->skinheight);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else // Full float loading method
|
else // Full float loading method
|
||||||
|
|
|
@ -144,8 +144,6 @@ static bool latlnginit = false;
|
||||||
|
|
||||||
model_t *MD3_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
model_t *MD3_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
||||||
{
|
{
|
||||||
useFloat = true; // Right now we always useFloat = true, because the GL subsystem needs some work for the other option to work.
|
|
||||||
|
|
||||||
if (!latlnginit)
|
if (!latlnginit)
|
||||||
{
|
{
|
||||||
LatLngInit();
|
LatLngInit();
|
||||||
|
@ -307,20 +305,20 @@ model_t *MD3_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
||||||
for (k = 0; k < mdS->numVerts; k++)
|
for (k = 0; k < mdS->numVerts; k++)
|
||||||
{
|
{
|
||||||
// Vertex
|
// Vertex
|
||||||
*vertptr = mdV[k].y;
|
*vertptr = mdV[k].x;
|
||||||
vertptr++;
|
vertptr++;
|
||||||
*vertptr = mdV[k].z;
|
*vertptr = mdV[k].z;
|
||||||
vertptr++;
|
vertptr++;
|
||||||
*vertptr = mdV[k].x;
|
*vertptr = 1.0f - mdV[k].y;
|
||||||
vertptr++;
|
vertptr++;
|
||||||
|
|
||||||
// Normal
|
// Normal
|
||||||
GetNormalFromLatLong(mdV[k].n, tempNormal);
|
GetNormalFromLatLong(mdV[k].n, tempNormal);
|
||||||
*normptr = (byte)(tempNormal[1] * 127);
|
*normptr = (byte)(tempNormal[0] * 127);
|
||||||
normptr++;
|
normptr++;
|
||||||
*normptr = (byte)(tempNormal[2] * 127);
|
*normptr = (byte)(tempNormal[2] * 127);
|
||||||
normptr++;
|
normptr++;
|
||||||
*normptr = (byte)(tempNormal[0] * 127);
|
*normptr = (byte)(tempNormal[1] * 127);
|
||||||
normptr++;
|
normptr++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -331,7 +329,7 @@ model_t *MD3_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
||||||
{
|
{
|
||||||
*uvptr = mdST[j].st[0];
|
*uvptr = mdST[j].st[0];
|
||||||
uvptr++;
|
uvptr++;
|
||||||
*uvptr = 1.0f - mdST[j].st[1];
|
*uvptr = mdST[j].st[1];
|
||||||
uvptr++;
|
uvptr++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -342,10 +340,10 @@ model_t *MD3_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
||||||
// Indices
|
// Indices
|
||||||
*indexptr = (unsigned short)mdT->index[0];
|
*indexptr = (unsigned short)mdT->index[0];
|
||||||
indexptr++;
|
indexptr++;
|
||||||
*indexptr = (unsigned short)mdT->index[2];
|
|
||||||
indexptr++;
|
|
||||||
*indexptr = (unsigned short)mdT->index[1];
|
*indexptr = (unsigned short)mdT->index[1];
|
||||||
indexptr++;
|
indexptr++;
|
||||||
|
*indexptr = (unsigned short)mdT->index[2];
|
||||||
|
indexptr++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else // Traditional full-float loading method
|
else // Traditional full-float loading method
|
||||||
|
@ -377,48 +375,48 @@ model_t *MD3_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
||||||
vertptr++;
|
vertptr++;
|
||||||
*vertptr = mdV[mdT->index[0]].z * dataScale;
|
*vertptr = mdV[mdT->index[0]].z * dataScale;
|
||||||
vertptr++;
|
vertptr++;
|
||||||
*vertptr = mdV[mdT->index[0]].y * dataScale;
|
*vertptr = 1.0f - mdV[mdT->index[0]].y * dataScale;
|
||||||
vertptr++;
|
vertptr++;
|
||||||
|
|
||||||
GetNormalFromLatLong(mdV[mdT->index[0]].n, tempNormal);
|
GetNormalFromLatLong(mdV[mdT->index[0]].n, tempNormal);
|
||||||
*normptr = tempNormal[1];
|
*normptr = tempNormal[0];
|
||||||
normptr++;
|
normptr++;
|
||||||
*normptr = tempNormal[2];
|
*normptr = tempNormal[2];
|
||||||
normptr++;
|
normptr++;
|
||||||
*normptr = tempNormal[0];
|
*normptr = tempNormal[1];
|
||||||
normptr++;
|
normptr++;
|
||||||
|
|
||||||
// Vertex 2
|
// Vertex 2
|
||||||
*vertptr = mdV[mdT->index[2]].x * dataScale;
|
|
||||||
vertptr++;
|
|
||||||
*vertptr = mdV[mdT->index[2]].z * dataScale;
|
|
||||||
vertptr++;
|
|
||||||
*vertptr = mdV[mdT->index[2]].y * dataScale;
|
|
||||||
vertptr++;
|
|
||||||
|
|
||||||
GetNormalFromLatLong(mdV[mdT->index[2]].n, tempNormal);
|
|
||||||
*normptr = tempNormal[1];
|
|
||||||
normptr++;
|
|
||||||
*normptr = tempNormal[2];
|
|
||||||
normptr++;
|
|
||||||
*normptr = tempNormal[0];
|
|
||||||
normptr++;
|
|
||||||
|
|
||||||
// Vertex 3
|
|
||||||
*vertptr = mdV[mdT->index[1]].x * dataScale;
|
*vertptr = mdV[mdT->index[1]].x * dataScale;
|
||||||
vertptr++;
|
vertptr++;
|
||||||
*vertptr = mdV[mdT->index[1]].z * dataScale;
|
*vertptr = mdV[mdT->index[1]].z * dataScale;
|
||||||
vertptr++;
|
vertptr++;
|
||||||
*vertptr = mdV[mdT->index[1]].y * dataScale;
|
*vertptr = 1.0f - mdV[mdT->index[1]].y * dataScale;
|
||||||
vertptr++;
|
vertptr++;
|
||||||
|
|
||||||
GetNormalFromLatLong(mdV[mdT->index[1]].n, tempNormal);
|
GetNormalFromLatLong(mdV[mdT->index[1]].n, tempNormal);
|
||||||
*normptr = tempNormal[1];
|
*normptr = tempNormal[0];
|
||||||
normptr++;
|
normptr++;
|
||||||
*normptr = tempNormal[2];
|
*normptr = tempNormal[2];
|
||||||
normptr++;
|
normptr++;
|
||||||
|
*normptr = tempNormal[1];
|
||||||
|
normptr++;
|
||||||
|
|
||||||
|
// Vertex 3
|
||||||
|
*vertptr = mdV[mdT->index[2]].x * dataScale;
|
||||||
|
vertptr++;
|
||||||
|
*vertptr = mdV[mdT->index[2]].z * dataScale;
|
||||||
|
vertptr++;
|
||||||
|
*vertptr = 1.0f - mdV[mdT->index[2]].y * dataScale;
|
||||||
|
vertptr++;
|
||||||
|
|
||||||
|
GetNormalFromLatLong(mdV[mdT->index[2]].n, tempNormal);
|
||||||
*normptr = tempNormal[0];
|
*normptr = tempNormal[0];
|
||||||
normptr++;
|
normptr++;
|
||||||
|
*normptr = tempNormal[2];
|
||||||
|
normptr++;
|
||||||
|
*normptr = tempNormal[1];
|
||||||
|
normptr++;
|
||||||
|
|
||||||
mdT++; // Advance to next triangle
|
mdT++; // Advance to next triangle
|
||||||
}
|
}
|
||||||
|
@ -436,16 +434,16 @@ model_t *MD3_LoadModel(const char *fileName, int ztag, boolean useFloat)
|
||||||
*uvptr = mdST[mdT->index[0]].st[1];
|
*uvptr = mdST[mdT->index[0]].st[1];
|
||||||
uvptr++;
|
uvptr++;
|
||||||
|
|
||||||
*uvptr = mdST[mdT->index[2]].st[0];
|
|
||||||
uvptr++;
|
|
||||||
*uvptr = mdST[mdT->index[2]].st[1];
|
|
||||||
uvptr++;
|
|
||||||
|
|
||||||
*uvptr = mdST[mdT->index[1]].st[0];
|
*uvptr = mdST[mdT->index[1]].st[0];
|
||||||
uvptr++;
|
uvptr++;
|
||||||
*uvptr = mdST[mdT->index[1]].st[1];
|
*uvptr = mdST[mdT->index[1]].st[1];
|
||||||
uvptr++;
|
uvptr++;
|
||||||
|
|
||||||
|
*uvptr = mdST[mdT->index[2]].st[0];
|
||||||
|
uvptr++;
|
||||||
|
*uvptr = mdST[mdT->index[2]].st[1];
|
||||||
|
uvptr++;
|
||||||
|
|
||||||
mdT++; // Advance to next triangle
|
mdT++; // Advance to next triangle
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -241,14 +241,18 @@ FUNCPRINTF void DBG_Printf(const char *lpFmt, ...)
|
||||||
#define pglBegin glBegin
|
#define pglBegin glBegin
|
||||||
#define pglEnd glEnd
|
#define pglEnd glEnd
|
||||||
#define pglVertex3f glVertex3f
|
#define pglVertex3f glVertex3f
|
||||||
|
#define pglVertex3sv glVertex3sv
|
||||||
#define pglNormal3f glNormal3f
|
#define pglNormal3f glNormal3f
|
||||||
|
#define pglNormal3bv glNormal3bv
|
||||||
#define pglColor4f glColor4f
|
#define pglColor4f glColor4f
|
||||||
#define pglColor4fv glColor4fv
|
#define pglColor4fv glColor4fv
|
||||||
#define pglTexCoord2f glTexCoord2f
|
#define pglTexCoord2f glTexCoord2f
|
||||||
|
#define pglTexCoord2fv glTexCoord2fv
|
||||||
#define pglVertexPointer glVertexPointer
|
#define pglVertexPointer glVertexPointer
|
||||||
#define pglNormalPointer glNormalPointer
|
#define pglNormalPointer glNormalPointer
|
||||||
#define pglTexCoordPointer glTexCoordPointer
|
#define pglTexCoordPointer glTexCoordPointer
|
||||||
#define pglDrawArrays glDrawArrays
|
#define pglDrawArrays glDrawArrays
|
||||||
|
#define pglDrawElements glDrawElements
|
||||||
#define pglEnableClientState glEnableClientState
|
#define pglEnableClientState glEnableClientState
|
||||||
#define pglDisableClientState pglDisableClientState
|
#define pglDisableClientState pglDisableClientState
|
||||||
|
|
||||||
|
@ -355,14 +359,20 @@ typedef void (APIENTRY * PFNglEnd) (void);
|
||||||
static PFNglEnd pglEnd;
|
static PFNglEnd pglEnd;
|
||||||
typedef void (APIENTRY * PFNglVertex3f) (GLfloat x, GLfloat y, GLfloat z);
|
typedef void (APIENTRY * PFNglVertex3f) (GLfloat x, GLfloat y, GLfloat z);
|
||||||
static PFNglVertex3f pglVertex3f;
|
static PFNglVertex3f pglVertex3f;
|
||||||
|
typedef void (APIENTRY * PFNglVertex3sv) (const GLshort *v);
|
||||||
|
static PFNglVertex3sv pglVertex3sv;
|
||||||
typedef void (APIENTRY * PFNglNormal3f) (GLfloat x, GLfloat y, GLfloat z);
|
typedef void (APIENTRY * PFNglNormal3f) (GLfloat x, GLfloat y, GLfloat z);
|
||||||
static PFNglNormal3f pglNormal3f;
|
static PFNglNormal3f pglNormal3f;
|
||||||
|
typedef void (APIENTRY * PFNglNormal3bv)(const GLbyte *v);
|
||||||
|
static PFNglNormal3bv pglNormal3bv;
|
||||||
typedef void (APIENTRY * PFNglColor4f) (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha);
|
typedef void (APIENTRY * PFNglColor4f) (GLfloat red, GLfloat green, GLfloat blue, GLfloat alpha);
|
||||||
static PFNglColor4f pglColor4f;
|
static PFNglColor4f pglColor4f;
|
||||||
typedef void (APIENTRY * PFNglColor4fv) (const GLfloat *v);
|
typedef void (APIENTRY * PFNglColor4fv) (const GLfloat *v);
|
||||||
static PFNglColor4fv pglColor4fv;
|
static PFNglColor4fv pglColor4fv;
|
||||||
typedef void (APIENTRY * PFNglTexCoord2f) (GLfloat s, GLfloat t);
|
typedef void (APIENTRY * PFNglTexCoord2f) (GLfloat s, GLfloat t);
|
||||||
static PFNglTexCoord2f pglTexCoord2f;
|
static PFNglTexCoord2f pglTexCoord2f;
|
||||||
|
typedef void (APIENTRY * PFNglTexCoord2fv) (const GLfloat *v);
|
||||||
|
static PFNglTexCoord2fv pglTexCoord2fv;
|
||||||
typedef void (APIENTRY * PFNglVertexPointer) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer);
|
typedef void (APIENTRY * PFNglVertexPointer) (GLint size, GLenum type, GLsizei stride, const GLvoid *pointer);
|
||||||
static PFNglVertexPointer pglVertexPointer;
|
static PFNglVertexPointer pglVertexPointer;
|
||||||
typedef void (APIENTRY * PFNglNormalPointer) (GLenum type, GLsizei stride, const GLvoid *pointer);
|
typedef void (APIENTRY * PFNglNormalPointer) (GLenum type, GLsizei stride, const GLvoid *pointer);
|
||||||
|
@ -371,6 +381,8 @@ typedef void (APIENTRY * PFNglTexCoordPointer) (GLint size, GLenum type, GLsizei
|
||||||
static PFNglTexCoordPointer pglTexCoordPointer;
|
static PFNglTexCoordPointer pglTexCoordPointer;
|
||||||
typedef void (APIENTRY * PFNglDrawArrays) (GLenum mode, GLint first, GLsizei count);
|
typedef void (APIENTRY * PFNglDrawArrays) (GLenum mode, GLint first, GLsizei count);
|
||||||
static PFNglDrawArrays pglDrawArrays;
|
static PFNglDrawArrays pglDrawArrays;
|
||||||
|
typedef void (APIENTRY * PFNglDrawElements) (GLenum mode, GLsizei count, GLenum type, const GLvoid *indices);
|
||||||
|
static PFNglDrawElements pglDrawElements;
|
||||||
typedef void (APIENTRY * PFNglEnableClientState) (GLenum cap);
|
typedef void (APIENTRY * PFNglEnableClientState) (GLenum cap);
|
||||||
static PFNglEnableClientState pglEnableClientState;
|
static PFNglEnableClientState pglEnableClientState;
|
||||||
typedef void (APIENTRY * PFNglDisableClientState) (GLenum cap);
|
typedef void (APIENTRY * PFNglDisableClientState) (GLenum cap);
|
||||||
|
@ -509,14 +521,18 @@ boolean SetupGLfunc(void)
|
||||||
GETOPENGLFUNC(pglBegin , glBegin)
|
GETOPENGLFUNC(pglBegin , glBegin)
|
||||||
GETOPENGLFUNC(pglEnd , glEnd)
|
GETOPENGLFUNC(pglEnd , glEnd)
|
||||||
GETOPENGLFUNC(pglVertex3f , glVertex3f)
|
GETOPENGLFUNC(pglVertex3f , glVertex3f)
|
||||||
|
GETOPENGLFUNC(pglVertex3sv, glVertex3sv)
|
||||||
GETOPENGLFUNC(pglNormal3f , glNormal3f)
|
GETOPENGLFUNC(pglNormal3f , glNormal3f)
|
||||||
|
GETOPENGLFUNC(pglNormal3bv, glNomral3bv)
|
||||||
GETOPENGLFUNC(pglColor4f , glColor4f)
|
GETOPENGLFUNC(pglColor4f , glColor4f)
|
||||||
GETOPENGLFUNC(pglColor4fv , glColor4fv)
|
GETOPENGLFUNC(pglColor4fv , glColor4fv)
|
||||||
GETOPENGLFUNC(pglTexCoord2f , glTexCoord2f)
|
GETOPENGLFUNC(pglTexCoord2f , glTexCoord2f)
|
||||||
|
GETOPENGLFUNC(pglTexCoord2fv, glTexCoord2fv)
|
||||||
GETOPENGLFUNC(pglVertexPointer, glVertexPointer)
|
GETOPENGLFUNC(pglVertexPointer, glVertexPointer)
|
||||||
GETOPENGLFUNC(pglNormalPointer, glNormalPointer)
|
GETOPENGLFUNC(pglNormalPointer, glNormalPointer)
|
||||||
GETOPENGLFUNC(pglTexCoordPointer, glTexCoordPointer)
|
GETOPENGLFUNC(pglTexCoordPointer, glTexCoordPointer)
|
||||||
GETOPENGLFUNC(pglDrawArrays, glDrawArrays)
|
GETOPENGLFUNC(pglDrawArrays, glDrawArrays)
|
||||||
|
GETOPENGLFUNC(pglDrawElements, glDrawElements)
|
||||||
GETOPENGLFUNC(pglEnableClientState, glEnableClientState)
|
GETOPENGLFUNC(pglEnableClientState, glEnableClientState)
|
||||||
GETOPENGLFUNC(pglDisableClientState, glDisableClientState)
|
GETOPENGLFUNC(pglDisableClientState, glDisableClientState)
|
||||||
|
|
||||||
|
@ -1902,7 +1918,7 @@ EXPORT void HWRAPI(SetSpecialState) (hwdspecialstate_t IdState, INT32 Value)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void DrawModelEx(model_t *model, mdlframe_t *frame, INT32 duration, INT32 tics, mdlframe_t *nextframe, FTransform *pos, float scale, UINT8 flipped, UINT8 *color)
|
static void DrawModelEx(model_t *model, INT32 frameIndex, INT32 duration, INT32 tics, INT32 nextFrameIndex, FTransform *pos, float scale, UINT8 flipped, UINT8 *color)
|
||||||
{
|
{
|
||||||
INT32 val, count, pindex;
|
INT32 val, count, pindex;
|
||||||
GLfloat s, t;
|
GLfloat s, t;
|
||||||
|
@ -1993,105 +2009,139 @@ static void DrawModelEx(model_t *model, mdlframe_t *frame, INT32 duration, INT32
|
||||||
|
|
||||||
pglScalef(scalex, scaley, scalez);
|
pglScalef(scalex, scaley, scalez);
|
||||||
|
|
||||||
mesh_t *mesh = &model->meshes[0];
|
boolean useTinyFrames = model->meshes[0].tinyframes != NULL;
|
||||||
|
|
||||||
if (!nextframe || pol == 0.0f)
|
if (useTinyFrames)
|
||||||
|
pglScalef(1 / 64.0f, 1 / 64.0f, 1 / 64.0f);
|
||||||
|
|
||||||
|
for (int i = 0; i < model->numMeshes; i++)
|
||||||
{
|
{
|
||||||
// Zoom! Take advantage of just shoving the entire arrays to the GPU.
|
mesh_t *mesh = &model->meshes[i];
|
||||||
pglEnableClientState(GL_VERTEX_ARRAY);
|
|
||||||
pglEnableClientState(GL_TEXTURE_COORD_ARRAY);
|
|
||||||
pglEnableClientState(GL_NORMAL_ARRAY);
|
|
||||||
pglVertexPointer(3, GL_FLOAT, 0, frame->vertices);
|
|
||||||
pglNormalPointer(GL_FLOAT, 0, frame->normals);
|
|
||||||
pglTexCoordPointer(2, GL_FLOAT, 0, mesh->uvs);
|
|
||||||
pglDrawArrays(GL_TRIANGLES, 0, mesh->numTriangles * 3);
|
|
||||||
pglDisableClientState(GL_NORMAL_ARRAY);
|
|
||||||
pglDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
|
||||||
pglDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
|
||||||
/*
|
|
||||||
pglBegin(GL_TRIANGLES);
|
|
||||||
|
|
||||||
int i = 0;
|
if (useTinyFrames)
|
||||||
float *uvPtr = mesh->uvs;
|
|
||||||
float *frameVert = frame->vertices;
|
|
||||||
float *frameNormal = frame->normals;
|
|
||||||
for (i = 0; i < mesh->numTriangles; i++)
|
|
||||||
{
|
{
|
||||||
float uvx = *uvPtr++;
|
tinyframe_t *frame = &mesh->tinyframes[frameIndex % mesh->numFrames];
|
||||||
float uvy = *uvPtr++;
|
tinyframe_t *nextframe = NULL;
|
||||||
|
|
||||||
// Interpolate
|
if (nextFrameIndex != -1)
|
||||||
float px1 = *frameVert++;
|
nextframe = &mesh->tinyframes[nextFrameIndex % mesh->numFrames];
|
||||||
float py1 = *frameVert++;
|
|
||||||
float pz1 = *frameVert++;
|
|
||||||
float nx1 = *frameNormal++;
|
|
||||||
float ny1 = *frameNormal++;
|
|
||||||
float nz1 = *frameNormal++;
|
|
||||||
|
|
||||||
pglTexCoord2f(uvx, uvy);
|
if (!nextframe || pol == 0.0f)
|
||||||
pglNormal3f(nx1, ny1, nz1);
|
{
|
||||||
pglVertex3f(px1, py1, pz1);
|
pglEnableClientState(GL_VERTEX_ARRAY);
|
||||||
|
pglEnableClientState(GL_TEXTURE_COORD_ARRAY);
|
||||||
|
pglEnableClientState(GL_NORMAL_ARRAY);
|
||||||
|
pglVertexPointer(3, GL_SHORT, 0, frame->vertices);
|
||||||
|
pglNormalPointer(GL_BYTE, 0, frame->normals);
|
||||||
|
pglTexCoordPointer(2, GL_FLOAT, 0, mesh->uvs);
|
||||||
|
pglDrawElements(GL_TRIANGLES, mesh->numTriangles * 3, GL_UNSIGNED_SHORT, mesh->indices);
|
||||||
|
pglDisableClientState(GL_NORMAL_ARRAY);
|
||||||
|
pglDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
||||||
|
pglDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Dangit, I soooo want to do this in a GLSL shader...
|
||||||
|
pglBegin(GL_TRIANGLES);
|
||||||
|
|
||||||
|
short *buffer = malloc(mesh->numVertices * sizeof(short));
|
||||||
|
short *vertPtr = buffer;
|
||||||
|
char *normBuffer = malloc(mesh->numVertices * sizeof(char));
|
||||||
|
char *normPtr = normBuffer;
|
||||||
|
|
||||||
|
int j = 0;
|
||||||
|
for (j = 0; j < mesh->numVertices; j++)
|
||||||
|
{
|
||||||
|
// Interpolate
|
||||||
|
*vertPtr++ = (short)(frame->vertices[j] + (pol * (nextframe->vertices[j] - frame->vertices[j])));
|
||||||
|
*normPtr++ = (short)(frame->normals[j] + (pol * (nextframe->normals[j] - frame->normals[j])));
|
||||||
|
}
|
||||||
|
|
||||||
|
float *uvPtr = mesh->uvs;
|
||||||
|
vertPtr = buffer;
|
||||||
|
normPtr = normBuffer;
|
||||||
|
for (j = 0; j < mesh->numTriangles; j++)
|
||||||
|
{
|
||||||
|
pglTexCoord2fv(uvPtr);
|
||||||
|
pglNormal3bv(normPtr);
|
||||||
|
pglVertex3sv(vertPtr);
|
||||||
|
|
||||||
|
uvPtr += 2;
|
||||||
|
normPtr += 3;
|
||||||
|
vertPtr += 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
free(buffer);
|
||||||
|
free(normBuffer);
|
||||||
|
|
||||||
|
pglEnd();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
pglEnd();*/
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Dangit, I soooo want to do this in a GLSL shader...
|
|
||||||
pglBegin(GL_TRIANGLES);
|
|
||||||
|
|
||||||
int i = 0;
|
|
||||||
float *uvPtr = mesh->uvs;
|
|
||||||
float *frameVert = frame->vertices;
|
|
||||||
float *frameNormal = frame->normals;
|
|
||||||
float *nextFrameVert = nextframe->vertices;
|
|
||||||
float *nextFrameNormal = frame->normals;
|
|
||||||
for (i = 0; i < mesh->numTriangles; i++)
|
|
||||||
{
|
{
|
||||||
float uvx = *uvPtr++;
|
mdlframe_t *frame = &mesh->frames[frameIndex % mesh->numFrames];
|
||||||
float uvy = *uvPtr++;
|
mdlframe_t *nextframe = NULL;
|
||||||
|
|
||||||
// Interpolate
|
if (nextFrameIndex != -1)
|
||||||
float px1 = *frameVert++;
|
nextframe = &mesh->frames[nextFrameIndex % mesh->numFrames];
|
||||||
float px2 = *nextFrameVert++;
|
|
||||||
float py1 = *frameVert++;
|
|
||||||
float py2 = *nextFrameVert++;
|
|
||||||
float pz1 = *frameVert++;
|
|
||||||
float pz2 = *nextFrameVert++;
|
|
||||||
float nx1 = *frameNormal++;
|
|
||||||
float nx2 = *nextFrameNormal++;
|
|
||||||
float ny1 = *frameNormal++;
|
|
||||||
float ny2 = *nextFrameNormal++;
|
|
||||||
float nz1 = *frameNormal++;
|
|
||||||
float nz2 = *nextFrameNormal++;
|
|
||||||
|
|
||||||
pglTexCoord2f(uvx, uvy);
|
if (!nextframe || pol == 0.0f)
|
||||||
pglNormal3f((nx1 + pol * (nx2 - nx1)),
|
{
|
||||||
(ny1 + pol * (ny2 - ny1)),
|
// Zoom! Take advantage of just shoving the entire arrays to the GPU.
|
||||||
(nz1 + pol * (nz2 - nz1)));
|
pglEnableClientState(GL_VERTEX_ARRAY);
|
||||||
pglVertex3f((px1 + pol * (px2 - px1)),
|
pglEnableClientState(GL_TEXTURE_COORD_ARRAY);
|
||||||
(py1 + pol * (py2 - py1)),
|
pglEnableClientState(GL_NORMAL_ARRAY);
|
||||||
(pz1 + pol * (pz2 - pz1)));
|
pglVertexPointer(3, GL_FLOAT, 0, frame->vertices);
|
||||||
|
pglNormalPointer(GL_FLOAT, 0, frame->normals);
|
||||||
|
pglTexCoordPointer(2, GL_FLOAT, 0, mesh->uvs);
|
||||||
|
pglDrawArrays(GL_TRIANGLES, 0, mesh->numTriangles * 3);
|
||||||
|
pglDisableClientState(GL_NORMAL_ARRAY);
|
||||||
|
pglDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
||||||
|
pglDisableClientState(GL_TEXTURE_COORD_ARRAY);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Dangit, I soooo want to do this in a GLSL shader...
|
||||||
|
pglBegin(GL_TRIANGLES);
|
||||||
|
|
||||||
|
int j = 0;
|
||||||
|
float *uvPtr = mesh->uvs;
|
||||||
|
float *frameVert = frame->vertices;
|
||||||
|
float *frameNormal = frame->normals;
|
||||||
|
float *nextFrameVert = nextframe->vertices;
|
||||||
|
float *nextFrameNormal = frame->normals;
|
||||||
|
for (j = 0; j < mesh->numTriangles; j++)
|
||||||
|
{
|
||||||
|
// Interpolate
|
||||||
|
float px1 = *frameVert++;
|
||||||
|
float px2 = *nextFrameVert++;
|
||||||
|
float py1 = *frameVert++;
|
||||||
|
float py2 = *nextFrameVert++;
|
||||||
|
float pz1 = *frameVert++;
|
||||||
|
float pz2 = *nextFrameVert++;
|
||||||
|
float nx1 = *frameNormal++;
|
||||||
|
float nx2 = *nextFrameNormal++;
|
||||||
|
float ny1 = *frameNormal++;
|
||||||
|
float ny2 = *nextFrameNormal++;
|
||||||
|
float nz1 = *frameNormal++;
|
||||||
|
float nz2 = *nextFrameNormal++;
|
||||||
|
|
||||||
|
pglTexCoord2fv(uvPtr);
|
||||||
|
pglNormal3f((nx1 + pol * (nx2 - nx1)),
|
||||||
|
(ny1 + pol * (ny2 - ny1)),
|
||||||
|
(nz1 + pol * (nz2 - nz1)));
|
||||||
|
pglVertex3f((px1 + pol * (px2 - px1)),
|
||||||
|
(py1 + pol * (py2 - py1)),
|
||||||
|
(pz1 + pol * (pz2 - pz1)));
|
||||||
|
|
||||||
|
uvPtr++;
|
||||||
|
}
|
||||||
|
|
||||||
|
pglEnd();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pglEnd();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if (lightType != LIGHT_NONE)
|
|
||||||
{
|
|
||||||
glVertexAttribPointer(program->slots[Shaders::A_NORMAL_SLOT], 3, BGL_FLOAT, BGL_FALSE, 0, frame->normals);
|
|
||||||
// if (normalmapped)
|
|
||||||
// bglVertexAttribPointer(program->slots[Shaders::A_TANGENT_SLOT], 3, BGL_FLOAT, BGL_FALSE, 0, frame->tangents);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (frame->colors)
|
|
||||||
glVertexAttribPointer(program->slots[Shaders::A_COLOR_SLOT], 4, GL_UNSIGNED_BYTE, BGL_TRUE, 0, frame->colors);
|
|
||||||
else
|
|
||||||
{
|
|
||||||
SetGlobalWhiteColorArray(mesh->numTriangles * 3);
|
|
||||||
glVertexAttribPointer(program->slots[Shaders::A_COLOR_SLOT], 3, BGL_UNSIGNED_BYTE, BGL_TRUE, 0, globalWhiteColorArray);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
pglPopMatrix(); // should be the same as glLoadIdentity
|
pglPopMatrix(); // should be the same as glLoadIdentity
|
||||||
if (color)
|
if (color)
|
||||||
pglDisable(GL_LIGHTING);
|
pglDisable(GL_LIGHTING);
|
||||||
|
@ -2102,9 +2152,9 @@ static void DrawModelEx(model_t *model, mdlframe_t *frame, INT32 duration, INT32
|
||||||
// -----------------+
|
// -----------------+
|
||||||
// HWRAPI DrawMD2 : Draw an MD2 model with glcommands
|
// HWRAPI DrawMD2 : Draw an MD2 model with glcommands
|
||||||
// -----------------+
|
// -----------------+
|
||||||
EXPORT void HWRAPI(DrawModel) (model_t *model, mdlframe_t *frame, INT32 duration, INT32 tics, mdlframe_t *nextframe, FTransform *pos, float scale, UINT8 flipped, UINT8 *color)
|
EXPORT void HWRAPI(DrawModel) (model_t *model, INT32 frameIndex, INT32 duration, INT32 tics, INT32 nextFrameIndex, FTransform *pos, float scale, UINT8 flipped, UINT8 *color)
|
||||||
{
|
{
|
||||||
DrawModelEx(model, frame, duration, tics, nextframe, pos, scale, flipped, color);
|
DrawModelEx(model, frameIndex, duration, tics, nextFrameIndex, pos, scale, flipped, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
// -----------------+
|
// -----------------+
|
||||||
|
|
Loading…
Reference in a new issue