- collect all 3D geometry in a list so that it can be rendered later.

With this out of the way the renderer can now be switched to the core profile.
This commit is contained in:
Christoph Oelckers 2020-01-18 22:41:08 +01:00
parent 2bc1708870
commit 454f796b69
16 changed files with 127 additions and 165 deletions

View file

@ -331,7 +331,7 @@ typedef struct {
int16_t angoff, pitch, roll; int16_t angoff, pitch, roll;
vec3_t pivot_offset, position_offset; vec3_t pivot_offset, position_offset;
uint8_t flags; uint8_t flags;
uint8_t xpanning, ypanning; uint8_t xpanning, ypanning; // EDuke script hacks.
uint8_t filler; uint8_t filler;
uint32_t filler2; uint32_t filler2;
float alpha; float alpha;

View file

@ -10,6 +10,7 @@
#include "baselayer.h" #include "baselayer.h"
#include "build.h" #include "build.h"
#include "tarray.h" #include "tarray.h"
#include "flatvertices.h"
#include "../../glbackend/glbackend.h" #include "../../glbackend/glbackend.h"
static TArray<uint8_t> buffer; static TArray<uint8_t> buffer;
@ -75,13 +76,5 @@ void glsurface_blitBuffer()
bufferTexture->LoadTexture(buffer.Data()); bufferTexture->LoadTexture(buffer.Data());
GLInterface.BindTexture(0, bufferTexture, SamplerNoFilterClampXY); GLInterface.BindTexture(0, bufferTexture, SamplerNoFilterClampXY);
GLInterface.Draw(DT_TRIANGLE_STRIP, FFlatVertexBuffer::PRESENT_INDEX, 4);
auto data = GLInterface.AllocVertices(4);
auto vt = data.second;
vt[0].Set(-1.0f, 1.0f, 0.0f, 0.0f, 0.0f); //top-left
vt[1].Set(-1.0f, -1.0f, 0.0f, 0.0f, 1.0f); //bottom-left
vt[2].Set(1.0f, 1.0f, 0.0f, 1.0f, 0.0f); //top-right
vt[3].Set(1.0f, -1.0f, 0.0f, 1.0f, 1.0f); //bottom-right
GLInterface.DrawIm(DT_TRIANGLE_STRIP, data.first, 4);
} }

View file

