mirror of
https://github.com/ZDoom/gzdoom.git
synced 2025-01-19 08:01:50 +00:00
Add palette support
This commit is contained in:
parent
7ac0cace7d
commit
6761e8639a
14 changed files with 94 additions and 19 deletions
|
@ -258,7 +258,18 @@ void DrawTriangleCodegen::LoopBlockX()
|
||||||
SSAFloat shade = 64.0f - (SSAFloat(light * 255 / 256) + 12.0f) * 32.0f / 128.0f;
|
SSAFloat shade = 64.0f - (SSAFloat(light * 255 / 256) + 12.0f) * 32.0f / 128.0f;
|
||||||
SSAFloat lightscale = SSAFloat::clamp((shade - SSAFloat::MIN(SSAFloat(24.0f), vis)) / 32.0f, SSAFloat(0.0f), SSAFloat(31.0f / 32.0f));
|
SSAFloat lightscale = SSAFloat::clamp((shade - SSAFloat::MIN(SSAFloat(24.0f), vis)) / 32.0f, SSAFloat(0.0f), SSAFloat(31.0f / 32.0f));
|
||||||
SSAInt diminishedlight = SSAInt(SSAFloat::clamp((1.0f - lightscale) * 256.0f + 0.5f, SSAFloat(0.0f), SSAFloat(256.0f)), false);
|
SSAInt diminishedlight = SSAInt(SSAFloat::clamp((1.0f - lightscale) * 256.0f + 0.5f, SSAFloat(0.0f), SSAFloat(256.0f)), false);
|
||||||
currentlight = is_fixed_light.select(light, diminishedlight);
|
|
||||||
|
if (!truecolor)
|
||||||
|
{
|
||||||
|
SSAInt diminishedindex = SSAInt(lightscale * 32.0f, false);
|
||||||
|
SSAInt lightindex = SSAInt::MIN((256 - light) * 32 / 256, SSAInt(31));
|
||||||
|
SSAInt colormapindex = is_fixed_light.select(lightindex, diminishedindex);
|
||||||
|
currentcolormap = Colormaps[colormapindex << 8];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
currentlight = is_fixed_light.select(light, diminishedlight);
|
||||||
|
}
|
||||||
|
|
||||||
SetStencilBlock(x / 8 + y / 8 * stencilPitch);
|
SetStencilBlock(x / 8 + y / 8 * stencilPitch);
|
||||||
|
|
||||||
|
@ -352,25 +363,32 @@ void DrawTriangleCodegen::LoopFullBlock()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
SSAVec4i pixels = buf.load_vec4ub(false);
|
SSAVec4i pixelsvec = buf.load_vec4ub(false);
|
||||||
|
SSAInt pixels[4] =
|
||||||
|
{
|
||||||
|
pixelsvec[0],
|
||||||
|
pixelsvec[1],
|
||||||
|
pixelsvec[2],
|
||||||
|
pixelsvec[3]
|
||||||
|
};
|
||||||
|
|
||||||
for (int sse = 0; sse < 4; sse++)
|
for (int sse = 0; sse < 4; sse++)
|
||||||
{
|
{
|
||||||
if (variant == TriDrawVariant::DrawSubsector || variant == TriDrawVariant::FillSubsector || variant == TriDrawVariant::FuzzSubsector)
|
if (variant == TriDrawVariant::DrawSubsector || variant == TriDrawVariant::FillSubsector || variant == TriDrawVariant::FuzzSubsector)
|
||||||
{
|
{
|
||||||
SSABool subsectorTest = subsectorbuffer[ix].load(true) >= subsectorDepth;
|
SSABool subsectorTest = subsectorbuffer[ix].load(true) >= subsectorDepth;
|
||||||
pixels.insert(sse, subsectorTest.select(ProcessPixel8(pixels[sse], varying), pixels[sse]));
|
pixels[sse] = subsectorTest.select(ProcessPixel8(pixels[sse], varying), pixels[sse]);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pixels.insert(sse, ProcessPixel8(pixels[sse], varying));
|
pixels[sse] = ProcessPixel8(pixels[sse], varying);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < TriVertex::NumVarying; i++)
|
for (int i = 0; i < TriVertex::NumVarying; i++)
|
||||||
varying[i] = varying[i] + varyingStep[i];
|
varying[i] = varying[i] + varyingStep[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
buf.store_vec4ub(pixels);
|
buf.store_vec4ub(SSAVec4i(pixels[0], pixels[1], pixels[2], pixels[3]));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (variant != TriDrawVariant::DrawSubsector && variant != TriDrawVariant::FillSubsector && variant != TriDrawVariant::FuzzSubsector)
|
if (variant != TriDrawVariant::DrawSubsector && variant != TriDrawVariant::FillSubsector && variant != TriDrawVariant::FuzzSubsector)
|
||||||
|
@ -580,12 +598,16 @@ SSAInt DrawTriangleCodegen::ProcessPixel8(SSAInt bg, SSAInt *varying)
|
||||||
|
|
||||||
if (variant == TriDrawVariant::FillNormal || variant == TriDrawVariant::FillSubsector || variant == TriDrawVariant::FuzzSubsector)
|
if (variant == TriDrawVariant::FillNormal || variant == TriDrawVariant::FillSubsector || variant == TriDrawVariant::FuzzSubsector)
|
||||||
{
|
{
|
||||||
return color;
|
return currentcolormap[color].load(true).zext_int();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
SSAUByte fg = texturePixels[uvoffset].load(true);
|
SSAInt index = texturePixels[uvoffset].load(true).zext_int();
|
||||||
return fg.zext_int();
|
SSAInt fg = currentcolormap[index].load(true).zext_int();
|
||||||
|
if (blendmode != TriBlendMode::AlphaBlend)
|
||||||
|
return fg;
|
||||||
|
else
|
||||||
|
return (index == SSAInt(0)).select(bg, fg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -659,6 +681,14 @@ void DrawTriangleCodegen::LoadArgs(SSAValue args, SSAValue thread_data)
|
||||||
stencilTestValue = args[0][17].load(true);
|
stencilTestValue = args[0][17].load(true);
|
||||||
stencilWriteValue = args[0][18].load(true);
|
stencilWriteValue = args[0][18].load(true);
|
||||||
subsectorGBuffer = args[0][19].load(true);
|
subsectorGBuffer = args[0][19].load(true);
|
||||||
|
if (!truecolor)
|
||||||
|
{
|
||||||
|
Colormaps = args[0][20].load(true);
|
||||||
|
RGB32k = args[0][21].load(true);
|
||||||
|
Col2RGB8 = args[0][22].load(true);
|
||||||
|
Col2RGB8_LessPrecision = args[0][23].load(true);
|
||||||
|
Col2RGB8_Inverse = args[0][24].load(true);
|
||||||
|
}
|
||||||
|
|
||||||
thread.core = thread_data[0][0].load(true);
|
thread.core = thread_data[0][0].load(true);
|
||||||
thread.num_cores = thread_data[0][1].load(true);
|
thread.num_cores = thread_data[0][1].load(true);
|
||||||
|
|
|
@ -107,6 +107,12 @@ private:
|
||||||
SSAUByte stencilWriteValue;
|
SSAUByte stencilWriteValue;
|
||||||
SSAIntPtr subsectorGBuffer;
|
SSAIntPtr subsectorGBuffer;
|
||||||
|
|
||||||
|
SSAUBytePtr Colormaps;
|
||||||
|
SSAUBytePtr RGB32k;
|
||||||
|
SSAIntPtr Col2RGB8;
|
||||||
|
SSAIntPtr Col2RGB8_LessPrecision;
|
||||||
|
SSAIntPtr Col2RGB8_Inverse;
|
||||||
|
|
||||||
SSAWorkerThread thread;
|
SSAWorkerThread thread;
|
||||||
|
|
||||||
// Block size, standard 8x8 (must be power of two)
|
// Block size, standard 8x8 (must be power of two)
|
||||||
|
@ -126,6 +132,7 @@ private:
|
||||||
SSAInt x, y;
|
SSAInt x, y;
|
||||||
SSAInt x0, x1, y0, y1;
|
SSAInt x0, x1, y0, y1;
|
||||||
SSAInt currentlight;
|
SSAInt currentlight;
|
||||||
|
SSAUBytePtr currentcolormap;
|
||||||
SSAInt varyingPos[TriVertex::NumVarying];
|
SSAInt varyingPos[TriVertex::NumVarying];
|
||||||
SSAInt varyingStepPos[TriVertex::NumVarying];
|
SSAInt varyingStepPos[TriVertex::NumVarying];
|
||||||
SSAInt varyingStartStepX[TriVertex::NumVarying];
|
SSAInt varyingStartStepX[TriVertex::NumVarying];
|
||||||
|
|
|
@ -127,7 +127,7 @@ LLVMDrawers *LLVMDrawers::Instance()
|
||||||
|
|
||||||
LLVMDrawersImpl::LLVMDrawersImpl()
|
LLVMDrawersImpl::LLVMDrawersImpl()
|
||||||
{
|
{
|
||||||
int version = 2; // Increment this number if the drawer codegen is modified (forces recreation of the module).
|
int version = 3; // Increment this number if the drawer codegen is modified (forces recreation of the module).
|
||||||
std::string targetCPU = mProgram.GetTargetCPU();
|
std::string targetCPU = mProgram.GetTargetCPU();
|
||||||
bool loaded = mProgram.LoadCachedModule(version, targetCPU);
|
bool loaded = mProgram.LoadCachedModule(version, targetCPU);
|
||||||
if (!loaded)
|
if (!loaded)
|
||||||
|
@ -582,6 +582,11 @@ llvm::Type *LLVMDrawersImpl::GetTriDrawTriangleArgs(llvm::LLVMContext &context)
|
||||||
elements.push_back(llvm::Type::getInt8Ty(context)); // uint8_t stencilTestValue;
|
elements.push_back(llvm::Type::getInt8Ty(context)); // uint8_t stencilTestValue;
|
||||||
elements.push_back(llvm::Type::getInt8Ty(context)); // uint8_t stencilWriteValue;
|
elements.push_back(llvm::Type::getInt8Ty(context)); // uint8_t stencilWriteValue;
|
||||||
elements.push_back(llvm::Type::getInt32PtrTy(context)); // uint32_t *subsectorGBuffer;
|
elements.push_back(llvm::Type::getInt32PtrTy(context)); // uint32_t *subsectorGBuffer;
|
||||||
|
elements.push_back(llvm::Type::getInt8PtrTy(context)); // const uint8_t *colormaps;
|
||||||
|
elements.push_back(llvm::Type::getInt8PtrTy(context)); // const uint8_t *RGB32k;
|
||||||
|
elements.push_back(llvm::Type::getInt32PtrTy(context)); // const uint32_t *Col2RGB8;
|
||||||
|
elements.push_back(llvm::Type::getInt32PtrTy(context)); // const uint32_t *Col2RGB8_LessPrecision;
|
||||||
|
elements.push_back(llvm::Type::getInt32PtrTy(context)); // const uint32_t *Col2RGB8_Inverse;
|
||||||
return llvm::StructType::create(context, elements, "TriDrawTriangle", false)->getPointerTo();
|
return llvm::StructType::create(context, elements, "TriDrawTriangle", false)->getPointerTo();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -258,6 +258,11 @@ struct TriDrawTriangleArgs
|
||||||
uint8_t stencilTestValue;
|
uint8_t stencilTestValue;
|
||||||
uint8_t stencilWriteValue;
|
uint8_t stencilWriteValue;
|
||||||
uint32_t *subsectorGBuffer;
|
uint32_t *subsectorGBuffer;
|
||||||
|
const uint8_t *colormaps;
|
||||||
|
const uint8_t *RGB32k;
|
||||||
|
const uint32_t *Col2RGB8;
|
||||||
|
const uint32_t *Col2RGB8_LessPrecision;
|
||||||
|
const uint32_t *Col2RGB8_Inverse;
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class TriDrawVariant
|
enum class TriDrawVariant
|
||||||
|
|
|
@ -36,9 +36,6 @@ void InitGLRMapinfoData();
|
||||||
|
|
||||||
void RenderPolyScene::Render()
|
void RenderPolyScene::Render()
|
||||||
{
|
{
|
||||||
if (!r_swtruecolor) // Disable pal rendering for now
|
|
||||||
return;
|
|
||||||
|
|
||||||
ClearBuffers();
|
ClearBuffers();
|
||||||
SetSceneViewport();
|
SetSceneViewport();
|
||||||
SetupPerspectiveMatrix();
|
SetupPerspectiveMatrix();
|
||||||
|
@ -63,8 +60,8 @@ void RenderPolyScene::ClearBuffers()
|
||||||
SectorSpriteRanges.resize(numsectors);
|
SectorSpriteRanges.resize(numsectors);
|
||||||
SortedSprites.clear();
|
SortedSprites.clear();
|
||||||
TranslucentObjects.clear();
|
TranslucentObjects.clear();
|
||||||
PolyStencilBuffer::Instance()->Clear(screen->GetWidth(), screen->GetHeight(), 0);
|
PolyStencilBuffer::Instance()->Clear(RenderTarget->GetWidth(), RenderTarget->GetHeight(), 0);
|
||||||
PolySubsectorGBuffer::Instance()->Resize(screen->GetPitch(), screen->GetHeight());
|
PolySubsectorGBuffer::Instance()->Resize(RenderTarget->GetPitch(), RenderTarget->GetHeight());
|
||||||
NextSubsectorDepth = 0;
|
NextSubsectorDepth = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,7 +74,7 @@ void RenderPolyScene::SetSceneViewport()
|
||||||
height = (screenblocks*SCREENHEIGHT / 10) & ~7;
|
height = (screenblocks*SCREENHEIGHT / 10) & ~7;
|
||||||
|
|
||||||
int bottom = SCREENHEIGHT - (height + viewwindowy - ((height - viewheight) / 2));
|
int bottom = SCREENHEIGHT - (height + viewwindowy - ((height - viewheight) / 2));
|
||||||
PolyTriangleDrawer::set_viewport(viewwindowx, SCREENHEIGHT - bottom - height, viewwidth, height, screen);
|
PolyTriangleDrawer::set_viewport(viewwindowx, SCREENHEIGHT - bottom - height, viewwidth, height, RenderTarget);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RenderPolyScene::SetupPerspectiveMatrix()
|
void RenderPolyScene::SetupPerspectiveMatrix()
|
||||||
|
|
|
@ -152,6 +152,7 @@ void RenderPolyDecal::Render(const TriMatrix &worldToClip, DBaseDecal *decal, co
|
||||||
args.stenciltestvalue = 0;
|
args.stenciltestvalue = 0;
|
||||||
args.stencilwritevalue = 1;
|
args.stencilwritevalue = 1;
|
||||||
args.SetTexture(tex);
|
args.SetTexture(tex);
|
||||||
|
args.SetColormap(line->frontsector->ColorMap);
|
||||||
//mode = R_SetPatchStyle (decal->RenderStyle, (float)decal->Alpha, decal->Translation, decal->AlphaColor);
|
//mode = R_SetPatchStyle (decal->RenderStyle, (float)decal->Alpha, decal->Translation, decal->AlphaColor);
|
||||||
PolyTriangleDrawer::draw(args, TriDrawVariant::DrawSubsector, TriBlendMode::Shaded);
|
PolyTriangleDrawer::draw(args, TriDrawVariant::DrawSubsector, TriBlendMode::Shaded);
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,5 +94,6 @@ void RenderPolyParticle::Render(const TriMatrix &worldToClip, particle_t *partic
|
||||||
args.ccw = true;
|
args.ccw = true;
|
||||||
args.stenciltestvalue = 0;
|
args.stenciltestvalue = 0;
|
||||||
args.stencilwritevalue = 1;
|
args.stencilwritevalue = 1;
|
||||||
|
args.SetColormap(sub->sector->ColorMap);
|
||||||
PolyTriangleDrawer::draw(args, TriDrawVariant::FillSubsector, TriBlendMode::AlphaBlend);
|
PolyTriangleDrawer::draw(args, TriDrawVariant::FillSubsector, TriBlendMode::AlphaBlend);
|
||||||
}
|
}
|
||||||
|
|
|
@ -140,6 +140,7 @@ void RenderPolyPlane::Render3DFloor(const TriMatrix &worldToClip, subsector_t *s
|
||||||
args.stenciltestvalue = 0;
|
args.stenciltestvalue = 0;
|
||||||
args.stencilwritevalue = 1;
|
args.stencilwritevalue = 1;
|
||||||
args.SetTexture(tex);
|
args.SetTexture(tex);
|
||||||
|
args.SetColormap(sub->sector->ColorMap);
|
||||||
PolyTriangleDrawer::draw(args, TriDrawVariant::DrawNormal, TriBlendMode::Copy);
|
PolyTriangleDrawer::draw(args, TriDrawVariant::DrawNormal, TriBlendMode::Copy);
|
||||||
PolyTriangleDrawer::draw(args, TriDrawVariant::Stencil, TriBlendMode::Copy);
|
PolyTriangleDrawer::draw(args, TriDrawVariant::Stencil, TriBlendMode::Copy);
|
||||||
}
|
}
|
||||||
|
@ -231,6 +232,7 @@ void RenderPolyPlane::Render(const TriMatrix &worldToClip, subsector_t *sub, uin
|
||||||
args.ccw = ccw;
|
args.ccw = ccw;
|
||||||
args.stenciltestvalue = 0;
|
args.stenciltestvalue = 0;
|
||||||
args.stencilwritevalue = 1;
|
args.stencilwritevalue = 1;
|
||||||
|
args.SetColormap(frontsector->ColorMap);
|
||||||
|
|
||||||
if (!isSky)
|
if (!isSky)
|
||||||
{
|
{
|
||||||
|
|
|
@ -63,6 +63,7 @@ void PolySkyDome::Render(const TriMatrix &worldToClip)
|
||||||
args.stenciltestvalue = 255;
|
args.stenciltestvalue = 255;
|
||||||
args.stencilwritevalue = 1;
|
args.stencilwritevalue = 1;
|
||||||
args.SetTexture(frontskytex);
|
args.SetTexture(frontskytex);
|
||||||
|
args.SetColormap(&NormalLight);
|
||||||
|
|
||||||
RenderCapColorRow(args, frontskytex, 0, false);
|
RenderCapColorRow(args, frontskytex, 0, false);
|
||||||
RenderCapColorRow(args, frontskytex, rc, true);
|
RenderCapColorRow(args, frontskytex, rc, true);
|
||||||
|
|
|
@ -136,6 +136,7 @@ void RenderPolySprite::Render(const TriMatrix &worldToClip, AActor *thing, subse
|
||||||
args.stenciltestvalue = 0;
|
args.stenciltestvalue = 0;
|
||||||
args.stencilwritevalue = 1;
|
args.stencilwritevalue = 1;
|
||||||
args.SetTexture(tex, thing->Translation);
|
args.SetTexture(tex, thing->Translation);
|
||||||
|
args.SetColormap(sub->sector->ColorMap);
|
||||||
|
|
||||||
if (args.translation)
|
if (args.translation)
|
||||||
PolyTriangleDrawer::draw(args, TriDrawVariant::DrawSubsector, TriBlendMode::TranslateAlphaBlend);
|
PolyTriangleDrawer::draw(args, TriDrawVariant::DrawSubsector, TriBlendMode::TranslateAlphaBlend);
|
||||||
|
|
|
@ -70,10 +70,7 @@ void PolyTriangleDrawer::set_viewport(int x, int y, int width, int height, DCanv
|
||||||
|
|
||||||
void PolyTriangleDrawer::draw(const PolyDrawArgs &args, TriDrawVariant variant, TriBlendMode blendmode)
|
void PolyTriangleDrawer::draw(const PolyDrawArgs &args, TriDrawVariant variant, TriBlendMode blendmode)
|
||||||
{
|
{
|
||||||
if (dest_bgra)
|
DrawerCommandQueue::QueueCommand<DrawPolyTrianglesCommand>(args, variant, blendmode);
|
||||||
DrawerCommandQueue::QueueCommand<DrawPolyTrianglesCommand>(args, variant, blendmode);
|
|
||||||
else
|
|
||||||
draw_arrays(args, variant, blendmode, nullptr);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void PolyTriangleDrawer::draw_arrays(const PolyDrawArgs &drawargs, TriDrawVariant variant, TriBlendMode blendmode, WorkerThreadData *thread)
|
void PolyTriangleDrawer::draw_arrays(const PolyDrawArgs &drawargs, TriDrawVariant variant, TriBlendMode blendmode, WorkerThreadData *thread)
|
||||||
|
@ -113,6 +110,11 @@ void PolyTriangleDrawer::draw_arrays(const PolyDrawArgs &drawargs, TriDrawVarian
|
||||||
args.stencilValues = PolyStencilBuffer::Instance()->Values();
|
args.stencilValues = PolyStencilBuffer::Instance()->Values();
|
||||||
args.stencilMasks = PolyStencilBuffer::Instance()->Masks();
|
args.stencilMasks = PolyStencilBuffer::Instance()->Masks();
|
||||||
args.subsectorGBuffer = PolySubsectorGBuffer::Instance()->Values();
|
args.subsectorGBuffer = PolySubsectorGBuffer::Instance()->Values();
|
||||||
|
args.colormaps = drawargs.colormaps;
|
||||||
|
args.RGB32k = RGB32k.All;
|
||||||
|
args.Col2RGB8 = (const uint32_t*)Col2RGB8;
|
||||||
|
args.Col2RGB8_Inverse = (const uint32_t*)Col2RGB8_Inverse;
|
||||||
|
args.Col2RGB8_LessPrecision = (const uint32_t*)Col2RGB8_LessPrecision;
|
||||||
|
|
||||||
bool ccw = drawargs.ccw;
|
bool ccw = drawargs.ccw;
|
||||||
const TriVertex *vinput = drawargs.vinput;
|
const TriVertex *vinput = drawargs.vinput;
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
#include "r_thread.h"
|
#include "r_thread.h"
|
||||||
#include "r_compiler/llvmdrawers.h"
|
#include "r_compiler/llvmdrawers.h"
|
||||||
#include "r_data/r_translate.h"
|
#include "r_data/r_translate.h"
|
||||||
|
#include "r_data/colormaps.h"
|
||||||
|
|
||||||
class FTexture;
|
class FTexture;
|
||||||
|
|
||||||
|
@ -53,6 +54,7 @@ public:
|
||||||
const uint8_t *translation = nullptr;
|
const uint8_t *translation = nullptr;
|
||||||
uint8_t stenciltestvalue = 0;
|
uint8_t stenciltestvalue = 0;
|
||||||
uint8_t stencilwritevalue = 0;
|
uint8_t stencilwritevalue = 0;
|
||||||
|
const uint8_t *colormaps = nullptr;
|
||||||
|
|
||||||
void SetTexture(FTexture *texture)
|
void SetTexture(FTexture *texture)
|
||||||
{
|
{
|
||||||
|
@ -86,6 +88,25 @@ public:
|
||||||
|
|
||||||
SetTexture(texture);
|
SetTexture(texture);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SetColormap(FSWColormap *base_colormap)
|
||||||
|
{
|
||||||
|
uniforms.light_red = base_colormap->Color.r * 256 / 255;
|
||||||
|
uniforms.light_green = base_colormap->Color.g * 256 / 255;
|
||||||
|
uniforms.light_blue = base_colormap->Color.b * 256 / 255;
|
||||||
|
uniforms.light_alpha = base_colormap->Color.a * 256 / 255;
|
||||||
|
uniforms.fade_red = base_colormap->Fade.r;
|
||||||
|
uniforms.fade_green = base_colormap->Fade.g;
|
||||||
|
uniforms.fade_blue = base_colormap->Fade.b;
|
||||||
|
uniforms.fade_alpha = base_colormap->Fade.a;
|
||||||
|
uniforms.desaturate = MIN(abs(base_colormap->Desaturate), 255) * 255 / 256;
|
||||||
|
bool simple_shade = (base_colormap->Color.d == 0x00ffffff && base_colormap->Fade.d == 0x00000000 && base_colormap->Desaturate == 0);
|
||||||
|
if (simple_shade)
|
||||||
|
uniforms.flags |= TriUniforms::simple_shade;
|
||||||
|
else
|
||||||
|
uniforms.flags &= ~TriUniforms::simple_shade;
|
||||||
|
colormaps = base_colormap->Maps;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class PolyTriangleDrawer
|
class PolyTriangleDrawer
|
||||||
|
|
|
@ -190,6 +190,7 @@ void RenderPolyWall::Render(const TriMatrix &worldToClip)
|
||||||
args.stenciltestvalue = 0;
|
args.stenciltestvalue = 0;
|
||||||
args.stencilwritevalue = 1;
|
args.stencilwritevalue = 1;
|
||||||
args.SetTexture(tex);
|
args.SetTexture(tex);
|
||||||
|
args.SetColormap(Line->frontsector->ColorMap);
|
||||||
|
|
||||||
if (!Masked)
|
if (!Masked)
|
||||||
{
|
{
|
||||||
|
|
|
@ -121,5 +121,6 @@ void RenderPolyWallSprite::Render(const TriMatrix &worldToClip, AActor *thing, s
|
||||||
args.stenciltestvalue = 0;
|
args.stenciltestvalue = 0;
|
||||||
args.stencilwritevalue = 1;
|
args.stencilwritevalue = 1;
|
||||||
args.SetTexture(tex);
|
args.SetTexture(tex);
|
||||||
|
args.SetColormap(sub->sector->ColorMap);
|
||||||
PolyTriangleDrawer::draw(args, TriDrawVariant::DrawSubsector, TriBlendMode::AlphaBlend);
|
PolyTriangleDrawer::draw(args, TriDrawVariant::DrawSubsector, TriBlendMode::AlphaBlend);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue