2019-08-26 03:59:14 +00:00
|
|
|
|
|
|
|
#include "light.h"
|
|
|
|
#include "engine.h"
|
|
|
|
#include "exhumed.h"
|
|
|
|
#include "view.h"
|
|
|
|
#include "cd.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#define kMaxGrads 12
|
|
|
|
|
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;
|
|
|
|
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;
|
|
|
|
|
|
|
|
// 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
|
|
|
|
|
|
|
|
|
|
|
void MyLoadPalette()
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
//int hFile = kopen4load("PALETTE.DAT", 1);
|
|
|
|
//if (hFile == -1)
|
|
|
|
//{
|
|
|
|
// initprintf("Error reading palette 'PALETTE.DAT'\n");
|
|
|
|
// return;
|
|
|
|
//}
|
|
|
|
//
|
|
|
|
//kread(hFile, kenpal, sizeof(kenpal));
|
|
|
|
//kclose(hFile);
|
|
|
|
videoSetPalette(0, BASEPAL, 0);
|
|
|
|
SetOverscan(BASEPAL);
|
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++)
|
|
|
|
{
|
|
|
|
int hFile = kopen4load(GradList[i], 1);
|
|
|
|
if (hFile == -1)
|
|
|
|
{
|
2019-08-27 06:08:18 +00:00
|
|
|
initprintf("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-08-31 07:47:15 +00:00
|
|
|
kread(hFile, buffer, 256*64);
|
2019-08-31 10:36:26 +00:00
|
|
|
// TODO: dumb hack
|
|
|
|
if (palookup[i])
|
|
|
|
ALIGNED_FREE_AND_NULL(palookup[i]);
|
2019-08-31 07:47:15 +00:00
|
|
|
paletteSetLookupTable(i, buffer);
|
|
|
|
kclose(hFile);
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
origpalookup[i] = palookup[i];
|
|
|
|
}
|
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-08-31 07:47:15 +00:00
|
|
|
for (int i = 0; i < 12; i++)
|
|
|
|
{
|
|
|
|
palookup[i] = palookup[6];
|
|
|
|
}
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
palookup[5] = origpalookup[5];
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void RestoreGreenPal()
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
for (int i = 0; i < 12; i++)
|
|
|
|
{
|
|
|
|
palookup[i] = origpalookup[i];
|
|
|
|
}
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void WaitVBL()
|
|
|
|
{
|
|
|
|
#ifdef __WATCOMC__
|
2019-08-31 07:47:15 +00:00
|
|
|
while (!(inp(0x3da) & 8));
|
2019-08-26 03:59:14 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
//void MySetPalette(unsigned char *palette)
|
|
|
|
//{
|
|
|
|
// WaitVBL();
|
|
|
|
//
|
|
|
|
// // TODO
|
|
|
|
// kensetpalette(palette);
|
|
|
|
//
|
|
|
|
// memcpy(vgaPalette, palette, sizeof(vgaPalette));
|
|
|
|
//}
|
|
|
|
|
|
|
|
//void GetCurPal(unsigned char *palette)
|
|
|
|
//{
|
|
|
|
// if (!palette) {
|
|
|
|
// memcpy(curpal, vgaPalette, sizeof(curpal));
|
|
|
|
// }
|
|
|
|
// else {
|
|
|
|
// memcpy(palette, vgaPalette, sizeof(curpal));
|
|
|
|
// }
|
|
|
|
//}
|
2019-08-26 03:59:14 +00:00
|
|
|
|
|
|
|
void GrabPalette()
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
SetOverscan(BASEPAL);
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
memcpy(curpalettefaded, curpalette, sizeof(curpalette));
|
|
|
|
videoUpdatePalette(0, 256);
|
2019-08-26 03:59:14 +00:00
|
|
|
|
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-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void BlackOut()
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
for (int i = 0; i < 256; i++)
|
|
|
|
{
|
|
|
|
curpalettefaded[i].r = 0;
|
|
|
|
curpalettefaded[i].g = 0;
|
|
|
|
curpalettefaded[i].b = 0;
|
|
|
|
}
|
|
|
|
videoUpdatePalette(0, 256);
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void RestorePalette()
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
memcpy(curpalettefaded, curpalette, sizeof(curpalette));
|
|
|
|
videoUpdatePalette(0, 256);
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void WaitTicks(int nTicks)
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
if (htimer)
|
|
|
|
{
|
2019-09-06 05:18:12 +00:00
|
|
|
nTicks += (int)totalclock;
|
|
|
|
while (nTicks > (int)totalclock) { HandleAsync(); }
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
while (nTicks > 0) {
|
|
|
|
nTicks--;
|
|
|
|
WaitVBL();
|
|
|
|
}
|
|
|
|
}
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// unused
|
|
|
|
void DoFadeToRed()
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
for (int i = 0; i < 256; i++)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (curpalettefaded[i].g > 0)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
curpalettefaded[i].g -= 4;
|
|
|
|
if (curpalettefaded[i].g < 0)
|
|
|
|
curpalettefaded[i].g = 0;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
if (curpalettefaded[i].b > 0)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
curpalettefaded[i].b -= 4;
|
|
|
|
if (curpalettefaded[i].b < 0)
|
|
|
|
curpalettefaded[i].b = 0;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
videoUpdatePalette(0, 256);
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void FadeToWhite()
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
int ebx = 0;
|
2019-10-12 21:09:55 +00:00
|
|
|
int const palstep = (videoGetRenderMode() >= REND_POLYMOST) ? 255 : 4;
|
|
|
|
int const fadestep = (videoGetRenderMode() >= REND_POLYMOST) ? 1 : 64;
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
for (int i = 0; i < fadestep; i++)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
palette_t *pPal = curpalettefaded;
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
for (int j = 0; j < 256; j++)
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (pPal->r < 255)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
pPal->r += palstep;
|
|
|
|
if (pPal->r > 255)
|
|
|
|
pPal->r = 255;
|
|
|
|
ebx++;
|
|
|
|
}
|
|
|
|
if (pPal->g < 255)
|
|
|
|
{
|
|
|
|
pPal->g += palstep;
|
|
|
|
if (pPal->g > 255)
|
|
|
|
pPal->g = 255;
|
|
|
|
ebx++;
|
|
|
|
}
|
|
|
|
if (pPal->b < 255)
|
|
|
|
{
|
|
|
|
pPal->b += palstep;
|
|
|
|
if (pPal->b > 255)
|
|
|
|
pPal->b = 255;
|
|
|
|
ebx++;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
2019-10-12 21:09:55 +00:00
|
|
|
pPal++;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
videoUpdatePalette(0, 256);
|
2019-08-31 07:47:15 +00:00
|
|
|
WaitTicks(2);
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
// need to page flip in each iteration of the loop for non DOS version
|
|
|
|
videoNextPage();
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
if (!ebx) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void FadeOut(int bFadeMusic)
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
int const palstep = (videoGetRenderMode() >= REND_POLYMOST) ? 255 : 4;
|
|
|
|
int const fadestep = (videoGetRenderMode() >= REND_POLYMOST) ? 1 : 64;
|
2019-08-31 07:47:15 +00:00
|
|
|
if (bFadeMusic) {
|
|
|
|
StartfadeCDaudio();
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
for (int i = fadestep; i > 0; i--)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
|
|
|
int v4 = 0;
|
2019-10-12 21:09:55 +00:00
|
|
|
palette_t *pPal = curpalettefaded;
|
2019-08-31 07:47:15 +00:00
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
for (int j = 0; j < 256; j++)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (pPal->r > 0)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
pPal->r -= palstep;
|
|
|
|
if (pPal->r < 0)
|
|
|
|
pPal->r = 0;
|
2019-08-31 07:47:15 +00:00
|
|
|
v4++;
|
|
|
|
}
|
2019-10-12 21:09:55 +00:00
|
|
|
if (pPal->g > 0)
|
|
|
|
{
|
|
|
|
pPal->g -= palstep;
|
|
|
|
if (pPal->g < 0)
|
|
|
|
pPal->g = 0;
|
|
|
|
v4++;
|
|
|
|
}
|
|
|
|
if (pPal->b > 0)
|
|
|
|
{
|
|
|
|
pPal->b -= palstep;
|
|
|
|
if (pPal->b < 0)
|
|
|
|
pPal->b = 0;
|
|
|
|
v4++;
|
|
|
|
}
|
|
|
|
pPal++;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
videoUpdatePalette(0, 256);
|
2019-08-31 07:47:15 +00:00
|
|
|
WaitTicks(2);
|
|
|
|
|
|
|
|
// need to page flip in each iteration of the loop for non DOS version
|
|
|
|
videoNextPage();
|
|
|
|
|
|
|
|
if (v4 == 0) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (bFadeMusic) {
|
|
|
|
StepFadeCDaudio();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (bFadeMusic) {
|
|
|
|
while (StepFadeCDaudio() != 0) {}
|
|
|
|
}
|
|
|
|
|
|
|
|
EraseScreen(overscanindex);
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void StartFadeIn()
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
//fadedestpal = curpalette;
|
|
|
|
//fadecurpal = curpal;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int DoFadeIn()
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
int v2 = 0;
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
for (int i = 0; i < 256; i++)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (curpalettefaded[i].r != curpalette[i].r)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
v2++;
|
|
|
|
int diff = curpalette[i].r - curpalettefaded[i].r;
|
|
|
|
if (klabs(diff) < 4)
|
|
|
|
curpalettefaded[i].r = curpalette[i].r;
|
|
|
|
else
|
|
|
|
curpalettefaded[i].r += 4 * ksgn(diff);
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
2019-10-12 21:09:55 +00:00
|
|
|
if (curpalettefaded[i].g != curpalette[i].g)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
v2++;
|
|
|
|
int diff = curpalette[i].g - curpalettefaded[i].g;
|
|
|
|
if (klabs(diff) < 4)
|
|
|
|
curpalettefaded[i].g = curpalette[i].g;
|
|
|
|
else
|
|
|
|
curpalettefaded[i].g += 4 * ksgn(diff);
|
|
|
|
}
|
|
|
|
if (curpalettefaded[i].b != curpalette[i].b)
|
|
|
|
{
|
|
|
|
v2++;
|
|
|
|
int diff = curpalette[i].b - curpalettefaded[i].b;
|
|
|
|
if (klabs(diff) < 4)
|
|
|
|
curpalettefaded[i].b = curpalette[i].b;
|
|
|
|
else
|
|
|
|
curpalettefaded[i].b += 4 * ksgn(diff);
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
videoUpdatePalette(0, 256);
|
2019-08-31 07:47:15 +00:00
|
|
|
|
|
|
|
return v2;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void FadeIn()
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (videoGetRenderMode() >= REND_POLYMOST)
|
|
|
|
{
|
|
|
|
Bmemcpy(curpalettefaded, curpalette, sizeof(curpalette));
|
|
|
|
videoUpdatePalette(0, 256);
|
|
|
|
videoNextPage();
|
|
|
|
return;
|
|
|
|
}
|
2019-08-31 07:47:15 +00:00
|
|
|
StartFadeIn();
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
int val;
|
|
|
|
|
|
|
|
do
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
val = DoFadeIn();
|
2019-08-31 07:47:15 +00:00
|
|
|
WaitTicks(2);
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
// need to page flip in each iteration of the loop for non DOS version
|
|
|
|
videoNextPage();
|
2019-10-12 21:09:55 +00:00
|
|
|
} while (val);
|
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:40:48 +00:00
|
|
|
#ifdef USE_OPENGL
|
|
|
|
if (videoGetRenderMode() == REND_CLASSIC)
|
|
|
|
#endif
|
2019-10-12 21:09:55 +00:00
|
|
|
for (int i = 0; i < 256; i++)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
short nVal;
|
|
|
|
|
|
|
|
nVal = curpalettefaded[i].r - curpalette[i].r;
|
|
|
|
if (nVal > 0)
|
|
|
|
{
|
|
|
|
if (nVal > 20)
|
|
|
|
{
|
|
|
|
curpalettefaded[i].r -= 20;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
curpalettefaded[i].r = curpalette[i].r;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
nVal = curpalettefaded[i].g - curpalette[i].g;
|
2019-08-31 07:47:15 +00:00
|
|
|
if (nVal > 0)
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (nVal > 20)
|
2019-08-31 07:47:15 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
curpalettefaded[i].g -= 20;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
curpalettefaded[i].g = curpalette[i].g;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
nVal = curpalettefaded[i].b - curpalette[i].b;
|
|
|
|
if (nVal > 0)
|
|
|
|
{
|
|
|
|
if (nVal > 20)
|
|
|
|
{
|
|
|
|
curpalettefaded[i].b -= 20;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
curpalettefaded[i].b = curpalette[i].b;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:40:48 +00:00
|
|
|
#ifdef USE_OPENGL
|
|
|
|
if (videoGetRenderMode() >= REND_POLYMOST) videoTintBlood(rtint, gtint, btint);
|
|
|
|
else
|
|
|
|
#endif
|
2019-10-12 21:09:55 +00:00
|
|
|
videoUpdatePalette(0, 256);
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void TintPalette(int r, int g, int b)
|
|
|
|
{
|
2019-08-31 07:47:15 +00:00
|
|
|
int r2 = r;
|
|
|
|
int g2 = g;
|
|
|
|
int b2 = b;
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
palette_t *pPal = curpalettefaded;
|
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
|
|
|
|
b2 = b;
|
|
|
|
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;
|
|
|
|
|
2019-10-12 21:40:48 +00:00
|
|
|
#ifdef USE_OPENGL
|
|
|
|
if (videoGetRenderMode() >= REND_POLYMOST) videoTintBlood(rtint, gtint, btint);
|
|
|
|
else
|
|
|
|
#endif
|
2019-08-31 07:47:15 +00:00
|
|
|
for (int i = 0; i < 256; i++)
|
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
pPal->r += r;
|
|
|
|
if (pPal->r > 255) {
|
|
|
|
pPal->r = 255;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
pPal->g += g;
|
|
|
|
if (pPal->g > 255) {
|
|
|
|
pPal->g = 255;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
pPal->b += b;
|
|
|
|
if (pPal->b > 255) {
|
|
|
|
pPal->b = 255;
|
2019-08-31 07:47:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pPal++;
|
|
|
|
}
|
|
|
|
|
|
|
|
nPalDelay = 0;
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void DoOverscanSet(short someval)
|
|
|
|
{
|
|
|
|
#ifdef __WATCOMC__
|
2019-08-31 07:47:15 +00:00
|
|
|
union REGS regs;
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
regs.h.al = 1;
|
|
|
|
regs.h.ah = 0x10;
|
|
|
|
regs.h.ch = someval;
|
2019-08-26 03:59:14 +00:00
|
|
|
|
2019-08-31 07:47:15 +00:00
|
|
|
int386(0x10, ®s, ®s);
|
2019-08-26 03:59:14 +00:00
|
|
|
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
// unused
|
|
|
|
void SetWhiteOverscan()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-10-12 21:09:55 +00:00
|
|
|
void SetOverscan(int id)
|
2019-08-26 03:59:14 +00:00
|
|
|
{
|
2019-10-12 21:09:55 +00:00
|
|
|
if (basepaltable[id] == NULL)
|
|
|
|
return;
|
|
|
|
uint8_t *palette = basepaltable[id];
|
2019-08-31 07:47:15 +00:00
|
|
|
int edi = 1000;
|
|
|
|
overscanindex = 0;
|
|
|
|
|
|
|
|
for (int i = 0; i < 256; i++)
|
|
|
|
{
|
|
|
|
int ebx = 0;
|
|
|
|
|
|
|
|
for (int j = 0; j < 3; j++)
|
|
|
|
{
|
|
|
|
uint8_t cl = *palette;
|
|
|
|
palette++;
|
|
|
|
ebx += cl;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (ebx < edi)
|
|
|
|
{
|
|
|
|
edi = ebx;
|
|
|
|
overscanindex = i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
DoOverscanSet(overscanindex);
|
2019-08-26 03:59:14 +00:00
|
|
|
}
|