@ -15,6 +15,8 @@
#include "palette.h" #include "palette.h"
#include "textures.h" #include "textures.h"
#include "bitmap.h" #include "bitmap.h"
#include "v_video.h"
#include "flatvertices.h"
#include "../../glbackend/glbackend.h" #include "../../glbackend/glbackend.h"
static int32_t curextra=MAXTILES; static int32_t curextra=MAXTILES;
@ -1454,8 +1456,8 @@ static void md3draw_handle_triangles(const md3surf_t *s, uint16_t *indexhandle,
int32_t i; int32_t i;
auto data = GLInterface.AllocVertices(s->numtris * 3); auto data = screen->mVertexData->AllocVertices(s->numtris * 3);
auto vt = data.second; auto vt = data.first;
for (i=s->numtris-1; i>=0; i--) for (i=s->numtris-1; i>=0; i--)
{ {
uint16_t tri = M ? M->indexes[i] : i; uint16_t tri = M ? M->indexes[i] : i;
@ -1470,7 +1472,7 @@ static void md3draw_handle_triangles(const md3surf_t *s, uint16_t *indexhandle,
vt->SetVertex(vertlist[k].x, vertlist[k].y); vt->SetVertex(vertlist[k].x, vertlist[k].y);
} }
} }
GLInterface.DrawIm(DT_TRIANGLES, data.first, s->numtris *3); GLInterface.Draw(DT_TRIANGLES, data.second, s->numtris *3);
#ifndef USE_GLEXT #ifndef USE_GLEXT
UNREFERENCED_PARAMETER(texunits); UNREFERENCED_PARAMETER(texunits);
@ -1638,9 +1640,6 @@ static int32_t polymost_md3draw(md3model_t *m, tspriteptr_t tspr)
k3 = (float)sintable[sext->roll&2047] * (1.f/16384.f); k3 = (float)sintable[sext->roll&2047] * (1.f/16384.f);
} }
float const xpanning = (float)sext->xpanning * (1.f/256.f);
float const ypanning = (float)sext->ypanning * (1.f/256.f);
int prevClamp = GLInterface.GetClamp(); int prevClamp = GLInterface.GetClamp();
GLInterface.SetClamp(0); GLInterface.SetClamp(0);
@ -1720,10 +1719,7 @@ static int32_t polymost_md3draw(md3model_t *m, tspriteptr_t tspr)
} }
glow = hw_glowmapping ? mdloadskin((md2model_t *) m, tile2model[Ptile2tile(tspr->picnum, lpal)].skinnum, GLOWPAL, surfi, nullptr) : 0; glow = hw_glowmapping ? mdloadskin((md2model_t *) m, tile2model[Ptile2tile(tspr->picnum, lpal)].skinnum, GLOWPAL, surfi, nullptr) : 0;
} }
GLInterface.SetModelTexture(tex, globalpal, xpanning, ypanning, det, detscale, glow); GLInterface.SetModelTexture(tex, globalpal, det, detscale, glow);
VSMatrix texmat(0);
texmat.translate(xpanning, ypanning, 1.0f);
if (tspr->clipdist & TSPR_FLAGS_MDHACK) if (tspr->clipdist & TSPR_FLAGS_MDHACK)
{ {

View file

@ -16,6 +16,8 @@ Ken Silverman's official web site: http://www.advsys.net/ken
#include "../../glbackend/glbackend.h" #include "../../glbackend/glbackend.h"
#include "c_cvars.h" #include "c_cvars.h"
#include "gamecvars.h" #include "gamecvars.h"
#include "v_video.h"
#include "flatvertices.h"
CVAR(Bool, hw_detailmapping, true, CVAR_ARCHIVE | CVAR_GLOBALCONFIG) CVAR(Bool, hw_detailmapping, true, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
CVAR(Bool, hw_glowmapping, true, CVAR_ARCHIVE | CVAR_GLOBALCONFIG) CVAR(Bool, hw_glowmapping, true, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
@ -581,8 +583,8 @@ static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32
GLInterface.SetColor(pc[0], pc[1], pc[2], pc[3]); GLInterface.SetColor(pc[0], pc[1], pc[2], pc[3]);
vec2f_t const scale = { 1.f / tsiz2.x, 1.f / tsiz2.y }; vec2f_t const scale = { 1.f / tsiz2.x, 1.f / tsiz2.y };
auto data = GLInterface.AllocVertices(npoints); auto data = screen->mVertexData->AllocVertices(npoints);
auto vt = data.second; auto vt = data.first;
for (bssize_t i = 0; i < npoints; ++i, vt++) for (bssize_t i = 0; i < npoints; ++i, vt++)
{ {
float const r = 1.f / dd[i]; float const r = 1.f / dd[i];
@ -599,7 +601,7 @@ static void polymost_drawpoly(vec2f_t const * const dpxy, int32_t const n, int32
r * (1.f / 1024.f)); r * (1.f / 1024.f));
} }
GLInterface.DrawIm(DT_TRIANGLE_FAN, data.first, npoints); GLInterface.Draw(DT_TRIANGLE_FAN, data.second, npoints);
GLInterface.SetTinting(-1, 0xffffff, 0xffffff); GLInterface.SetTinting(-1, 0xffffff, 0xffffff);
GLInterface.UseDetailMapping(false); GLInterface.UseDetailMapping(false);

View file

@ -10,6 +10,8 @@
#include "hightile.h" #include "hightile.h"
#include "polymost.h" #include "polymost.h"
#include "mdsprite.h" #include "mdsprite.h"
#include "v_video.h"
#include "flatvertices.h"
#include "palette.h" #include "palette.h"
#include "../../glbackend/glbackend.h" #include "../../glbackend/glbackend.h"
@ -1140,10 +1142,10 @@ int32_t polymost_voxdraw(voxmodel_t *m, tspriteptr_t const tspr)
GLInterface.UseDetailMapping(false); GLInterface.UseDetailMapping(false);
#endif #endif
auto data = GLInterface.AllocVertices(m->qcnt * 6); auto data = screen->mVertexData->AllocVertices(m->qcnt * 6);
auto vt = data.second; auto vt = data.first;
int qstart = 0; int qstart = data.second;
int qdone = 0; int qdone = 0;
for (bssize_t i=0, fi=0; i<m->qcnt; i++) for (bssize_t i=0, fi=0; i<m->qcnt; i++)
{ {
@ -1152,7 +1154,7 @@ int32_t polymost_voxdraw(voxmodel_t *m, tspriteptr_t const tspr)
f = 1 /*clut[fi++]*/; f = 1 /*clut[fi++]*/;
if (qdone > 0) if (qdone > 0)
{ {
GLInterface.DrawIm(DT_TRIANGLES, qstart, qdone * 6); GLInterface.Draw(DT_TRIANGLES, qstart, qdone * 6);
qstart += qdone * 6; qstart += qdone * 6;
qdone = 0; qdone = 0;
} }
@ -1182,7 +1184,7 @@ int32_t polymost_voxdraw(voxmodel_t *m, tspriteptr_t const tspr)
qdone++; qdone++;
} }
GLInterface.DrawIm(DT_TRIANGLES, qstart, qdone * 6); GLInterface.Draw(DT_TRIANGLES, qstart, qdone * 6);
GLInterface.SetClamp(prevClamp); GLInterface.SetClamp(prevClamp);
//------------ //------------
GLInterface.SetCull(Cull_None); GLInterface.SetCull(Cull_None);

View file

@ -14,7 +14,7 @@ struct F2DPolygons
TArray<FVector4> vertices; TArray<FVector4> vertices;
TArray<int> indices; TArray<int> indices;
unsigned AllocVertices(int num) // Allocates a triangle fan. There's no code that needs a triangle strip. unsigned AllocVertices(int num)
{ {
auto vindex = vertices.Reserve(num); auto vindex = vertices.Reserve(num);
indices.Push(num); indices.Push(num);

View file

@ -207,6 +207,7 @@ void OpenGLFrameBuffer::Update()
Swap(); Swap();
Super::Update(); Super::Update();
screen->mVertexData->Reset();
} }
//=========================================================================== //===========================================================================

View file

@ -36,6 +36,7 @@
#include "flatvertices.h" #include "flatvertices.h"
#include "v_video.h" #include "v_video.h"
#include "cmdlib.h" #include "cmdlib.h"
#include "printf.h"
#include "hwrenderer/data/buffers.h" #include "hwrenderer/data/buffers.h"
//========================================================================== //==========================================================================
@ -89,7 +90,7 @@ FFlatVertexBuffer::FFlatVertexBuffer(int width, int height)
}; };
mVertexBuffer->SetFormat(1, 2, sizeof(FFlatVertex), format); mVertexBuffer->SetFormat(1, 2, sizeof(FFlatVertex), format);
mIndex = mCurIndex = 0; mIndex = mCurIndex = NUM_RESERVED;
mNumReserved = NUM_RESERVED; mNumReserved = NUM_RESERVED;
Copy(0, NUM_RESERVED); Copy(0, NUM_RESERVED);
} }
@ -129,6 +130,25 @@ void FFlatVertexBuffer::OutputResized(int width, int height)
// //
//========================================================================== //==========================================================================
std::pair<FFlatVertex *, unsigned int> FFlatVertexBuffer::AllocVertices(unsigned int count)
{
FFlatVertex *p = GetBuffer();
auto index = mCurIndex.fetch_add(count);
auto offset = index;
if (index + count >= BUFFER_SIZE_TO_USE)
{
// If a single scene needs 2'000'000 vertices there must be something very wrong.
I_FatalError("Out of vertex memory. Tried to allocate more than %u vertices for a single frame", index + count);
}
return std::make_pair(p, index);
}
//==========================================================================
//
//
//
//==========================================================================
void FFlatVertexBuffer::Copy(int start, int count) void FFlatVertexBuffer::Copy(int start, int count)
{ {
Map(); Map();

View file

@ -24,6 +24,20 @@ struct FFlatVertex
u = uu; u = uu;
v = vv; v = vv;
} }
void SetVertex(float _x, float _y, float _z = 0)
{
x = _x;
z = _y;
y = _z;
}
void SetTexCoord(float _u = 0, float _v = 0)
{
u = _u;
v = _v;
}
}; };
class FFlatVertexBuffer class FFlatVertexBuffer

