2019-11-20 16:21:32 +00:00
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
/*
|
|
|
|
Copyright (C) 2010-2019 EDuke32 developers and contributors
|
|
|
|
Copyright (C) 2019 sirlemonhead, Nuke.YKT
|
|
|
|
This file is part of PCExhumed.
|
|
|
|
PCExhumed is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU General Public License version 2
|
|
|
|
as published by the Free Software Foundation.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
//-------------------------------------------------------------------------
|
2019-11-22 23:11:37 +00:00
|
|
|
#include "ns.h"
|
2019-08-26 03:59:14 +00:00
|
|
|
#include "engine.h"
|
|
|
|
#include "exhumed.h"
|
|
|
|
#include "view.h"
|
2020-08-18 07:52:08 +00:00
|
|
|
#include "aistuff.h"
|
2019-12-31 21:53:03 +00:00
|
|
|
#include "../glbackend/glbackend.h"
|
2019-08-26 03:59:14 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2019-11-22 23:11:37 +00:00
|
|
|
BEGIN_PS_NS
|
|
|
|
|
2020-10-11 11:14:32 +00:00
|
|
|
enum { kMaxGrads = 12 };
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
const char *GradList[kMaxGrads] = {
|
|
|
|
"normal.rmp",
|
|
|
|
"nodim.rmp",
|
|
|
|
"torch.rmp",
|
|
|
|
"notorch.rmp",
|
|
|
|
"brite.rmp",
|
|
|
|
"redbrite.rmp",
|
|
|
|
"grnbrite.rmp",
|
|
|
|
"normal.rmp",
|
|
|
|
"nodim.rmp",
|
|
|
|
"torch.rmp",
|
|
|
|
"notorch.rmp",
|
|
|
|
"brite.rmp"
|
2019-08-26 03:59:14 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
int rtint = 0;
|
|
|
|
int gtint = 0;
|
|
|
|
int btint = 0;
|
2019-10-27 13:53:20 +00:00
|
|
|
//char *origpalookup[kMaxPalookups];
|
2019-10-12 21:09:55 +00:00
|
|
|
//unsigned char curpal[768];
|
|
|
|
//unsigned char kenpal[768];
|
|
|
|
palette_t *fadedestpal;
|
|
|
|
palette_t *fadecurpal;
|
2019-08-26 03:59:14 +00:00
|
|
|
short nPalDelay;
|
|
|
|
short nPalDiff;
|
|
|
|
short overscanindex;
|
2019-10-27 13:53:20 +00:00
|
|
|
int bGreenPal = 0;
|
2019-08-26 03:59:14 +00:00
|
|
|
|
|
|
|
// keep a local copy of the palette that would have been sent to the VGA display adapter
|
2019-08-31 07:47:15 +00:00
|
|
|
uint8_t vgaPalette[768];
|
2019-08-26 03:59:14 +00:00
|
|
|
|
|
|
|
int LoadPaletteLookups()
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
uint8_t buffer[256*64];
|
2019-08-27 06:08:18 +00:00
|
|
|
numshades = 64;
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
for (int i = 0; i < kMaxGrads; i++)
|
|
|
|
{
|
2020-04-11 21:54:33 +00:00
|
|
|
auto hFile = fileSystem.OpenFileReader(GradList[i]);
|
2019-11-24 12:59:36 +00:00
|
|
|
if (!hFile.isOpen())
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2020-04-11 21:45:45 +00:00
|
|
|
Printf("Error reading palette lookup '%s'\n", GradList[i]);
|
2019-08-31 07:47:15 +00:00
|
|
|
return 0;
|
|
|
|
}
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-11-24 12:59:36 +00:00
|
|
|
hFile.Read(buffer, 256*64);
|
2020-05-27 20:19:02 +00:00
|
|
|
lookups.setTable(i, buffer);
|
2019-11-24 12:59:36 +00:00
|
|
|
|
2019-10-27 13:53:20 +00:00
|
|
|
bGreenPal = 0;
|
2019-10-29 14:01:30 +00:00
|
|
|
|
2019-12-31 21:53:03 +00:00
|
|
|
// These 3 tables do not have normal gradients. The others work without adjustment.
|
|
|
|
// Other changes than altering the fog gradient are not necessary.
|
2020-06-05 21:18:21 +00:00
|
|
|
lookups.tables[kPalTorch].ShadeFactor = lookups.tables[kPalTorch2].ShadeFactor = (numshades - 2) / 20.f;
|
|
|
|
lookups.tables[kPalNoTorch].ShadeFactor = lookups.tables[kPalNoTorch2].ShadeFactor = (numshades - 2) / 4.f;
|
|
|
|
lookups.tables[kPalBrite].ShadeFactor = lookups.tables[kPalBrite].ShadeFactor = (numshades - 2) / 128.f;
|
2019-10-29 14:01:30 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
return 1;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void SetGreenPal()
|
|
|
|
{
|
2019-10-27 13:53:20 +00:00
|
|
|
bGreenPal = 1;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void RestoreGreenPal()
|
|
|
|
{
|
2019-10-27 13:53:20 +00:00
|
|
|
bGreenPal = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int HavePLURemap()
|
|
|
|
{
|
|
|
|
return bGreenPal || bTorch;
|
|
|
|
}
|
|
|
|
|
|
|
|
uint8_t RemapPLU(uint8_t pal)
|
|
|
|
{
|
|
|
|
if (bGreenPal)
|
|
|
|
{
|
|
|
|
if (pal != kPalRedBrite)
|
|
|
|
pal = kPalGreenBrite;
|
|
|
|
}
|
|
|
|
else if (bTorch)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-27 13:53:20 +00:00
|
|
|
switch (pal)
|
|
|
|
{
|
|
|
|
case kPalTorch:
|
|
|
|
pal = kPalNoTorch;
|
|
|
|
break;
|
|
|
|
case kPalNoTorch:
|
|
|
|
pal = kPalTorch;
|
|
|
|
break;
|
|
|
|
case kPalTorch2:
|
|
|
|
pal = kPalNoTorch2;
|
|
|
|
break;
|
|
|
|
case kPalNoTorch2:
|
|
|
|
pal = kPalTorch2;
|
|
|
|
break;
|
|
|
|
}
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
2019-10-27 13:53:20 +00:00
|
|
|
return pal;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void GrabPalette()
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
nPalDiff = 0;
|
|
|
|
nPalDelay = 0;
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
btint = 0;
|
|
|
|
gtint = 0;
|
|
|
|
rtint = 0;
|
2019-10-12 22:27:12 +00:00
|
|
|
videoTintBlood(0, 0, 0);
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void FixPalette()
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
if (!nPalDiff) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (nPalDelay > 0)
|
|
|
|
{
|
|
|
|
nPalDelay--;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
nPalDelay = 5;
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
nPalDiff -= 20;
|
|
|
|
gtint -= 20;
|
|
|
|
rtint -= 20;
|
2019-10-12 21:40:48 +00:00
|
|
|
btint -= 20;
|
2019-08-31 07:47:15 +00:00
|
|
|
|
|
|
|
if (gtint < 0) {
|
|
|
|
gtint = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (rtint < 0) {
|
|
|
|
rtint = 0;
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:40:48 +00:00
|
|
|
if (btint < 0) {
|
|
|
|
btint = 0;
|
|
|
|
}
|
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
if (nPalDiff < 0) {
|
|
|
|
nPalDiff = 0;
|
|
|
|
}
|
|
|
|
|
2020-04-12 05:51:11 +00:00
|
|
|
videoTintBlood(rtint, gtint, btint);
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void TintPalette(int r, int g, int b)
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
if (bCamera) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
// range limit R between 20 and 255 if positive
|
|
|
|
if (r > 255)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
r = 255;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (r && r < 20) {
|
|
|
|
r = 20;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
// range limit G between 20 and 255 if positive
|
|
|
|
if (g > 255)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
g = 255;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (g && g < 20) {
|
|
|
|
g = 20;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
// range limit B between 20 and 255 if positive
|
|
|
|
if (b > 255)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
b = 255;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (b && b < 20) {
|
|
|
|
b = 20;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// loc_17EFA
|
2019-10-12 21:09:55 +00:00
|
|
|
if (g && gtint > 32) {
|
2019-08-31 07:47:15 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
gtint += g;
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
if (r && rtint > 256) {
|
2019-08-31 07:47:15 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
rtint += r;
|
|
|
|
|
2019-10-12 21:40:48 +00:00
|
|
|
btint += b;
|
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
// do not modify r, g or b variables from this point on
|
|
|
|
int nVal;
|
|
|
|
|
|
|
|
// loc_17F49
|
2019-10-12 21:09:55 +00:00
|
|
|
if (klabs(r) > klabs(g)) {
|
|
|
|
nVal = klabs(r);
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
else {
|
2019-10-12 21:09:55 +00:00
|
|
|
nVal = klabs(g);
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
if (nVal < klabs(b)) {
|
|
|
|
nVal = klabs(b);
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
nPalDiff += nVal;
|
|
|
|
|
2020-03-29 14:59:49 +00:00
|
|
|
videoTintBlood(rtint, gtint, btint);
|
2019-08-31 07:47:15 +00:00
|
|
|
|
|
|
|
nPalDelay = 0;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-11-22 23:11:37 +00:00
|
|
|
END_PS_NS
|