2016-03-01 15:47:10 +00:00
|
|
|
/*
|
|
|
|
** r_swrender.cpp
|
|
|
|
** Software renderer interface
|
|
|
|
**
|
|
|
|
**---------------------------------------------------------------------------
|
|
|
|
** Copyright 2011 Christoph Oelckers
|
|
|
|
** All rights reserved.
|
|
|
|
**
|
|
|
|
** Redistribution and use in source and binary forms, with or without
|
|
|
|
** modification, are permitted provided that the following conditions
|
|
|
|
** are met:
|
|
|
|
**
|
|
|
|
** 1. Redistributions of source code must retain the above copyright
|
|
|
|
** notice, this list of conditions and the following disclaimer.
|
|
|
|
** 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
** notice, this list of conditions and the following disclaimer in the
|
|
|
|
** documentation and/or other materials provided with the distribution.
|
|
|
|
** 3. The name of the author may not be used to endorse or promote products
|
|
|
|
** derived from this software without specific prior written permission.
|
|
|
|
**
|
|
|
|
** THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
** IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
** OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
** IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
** INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
** NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
** THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
**---------------------------------------------------------------------------
|
|
|
|
**
|
|
|
|
*/
|
|
|
|
|
2017-01-12 15:21:46 +00:00
|
|
|
#include "swrenderer/scene/r_scene.h"
|
2017-02-02 14:10:06 +00:00
|
|
|
#include "swrenderer/viewport/r_viewport.h"
|
2016-12-31 11:45:07 +00:00
|
|
|
#include "swrenderer/things/r_playersprite.h"
|
2017-01-12 15:21:46 +00:00
|
|
|
#include "swrenderer/scene/r_scene.h"
|
|
|
|
#include "swrenderer/scene/r_light.h"
|
2018-03-27 08:34:21 +00:00
|
|
|
#include "swrenderer/r_swcolormaps.h"
|
2016-03-01 15:47:10 +00:00
|
|
|
#include "v_palette.h"
|
|
|
|
#include "v_video.h"
|
|
|
|
#include "m_png.h"
|
|
|
|
#include "r_swrenderer.h"
|
2017-01-11 19:42:39 +00:00
|
|
|
#include "scene/r_opaque_pass.h"
|
2016-12-27 05:31:55 +00:00
|
|
|
#include "scene/r_3dfloors.h"
|
2017-01-05 03:55:26 +00:00
|
|
|
#include "scene/r_portal.h"
|
2016-03-01 15:47:10 +00:00
|
|
|
#include "textures/textures.h"
|
|
|
|
#include "r_data/voxels.h"
|
2016-12-27 05:31:55 +00:00
|
|
|
#include "drawers/r_draw_rgba.h"
|
|
|
|
#include "polyrenderer/poly_renderer.h"
|
2016-11-30 23:42:14 +00:00
|
|
|
#include "p_setup.h"
|
2017-03-15 21:04:23 +00:00
|
|
|
#include "g_levellocals.h"
|
2016-03-01 15:47:10 +00:00
|
|
|
|
2017-03-19 04:31:30 +00:00
|
|
|
// [BB] Use ZDoom's freelook limit for the sotfware renderer.
|
|
|
|
// Note: ZDoom's limit is chosen such that the sky is rendered properly.
|
|
|
|
CUSTOM_CVAR (Bool, cl_oldfreelooklimit, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG | CVAR_NOINITCALL)
|
|
|
|
{
|
|
|
|
if (usergame) // [SP] Update pitch limits to the netgame/gamesim.
|
|
|
|
players[consoleplayer].SendPitchLimits();
|
|
|
|
}
|
|
|
|
|
2017-07-30 14:44:49 +00:00
|
|
|
EXTERN_CVAR(Float, maxviewpitch) // [SP] CVAR from OpenGL Renderer
|
|
|
|
EXTERN_CVAR(Bool, r_drawvoxels)
|
2016-03-01 15:47:10 +00:00
|
|
|
|
2016-12-01 01:38:32 +00:00
|
|
|
using namespace swrenderer;
|
|
|
|
|
2016-09-29 00:10:14 +00:00
|
|
|
FSoftwareRenderer::FSoftwareRenderer()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2018-04-03 22:21:25 +00:00
|
|
|
void FSoftwareRenderer::Init()
|
2016-09-29 00:10:14 +00:00
|
|
|
{
|
2018-03-31 17:20:59 +00:00
|
|
|
R_InitShadeMaps();
|
|
|
|
InitSWColorMaps();
|
2016-09-29 00:10:14 +00:00
|
|
|
}
|
|
|
|
|
2018-04-03 18:14:26 +00:00
|
|
|
FRenderer *CreateSWRenderer()
|
2016-03-01 15:47:10 +00:00
|
|
|
{
|
2018-04-03 18:14:26 +00:00
|
|
|
return new FSoftwareRenderer;
|
2016-03-01 15:47:10 +00:00
|
|
|
}
|
|
|
|
|
2018-12-06 19:12:15 +00:00
|
|
|
void FSoftwareRenderer::PrecacheTexture(FTexture *ttex, int cache)
|
2016-03-01 15:47:10 +00:00
|
|
|
{
|
2018-04-07 21:30:28 +00:00
|
|
|
bool isbgra = V_IsTrueColor();
|
2017-01-15 00:36:57 +00:00
|
|
|
|
2018-12-06 23:04:39 +00:00
|
|
|
if (ttex != NULL && ttex->isValid())
|
2016-03-01 15:47:10 +00:00
|
|
|
{
|
2018-12-06 19:12:15 +00:00
|
|
|
FSoftwareTexture *tex = ttex->GetSoftwareTexture();
|
2016-03-01 15:47:10 +00:00
|
|
|
if (cache & FTextureManager::HIT_Columnmode)
|
|
|
|
{
|
2018-12-06 00:11:04 +00:00
|
|
|
const FSoftwareTextureSpan *spanp;
|
2017-01-15 00:36:57 +00:00
|
|
|
if (isbgra)
|
2016-06-13 01:16:48 +00:00
|
|
|
tex->GetColumnBgra(0, &spanp);
|
2016-06-13 19:39:55 +00:00
|
|
|
else
|
2018-03-18 20:33:44 +00:00
|
|
|
tex->GetColumn(DefaultRenderStyle(), 0, &spanp);
|
2016-03-01 15:47:10 +00:00
|
|
|
}
|
|
|
|
else if (cache != 0)
|
|
|
|
{
|
2017-01-15 00:36:57 +00:00
|
|
|
if (isbgra)
|
2016-06-14 21:05:20 +00:00
|
|
|
tex->GetPixelsBgra();
|
2016-06-13 01:16:48 +00:00
|
|
|
else
|
2018-03-18 20:33:44 +00:00
|
|
|
tex->GetPixels (DefaultRenderStyle());
|
2016-03-01 15:47:10 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
tex->Unload ();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-09 18:54:41 +00:00
|
|
|
void FSoftwareRenderer::Precache(uint8_t *texhitlist, TMap<PClassActor*, bool> &actorhitlist)
|
2016-05-01 20:47:36 +00:00
|
|
|
{
|
2017-03-09 18:54:41 +00:00
|
|
|
uint8_t *spritelist = new uint8_t[sprites.Size()];
|
2016-05-01 20:47:36 +00:00
|
|
|
TMap<PClassActor*, bool>::Iterator it(actorhitlist);
|
|
|
|
TMap<PClassActor*, bool>::Pair *pair;
|
|
|
|
|
|
|
|
memset(spritelist, 0, sprites.Size());
|
|
|
|
|
|
|
|
while (it.NextPair(pair))
|
|
|
|
{
|
|
|
|
PClassActor *cls = pair->Key;
|
|
|
|
|
2017-04-11 22:07:41 +00:00
|
|
|
for (unsigned i = 0; i < cls->GetStateCount(); i++)
|
2016-05-01 20:47:36 +00:00
|
|
|
{
|
2017-04-11 22:07:41 +00:00
|
|
|
spritelist[cls->GetStates()[i].sprite] = true;
|
2016-05-01 20:47:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Precache textures (and sprites).
|
|
|
|
|
|
|
|
for (int i = (int)(sprites.Size() - 1); i >= 0; i--)
|
|
|
|
{
|
|
|
|
if (spritelist[i])
|
|
|
|
{
|
|
|
|
int j, k;
|
|
|
|
for (j = 0; j < sprites[i].numframes; j++)
|
|
|
|
{
|
|
|
|
const spriteframe_t *frame = &SpriteFrames[sprites[i].spriteframes + j];
|
|
|
|
|
|
|
|
for (k = 0; k < 16; k++)
|
|
|
|
{
|
|
|
|
FTextureID pic = frame->Texture[k];
|
|
|
|
if (pic.isValid())
|
|
|
|
{
|
|
|
|
texhitlist[pic.GetIndex()] = FTextureManager::HIT_Sprite;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
delete[] spritelist;
|
|
|
|
|
|
|
|
int cnt = TexMan.NumTextures();
|
|
|
|
for (int i = cnt - 1; i >= 0; i--)
|
|
|
|
{
|
|
|
|
PrecacheTexture(TexMan.ByIndex(i), texhitlist[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-20 03:48:15 +00:00
|
|
|
void FSoftwareRenderer::RenderView(player_t *player, DCanvas *target, void *videobuffer)
|
2016-03-01 15:47:10 +00:00
|
|
|
{
|
2018-04-07 21:30:28 +00:00
|
|
|
if (V_IsPolyRenderer())
|
2017-03-12 17:54:39 +00:00
|
|
|
{
|
2017-03-20 07:28:16 +00:00
|
|
|
PolyRenderer::Instance()->Viewpoint = r_viewpoint;
|
|
|
|
PolyRenderer::Instance()->Viewwindow = r_viewwindow;
|
2018-07-20 03:48:15 +00:00
|
|
|
PolyRenderer::Instance()->RenderView(player, target, videobuffer);
|
2017-03-20 07:28:16 +00:00
|
|
|
r_viewpoint = PolyRenderer::Instance()->Viewpoint;
|
|
|
|
r_viewwindow = PolyRenderer::Instance()->Viewwindow;
|
2017-03-12 17:54:39 +00:00
|
|
|
}
|
2017-01-15 00:36:57 +00:00
|
|
|
else
|
2017-03-12 17:54:39 +00:00
|
|
|
{
|
|
|
|
mScene.MainThread()->Viewport->viewpoint = r_viewpoint;
|
|
|
|
mScene.MainThread()->Viewport->viewwindow = r_viewwindow;
|
2018-07-20 03:48:15 +00:00
|
|
|
mScene.RenderView(player, target, videobuffer);
|
2017-03-12 17:54:39 +00:00
|
|
|
r_viewpoint = mScene.MainThread()->Viewport->viewpoint;
|
|
|
|
r_viewwindow = mScene.MainThread()->Viewport->viewwindow;
|
|
|
|
}
|
2016-06-12 20:54:23 +00:00
|
|
|
|
2017-01-15 01:46:43 +00:00
|
|
|
FCanvasTextureInfo::UpdateAll();
|
2017-01-15 00:36:57 +00:00
|
|
|
}
|
2016-03-01 15:47:10 +00:00
|
|
|
|
2016-09-21 07:01:12 +00:00
|
|
|
void FSoftwareRenderer::WriteSavePic (player_t *player, FileWriter *file, int width, int height)
|
2016-03-01 15:47:10 +00:00
|
|
|
{
|
2018-11-30 16:02:39 +00:00
|
|
|
DCanvas pic(width, height, false);
|
2016-03-01 15:47:10 +00:00
|
|
|
PalEntry palette[256];
|
|
|
|
|
|
|
|
// Take a snapshot of the player's view
|
2018-04-07 21:30:28 +00:00
|
|
|
if (V_IsPolyRenderer())
|
2017-03-12 17:54:39 +00:00
|
|
|
{
|
2017-03-20 07:28:16 +00:00
|
|
|
PolyRenderer::Instance()->Viewpoint = r_viewpoint;
|
|
|
|
PolyRenderer::Instance()->Viewwindow = r_viewwindow;
|
2018-04-07 13:48:48 +00:00
|
|
|
PolyRenderer::Instance()->RenderViewToCanvas(player->mo, &pic, 0, 0, width, height, true);
|
2017-03-20 07:28:16 +00:00
|
|
|
r_viewpoint = PolyRenderer::Instance()->Viewpoint;
|
|
|
|
r_viewwindow = PolyRenderer::Instance()->Viewwindow;
|
2017-03-12 17:54:39 +00:00
|
|
|
}
|
2016-11-30 23:42:14 +00:00
|
|
|
else
|
2017-03-12 17:54:39 +00:00
|
|
|
{
|
|
|
|
mScene.MainThread()->Viewport->viewpoint = r_viewpoint;
|
|
|
|
mScene.MainThread()->Viewport->viewwindow = r_viewwindow;
|
2018-04-07 13:48:48 +00:00
|
|
|
mScene.RenderViewToCanvas(player->mo, &pic, 0, 0, width, height);
|
2017-03-12 17:54:39 +00:00
|
|
|
r_viewpoint = mScene.MainThread()->Viewport->viewpoint;
|
|
|
|
r_viewwindow = mScene.MainThread()->Viewport->viewwindow;
|
|
|
|
}
|
2016-03-01 15:47:10 +00:00
|
|
|
screen->GetFlashedPalette (palette);
|
2018-04-13 19:35:21 +00:00
|
|
|
M_CreatePNG (file, pic.GetPixels(), palette, SS_PAL, width, height, pic.GetPitch(), Gamma);
|
2016-03-01 15:47:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void FSoftwareRenderer::DrawRemainingPlayerSprites()
|
|
|
|
{
|
2018-04-07 21:30:28 +00:00
|
|
|
if (!V_IsPolyRenderer())
|
2016-11-14 13:19:48 +00:00
|
|
|
{
|
2017-03-12 17:54:39 +00:00
|
|
|
mScene.MainThread()->Viewport->viewpoint = r_viewpoint;
|
|
|
|
mScene.MainThread()->Viewport->viewwindow = r_viewwindow;
|
2017-02-04 13:00:21 +00:00
|
|
|
mScene.MainThread()->PlayerSprites->RenderRemaining();
|
2017-03-12 17:54:39 +00:00
|
|
|
r_viewpoint = mScene.MainThread()->Viewport->viewpoint;
|
|
|
|
r_viewwindow = mScene.MainThread()->Viewport->viewwindow;
|
2016-11-14 13:19:48 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-03-20 07:28:16 +00:00
|
|
|
PolyRenderer::Instance()->Viewpoint = r_viewpoint;
|
|
|
|
PolyRenderer::Instance()->Viewwindow = r_viewwindow;
|
2016-12-03 13:58:56 +00:00
|
|
|
PolyRenderer::Instance()->RenderRemainingPlayerSprites();
|
2017-03-20 07:28:16 +00:00
|
|
|
r_viewpoint = PolyRenderer::Instance()->Viewpoint;
|
|
|
|
r_viewwindow = PolyRenderer::Instance()->Viewwindow;
|
2016-11-14 13:19:48 +00:00
|
|
|
}
|
2016-03-01 15:47:10 +00:00
|
|
|
}
|
|
|
|
|
2017-01-15 02:21:35 +00:00
|
|
|
void FSoftwareRenderer::SetClearColor(int color)
|
2016-03-01 15:47:10 +00:00
|
|
|
{
|
2017-02-04 13:00:21 +00:00
|
|
|
mScene.SetClearColor(color);
|
2016-03-01 15:47:10 +00:00
|
|
|
}
|
|
|
|
|
2017-08-31 20:37:29 +00:00
|
|
|
void FSoftwareRenderer::RenderTextureView (FCanvasTexture *tex, AActor *viewpoint, double fov)
|
2016-03-01 15:47:10 +00:00
|
|
|
{
|
2018-12-06 19:12:15 +00:00
|
|
|
#if 0 // This will require a complete redesign.
|
2018-04-07 21:30:28 +00:00
|
|
|
auto renderTarget = V_IsPolyRenderer() ? PolyRenderer::Instance()->RenderTarget : mScene.MainThread()->Viewport->RenderTarget;
|
|
|
|
auto &cameraViewpoint = V_IsPolyRenderer() ? PolyRenderer::Instance()->Viewpoint : mScene.MainThread()->Viewport->viewpoint;
|
|
|
|
auto &cameraViewwindow = V_IsPolyRenderer() ? PolyRenderer::Instance()->Viewwindow : mScene.MainThread()->Viewport->viewwindow;
|
2017-03-12 17:54:39 +00:00
|
|
|
|
|
|
|
// Grab global state shared with rest of zdoom
|
2017-03-20 07:28:16 +00:00
|
|
|
cameraViewpoint = r_viewpoint;
|
|
|
|
cameraViewwindow = r_viewwindow;
|
2017-02-01 15:02:21 +00:00
|
|
|
|
2018-03-18 20:33:44 +00:00
|
|
|
uint8_t *Pixels = renderTarget->IsBgra() ? (uint8_t*)tex->GetPixelsBgra() : (uint8_t*)tex->GetPixels(DefaultRenderStyle());
|
2018-11-30 16:02:39 +00:00
|
|
|
DCanvas *Canvas = renderTarget->IsBgra() ? tex->GetCanvasBgra() : tex->GetCanvas();
|
2016-03-01 15:47:10 +00:00
|
|
|
|
|
|
|
// curse Doom's overuse of global variables in the renderer.
|
|
|
|
// These get clobbered by rendering to a camera texture but they need to be preserved so the final rendering can be done with the correct palette.
|
2017-01-26 09:22:54 +00:00
|
|
|
CameraLight savedCameraLight = *CameraLight::Instance();
|
2016-03-01 15:47:10 +00:00
|
|
|
|
2017-03-20 07:28:16 +00:00
|
|
|
DAngle savedfov = cameraViewpoint.FieldOfView;
|
2017-08-31 20:37:29 +00:00
|
|
|
R_SetFOV (cameraViewpoint, fov);
|
2017-01-15 00:36:57 +00:00
|
|
|
|
2018-04-07 21:30:28 +00:00
|
|
|
if (V_IsPolyRenderer())
|
2016-12-03 13:58:56 +00:00
|
|
|
PolyRenderer::Instance()->RenderViewToCanvas(viewpoint, Canvas, 0, 0, tex->GetWidth(), tex->GetHeight(), tex->bFirstUpdate);
|
2016-11-30 23:42:14 +00:00
|
|
|
else
|
2017-02-04 13:00:21 +00:00
|
|
|
mScene.RenderViewToCanvas(viewpoint, Canvas, 0, 0, tex->GetWidth(), tex->GetHeight(), tex->bFirstUpdate);
|
2017-01-15 00:36:57 +00:00
|
|
|
|
2017-03-20 07:28:16 +00:00
|
|
|
R_SetFOV (cameraViewpoint, savedfov);
|
2016-06-13 01:16:48 +00:00
|
|
|
|
|
|
|
if (Canvas->IsBgra())
|
2016-03-01 15:47:10 +00:00
|
|
|
{
|
2018-03-27 11:50:31 +00:00
|
|
|
if (Pixels == Canvas->GetPixels())
|
2016-06-13 01:16:48 +00:00
|
|
|
{
|
|
|
|
FTexture::FlipSquareBlockBgra((uint32_t*)Pixels, tex->GetWidth(), tex->GetHeight());
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-03-27 11:50:31 +00:00
|
|
|
FTexture::FlipNonSquareBlockBgra((uint32_t*)Pixels, (const uint32_t*)Canvas->GetPixels(), tex->GetWidth(), tex->GetHeight(), Canvas->GetPitch());
|
2016-06-13 01:16:48 +00:00
|
|
|
}
|
2016-03-01 15:47:10 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-03-27 11:50:31 +00:00
|
|
|
if (Pixels == Canvas->GetPixels())
|
2016-06-13 01:16:48 +00:00
|
|
|
{
|
|
|
|
FTexture::FlipSquareBlockRemap(Pixels, tex->GetWidth(), tex->GetHeight(), GPalette.Remap);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-03-27 11:50:31 +00:00
|
|
|
FTexture::FlipNonSquareBlockRemap(Pixels, Canvas->GetPixels(), tex->GetWidth(), tex->GetHeight(), Canvas->GetPitch(), GPalette.Remap);
|
2016-06-13 01:16:48 +00:00
|
|
|
}
|
2016-03-01 15:47:10 +00:00
|
|
|
}
|
2016-06-17 08:14:33 +00:00
|
|
|
|
2017-03-20 07:28:16 +00:00
|
|
|
if (renderTarget->IsBgra())
|
2016-06-17 08:14:33 +00:00
|
|
|
{
|
|
|
|
// True color render still sometimes uses palette textures (for sprites, mostly).
|
|
|
|
// We need to make sure that both pixel buffers contain data:
|
|
|
|
int width = tex->GetWidth();
|
|
|
|
int height = tex->GetHeight();
|
2018-03-18 20:33:44 +00:00
|
|
|
uint8_t *palbuffer = (uint8_t *)tex->GetPixels(DefaultRenderStyle());
|
2016-06-17 08:14:33 +00:00
|
|
|
uint32_t *bgrabuffer = (uint32_t*)tex->GetPixelsBgra();
|
|
|
|
for (int x = 0; x < width; x++)
|
|
|
|
{
|
|
|
|
for (int y = 0; y < height; y++)
|
|
|
|
{
|
|
|
|
uint32_t color = bgrabuffer[y];
|
|
|
|
int r = RPART(color);
|
|
|
|
int g = GPART(color);
|
|
|
|
int b = BPART(color);
|
|
|
|
palbuffer[y] = RGB32k.RGB[r >> 3][g >> 3][b >> 3];
|
|
|
|
}
|
|
|
|
palbuffer += height;
|
|
|
|
bgrabuffer += height;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-17 08:16:34 +00:00
|
|
|
tex->SetUpdated();
|
|
|
|
|
2017-01-26 09:22:54 +00:00
|
|
|
*CameraLight::Instance() = savedCameraLight;
|
2017-03-12 17:54:39 +00:00
|
|
|
|
|
|
|
// Sync state back to zdoom
|
2017-03-20 07:28:16 +00:00
|
|
|
r_viewpoint = cameraViewpoint;
|
|
|
|
r_viewwindow = cameraViewwindow;
|
2018-12-06 19:12:15 +00:00
|
|
|
#endif
|
2016-03-01 15:47:10 +00:00
|
|
|
}
|
|
|
|
|
2018-04-03 20:50:47 +00:00
|
|
|
void FSoftwareRenderer::SetColormap()
|
2017-01-15 00:36:57 +00:00
|
|
|
{
|
2017-03-15 21:04:23 +00:00
|
|
|
// This just sets the default colormap for the spftware renderer.
|
|
|
|
NormalLight.Maps = realcolormaps.Maps;
|
|
|
|
NormalLight.ChangeColor(PalEntry(255, 255, 255), 0);
|
|
|
|
NormalLight.ChangeFade(level.fadeto);
|
|
|
|
if (level.fadeto == 0)
|
|
|
|
{
|
|
|
|
SetDefaultColormap(level.info->FadeTable);
|
|
|
|
}
|
2017-01-15 00:36:57 +00:00
|
|
|
}
|
|
|
|
|