View file

@ -46,6 +46,7 @@
#include "i_time.h" #include "i_time.h"
#include "v_2ddrawer.h" #include "v_2ddrawer.h"
#include "build.h" #include "build.h"
#include "../glbackend/glbackend.h"
/* /*
#include "hwrenderer/scene/hw_portal.h" #include "hwrenderer/scene/hw_portal.h"
#include "hwrenderer/utility/hw_clock.h" #include "hwrenderer/utility/hw_clock.h"
@ -390,5 +391,8 @@ void DFrameBuffer::FinishScene()
if (videoGetRenderMode() < REND_POLYMOST) return; if (videoGetRenderMode() < REND_POLYMOST) return;
assert(BufferLock > 0); assert(BufferLock > 0);
if (--BufferLock == 0) if (--BufferLock == 0)
{
mVertexData->Unmap(); mVertexData->Unmap();
GLInterface.DoDraw();
}
} }

View file

@ -50,13 +50,14 @@ enum PRSFlags
STF_CLEARCOLOR = 1024, STF_CLEARCOLOR = 1024,
STF_CLEARDEPTH = 2048, STF_CLEARDEPTH = 2048,
STF_VIEWPORTSET = 4096, STF_VIEWPORTSET = 4096,
STF_SCISSORSET = 4096, STF_SCISSORSET = 8192,
}; };
struct PolymostRenderState struct PolymostRenderState
{ {
int vindex, vcount, primtype;
float Shade; float Shade;
float NumShades = 64.f; float NumShades = 64.f;
float ShadeDiv = 62.f; float ShadeDiv = 62.f;
@ -70,7 +71,7 @@ struct PolymostRenderState
float Color[4] = { 1,1,1,1 }; float Color[4] = { 1,1,1,1 };
short matrixIndex[NUMMATRICES] = { -1,-1,-1,-1,-1 }; short matrixIndex[NUMMATRICES] = { -1,-1,-1,-1,-1 };
PalEntry fullscreenTint = 0xffffff, hictint = 0xffffff, hictint_overlay = 0xffffff; PalEntry fullscreenTint = 0xffffff, hictint = 0xffffff, hictint_overlay = 0xffffff;
int hictint_flags = 0; int hictint_flags = -1;
int StateFlags = STF_COLORMASK|STF_DEPTHMASK; int StateFlags = STF_COLORMASK|STF_DEPTHMASK;
FRenderStyle Style{}; FRenderStyle Style{};
@ -82,9 +83,5 @@ struct PolymostRenderState
PalEntry FogColor; PalEntry FogColor;
IVertexBuffer* VertexBuffer = nullptr;
int VB_Offset[2] = {};
IIndexBuffer* IndexBuffer = nullptr;
void Apply(PolymostShader *shader, GLState &oldstate); void Apply(PolymostShader *shader, GLState &oldstate);
}; };

View file

@ -150,7 +150,7 @@ FHardwareTexture* GLInstance::LoadTexture(FTexture* tex, int textype, int palid)
// //
//=========================================================================== //===========================================================================
bool GLInstance::SetTextureInternal(int picnum, FTexture* tex, int palette, int method, int sampleroverride, float xpanning, float ypanning, FTexture *det, float detscale, FTexture *glow) bool GLInstance::SetTextureInternal(int picnum, FTexture* tex, int palette, int method, int sampleroverride, FTexture *det, float detscale, FTexture *glow)
{ {
if (tex->GetWidth() <= 0 || tex->GetHeight() <= 0) return false; if (tex->GetWidth() <= 0 || tex->GetHeight() <= 0) return false;
int usepalette = fixpalette >= 1 ? fixpalette - 1 : curbasepal; int usepalette = fixpalette >= 1 ? fixpalette - 1 : curbasepal;
@ -158,6 +158,7 @@ bool GLInstance::SetTextureInternal(int picnum, FTexture* tex, int palette, int
GLInterface.SetPalette(usepalette); GLInterface.SetPalette(usepalette);
GLInterface.SetPalswap(usepalswap); GLInterface.SetPalswap(usepalswap);
bool texbound[3] = {}; bool texbound[3] = {};
int MatrixChange = 0;
TextureType = hw_useindexedcolortextures? TT_INDEXED : TT_TRUECOLOR; TextureType = hw_useindexedcolortextures? TT_INDEXED : TT_TRUECOLOR;
@ -209,13 +210,12 @@ bool GLInstance::SetTextureInternal(int picnum, FTexture* tex, int palette, int
UseBrightmaps(false); UseBrightmaps(false);
BindTexture(0, mtex, sampler); BindTexture(0, mtex, sampler);
if (rep && (rep->scale.x != 1.0f || rep->scale.y != 1.0f || xpanning != 0 || ypanning != 0)) // Needs a) testing and b) verification for correctness. This doesn't look like it makes sense.
if (rep && (rep->scale.x != 1.0f || rep->scale.y != 1.0f))
{ {
texmat.loadIdentity(); //texmat.loadIdentity();
texmat.translate(xpanning, ypanning, 0); //texmat.scale(rep->scale.x, rep->scale.y, 1.0f);
texmat.scale(rep->scale.x, rep->scale.y, 1.0f); //GLInterface.SetMatrix(Matrix_Texture, &texmat);
GLInterface.SetMatrix(Matrix_Texture, &texmat);
MatrixChange |= 1;
} }
// Also load additional layers needed for this texture. // Also load additional layers needed for this texture.
@ -239,16 +239,17 @@ bool GLInstance::SetTextureInternal(int picnum, FTexture* tex, int palette, int
BindTexture(3, htex, SamplerRepeat); BindTexture(3, htex, SamplerRepeat);
texbound[0] = true; texbound[0] = true;
// Q: Pass the scale factor as a separate uniform to get rid of the additional matrix?
/* todo: instead of a matrix, just pass a two-component uniform. Using a full matrix here is problematic.
if (MatrixChange & 1) MatrixChange |= 2; if (MatrixChange & 1) MatrixChange |= 2;
else texmat.loadIdentity(); else texmat.loadIdentity();
if ((detscalex != 1.0f) || (detscaley != 1.0f)) if ((detscalex != 1.0f) || (detscaley != 1.0f))
{ {
texmat.scale(detscalex, detscaley, 1.0f); texmat.scale(detscalex, detscaley, 1.0f);
MatrixChange |= 2; MatrixChange |= 2;
} }
if (MatrixChange & 2) GLInterface.SetMatrix(Matrix_Detail, &texmat); if (MatrixChange & 2) GLInterface.SetMatrix(Matrix_Detail, &texmat);
*/
} }
} }
if (hw_glowmapping && hw_hightile) if (hw_glowmapping && hw_hightile)

View file

@ -198,24 +198,25 @@ void GLInstance::ResetFrame()
} }
void GLInstance::SetVertexBuffer(IVertexBuffer* vb, int offset1, int offset2)
{
int o[] = { offset1, offset2 };
static_cast<OpenGLRenderer::GLVertexBuffer*>(vb)->Bind(o);
}
void GLInstance::SetIndexBuffer(IIndexBuffer* vb)
{
if (vb) static_cast<OpenGLRenderer::GLIndexBuffer*>(vb)->Bind();
else glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0);
}
void GLInstance::ClearBufferState() void GLInstance::ClearBufferState()
{ {
auto buffer = (screen->mVertexData->GetBufferObjects().first); SetVertexBuffer(screen->mVertexData->GetBufferObjects().first, 0, 0);
SetVertexBuffer(buffer, 0, 0);
SetIndexBuffer(nullptr); SetIndexBuffer(nullptr);
// Invalidate the pointers as well to make sure that if another buffer with the same address is used it actually gets bound.
LastVertexBuffer = (IVertexBuffer*)~intptr_t(0);
LastIndexBuffer = (IIndexBuffer*)~intptr_t(0);
} }
std::pair<size_t, BaseVertex *> GLInstance::AllocVertices(size_t num)
{
Buffer.resize(num);
return std::make_pair((size_t)0, Buffer.data());
}
static GLint primtypes[] = static GLint primtypes[] =
{ {
GL_TRIANGLES, GL_TRIANGLES,
@ -224,37 +225,19 @@ static GLint primtypes[] =
GL_LINES GL_LINES
}; };
void GLInstance::DrawIm(EDrawType type, size_t start, size_t count)
{
// Todo: Based on the current tinting flags and the texture type (indexed texture and APPLYOVERPALSWAP not set) this may have to reset the palette for the draw call / texture creation.
bool applied = false;
if (activeShader == polymostShader)
{
glVertexAttrib4fv(2, renderState.Color);
if (renderState.Color[3] != 1.f) renderState.Flags &= ~RF_Brightmapping; // The way the colormaps are set up means that brightmaps cannot be used on translucent content at all.
renderState.Apply(polymostShader, lastState);
}
glBegin(primtypes[type]);
auto p = &Buffer[start];
for (size_t i = 0; i < count; i++, p++)
{
glVertexAttrib2f(1, p->u, p->v);
glVertexAttrib3f(0, p->x, p->y, p->z);
}
glEnd();
if (MatrixChange)
{
if (MatrixChange & 1) SetIdentityMatrix(Matrix_Texture);
if (MatrixChange & 2) SetIdentityMatrix(Matrix_Detail);
MatrixChange = 0;
}
matrixArray.Resize(1);
}
void GLInstance::Draw(EDrawType type, size_t start, size_t count) void GLInstance::Draw(EDrawType type, size_t start, size_t count)
{
renderState.vindex = start;
renderState.vcount = count;
renderState.primtype = type;
rendercommands.Push(renderState);
SetIdentityMatrix(Matrix_Texture);
SetIdentityMatrix(Matrix_Detail);
renderState.StateFlags &= ~(STF_CLEARCOLOR | STF_CLEARDEPTH | STF_VIEWPORTSET | STF_SCISSORSET);
}
void GLInstance::DrawElement(EDrawType type, size_t start, size_t count, PolymostRenderState &renderState)
{ {
// Todo: Based on the current tinting flags and the texture type (indexed texture and APPLYOVERPALSWAP not set) this may have to reset the palette for the draw call / texture creation. // Todo: Based on the current tinting flags and the texture type (indexed texture and APPLYOVERPALSWAP not set) this may have to reset the palette for the draw call / texture creation.
bool applied = false; bool applied = false;
@ -264,28 +247,8 @@ void GLInstance::Draw(EDrawType type, size_t start, size_t count)
glVertexAttrib4fv(2, renderState.Color); glVertexAttrib4fv(2, renderState.Color);
if (renderState.Color[3] != 1.f) renderState.Flags &= ~RF_Brightmapping; // The way the colormaps are set up means that brightmaps cannot be used on translucent content at all. if (renderState.Color[3] != 1.f) renderState.Flags &= ~RF_Brightmapping; // The way the colormaps are set up means that brightmaps cannot be used on translucent content at all.
renderState.Apply(polymostShader, lastState); renderState.Apply(polymostShader, lastState);
if (renderState.VertexBuffer != LastVertexBuffer || LastVB_Offset[0] != renderState.VB_Offset[0] || LastVB_Offset[1] != renderState.VB_Offset[1])
{
if (renderState.VertexBuffer)
{
static_cast<OpenGLRenderer::GLVertexBuffer*>(renderState.VertexBuffer)->Bind(renderState.VB_Offset);
} }
else glBindBuffer(GL_ARRAY_BUFFER, 0); if (type != DT_LINES)
LastVertexBuffer = renderState.VertexBuffer;
LastVB_Offset[0] = renderState.VB_Offset[0];
LastVB_Offset[1] = renderState.VB_Offset[1];
}
if (renderState.IndexBuffer != LastIndexBuffer)
{
if (renderState.IndexBuffer)
{
static_cast<OpenGLRenderer::GLIndexBuffer*>(renderState.IndexBuffer)->Bind();
}
else glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0);
LastIndexBuffer = renderState.IndexBuffer;
}
}
if (type != DT_LINES && renderState.IndexBuffer)
{ {
glDrawElements(primtypes[type], count, GL_UNSIGNED_INT, (void*)(intptr_t)(start * sizeof(uint32_t))); glDrawElements(primtypes[type], count, GL_UNSIGNED_INT, (void*)(intptr_t)(start * sizeof(uint32_t)));
} }
@ -293,13 +256,22 @@ void GLInstance::Draw(EDrawType type, size_t start, size_t count)
{ {
glDrawArrays(primtypes[type], start, count); glDrawArrays(primtypes[type], start, count);
} }
if (MatrixChange)
{
if (MatrixChange & 1) SetIdentityMatrix(Matrix_Texture);
if (MatrixChange & 2) SetIdentityMatrix(Matrix_Detail);
MatrixChange = 0;
} }
matrixArray.Resize(1);
void GLInstance::DoDraw()
{
for (auto& rs : rendercommands)
{
// Todo: Based on the current tinting flags and the texture type (indexed texture and APPLYOVERPALSWAP not set) this may have to reset the palette for the draw call / texture creation.
bool applied = false;
glVertexAttrib4fv(2, rs.Color);
if (rs.Color[3] != 1.f) rs.Flags &= ~RF_Brightmapping; // The way the colormaps are set up means that brightmaps cannot be used on translucent content at all.
rs.Apply(polymostShader, lastState);
glDrawArrays(primtypes[rs.primtype], rs.vindex, rs.vcount);
}
rendercommands.Clear();
matrixArray.Clear();
} }

View file

@ -95,34 +95,6 @@ struct glinfo_t {
float maxanisotropy; float maxanisotropy;
}; };
struct BaseVertex
{
float x, y, z;
float u, v;
void SetVertex(float _x, float _y, float _z = 0)
{
x = _x;
y = _y;
z = _z;
}
void SetTexCoord(float _u = 0, float _v = 0)
{
u = _u;
v = _v;
}
void Set(float _x, float _y, float _z = 0, float _u = 0, float _v = 0)
{
x = _x;
y = _y;
z = _z;
u = _u;
v = _v;
}
};
enum EDrawType enum EDrawType
{ {
DT_TRIANGLES, DT_TRIANGLES,
@ -180,7 +152,7 @@ struct GLState
class GLInstance class GLInstance
{ {
std::vector<BaseVertex> Buffer; // cheap-ass implementation. The primary purpose is to get the GL accesses out of polymost.cpp, not writing something performant right away. TArray<PolymostRenderState> rendercommands;
int maxTextureSize; int maxTextureSize;
PaletteManager palmanager; PaletteManager palmanager;
int lastPalswapIndex = -1; int lastPalswapIndex = -1;
@ -193,10 +165,6 @@ class GLInstance
// Cached GL state. // Cached GL state.
GLState lastState; GLState lastState;
IVertexBuffer* LastVertexBuffer = nullptr;
int LastVB_Offset[2] = {};
IIndexBuffer* LastIndexBuffer = nullptr;
float mProjectionM5 = 1.0f; // needed by ssao float mProjectionM5 = 1.0f; // needed by ssao
PolymostRenderState renderState; PolymostRenderState renderState;
FShader* activeShader; FShader* activeShader;
@ -225,9 +193,9 @@ public:
} }
GLInstance(); GLInstance();
std::pair<size_t, BaseVertex *> AllocVertices(size_t num);
void DrawIm(EDrawType type, size_t start, size_t count);
void Draw(EDrawType type, size_t start, size_t count); void Draw(EDrawType type, size_t start, size_t count);
void DoDraw();
void DrawElement(EDrawType type, size_t start, size_t count, PolymostRenderState& renderState);
FHardwareTexture* NewTexture(); FHardwareTexture* NewTexture();
void EnableNonTransparent255(bool on) void EnableNonTransparent255(bool on)
@ -235,16 +203,8 @@ public:
g_nontransparent255 = on; g_nontransparent255 = on;
} }
void SetVertexBuffer(IVertexBuffer* vb, int offset1, int offset2) void SetVertexBuffer(IVertexBuffer* vb, int offset1, int offset2);
{ void SetIndexBuffer(IIndexBuffer* vb);
renderState.VertexBuffer = vb;
renderState.VB_Offset[0] = offset1;
renderState.VB_Offset[1] = offset2;
}
void SetIndexBuffer(IIndexBuffer* vb)
{
renderState.IndexBuffer = vb;
}
void ClearBufferState(); void ClearBufferState();
float GetProjectionM5() { return mProjectionM5; } float GetProjectionM5() { return mProjectionM5; }
@ -542,18 +502,18 @@ public:
FHardwareTexture* CreateIndexedTexture(FTexture* tex); FHardwareTexture* CreateIndexedTexture(FTexture* tex);
FHardwareTexture* CreateTrueColorTexture(FTexture* tex, int palid, bool checkfulltransparency = false, bool rgb8bit = false); FHardwareTexture* CreateTrueColorTexture(FTexture* tex, int palid, bool checkfulltransparency = false, bool rgb8bit = false);
FHardwareTexture *LoadTexture(FTexture* tex, int texturetype, int palid); FHardwareTexture *LoadTexture(FTexture* tex, int texturetype, int palid);
bool SetTextureInternal(int globalpicnum, FTexture* tex, int palette, int method, int sampleroverride, float xpanning, float ypanning, FTexture *det, float detscale, FTexture *glow); bool SetTextureInternal(int globalpicnum, FTexture* tex, int palette, int method, int sampleroverride, FTexture *det, float detscale, FTexture *glow);
bool SetNamedTexture(FTexture* tex, int palette, int sampleroverride); bool SetNamedTexture(FTexture* tex, int palette, int sampleroverride);
bool SetTexture(int globalpicnum, FTexture* tex, int palette, int method, int sampleroverride) bool SetTexture(int globalpicnum, FTexture* tex, int palette, int method, int sampleroverride)
{ {
return SetTextureInternal(globalpicnum, tex, palette, method, sampleroverride, 0, 0, nullptr, 1, nullptr); return SetTextureInternal(globalpicnum, tex, palette, method, sampleroverride, nullptr, 1, nullptr);
} }
bool SetModelTexture(FTexture *tex, int palette, float xpanning, float ypanning, FTexture *det, float detscale, FTexture *glow) bool SetModelTexture(FTexture *tex, int palette, FTexture *det, float detscale, FTexture *glow)
{ {
return SetTextureInternal(-1, tex, palette, 8/*DAMETH_MODEL*/, -1, xpanning, ypanning, det, detscale, glow); return SetTextureInternal(-1, tex, palette, 8/*DAMETH_MODEL*/, -1, det, detscale, glow);
} }
}; };

View file

@ -191,11 +191,11 @@ void GLInstance::Draw2D(F2DDrawer *drawer)
{ {
case F2DDrawer::DrawTypeTriangles: case F2DDrawer::DrawTypeTriangles:
case F2DDrawer::DrawTypeRotateSprite: case F2DDrawer::DrawTypeRotateSprite:
Draw(DT_TRIANGLES, cmd.mIndexIndex, cmd.mIndexCount); DrawElement(DT_TRIANGLES, cmd.mIndexIndex, cmd.mIndexCount, renderState);
break; break;
case F2DDrawer::DrawTypeLines: case F2DDrawer::DrawTypeLines:
Draw(DT_LINES, cmd.mVertIndex, cmd.mVertCount); DrawElement(DT_LINES, cmd.mVertIndex, cmd.mVertCount, renderState);
break; break;
case F2DDrawer::DrawTypePoints: case F2DDrawer::DrawTypePoints:

View file

@ -405,7 +405,7 @@ bool Win32GLVideo::InitHardware(HWND Window, int multisample)
int prof = WGL_CONTEXT_CORE_PROFILE_BIT_ARB; int prof = WGL_CONTEXT_CORE_PROFILE_BIT_ARB;
const char *version = Args->CheckValue("-glversion"); const char *version = Args->CheckValue("-glversion");
prof = WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB; // At the moment the renderer still needs the compatibility profile. //prof = WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB; // At the moment the renderer still needs the compatibility profile.
for (; prof <= WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB; prof++) for (; prof <= WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB; prof++)
{ {