mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Fix Ramses head being all tiny
# Conflicts: # source/exhumed/src/exhumed.cpp
This commit is contained in:
parent
326947d976
commit
803f22904b
1 changed files with 4 additions and 346 deletions
|
@ -3030,6 +3030,10 @@ void InitSpiritHead()
|
|||
|
||||
nPixels = 0;
|
||||
|
||||
nSpiritRepeatX = sprite[nSpiritSprite].xrepeat;
|
||||
nSpiritRepeatY = sprite[nSpiritSprite].yrepeat;
|
||||
|
||||
tileLoad(kTileRamsesNormal); // Ramses Normal Head
|
||||
|
||||
for (int i = 0; i < kMaxSprites; i++)
|
||||
{
|
||||
|
@ -3165,7 +3169,6 @@ void CopyHeadToWorkTile(short nTile)
|
|||
}
|
||||
}
|
||||
|
||||
#if 1
|
||||
int DoSpiritHead()
|
||||
{
|
||||
static short word_964E6 = 0;
|
||||
|
@ -3547,349 +3550,4 @@ int DoSpiritHead()
|
|||
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
int DoSpiritHead()
|
||||
{
|
||||
static short word_964E6 = 0;
|
||||
|
||||
nVertPan[0] += (nDestVertPan[0] - nVertPan[0]) / 4;
|
||||
|
||||
if (nHeadStage < 2)
|
||||
{
|
||||
memset(worktile, -1, sizeof(worktile));
|
||||
}
|
||||
else if (nHeadStage == 5)
|
||||
{
|
||||
if (lNextStateChange <= (int)totalclock)
|
||||
{
|
||||
if (nPupData)
|
||||
{
|
||||
short nPupVal = *pPupData;
|
||||
pPupData++;
|
||||
nPupData -= 2;
|
||||
|
||||
if (nPupData > 0)
|
||||
{
|
||||
lNextStateChange = (nPupVal + lHeadStartClock) - 10;
|
||||
nTalkTime = !nTalkTime;
|
||||
}
|
||||
else
|
||||
{
|
||||
nTalkTime = 0;
|
||||
nPupData = 0;
|
||||
}
|
||||
}
|
||||
else if (!bSubTitles)
|
||||
{
|
||||
if (!CDplaying())
|
||||
{
|
||||
levelnew = levelnum + 1;
|
||||
fadecdaudio();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
word_964E8--;
|
||||
if (word_964E8 <= 0)
|
||||
{
|
||||
word_964EA = RandomBit() * 2;
|
||||
word_964E8 = RandomSize(5) + 4;
|
||||
}
|
||||
|
||||
int ebx = 592;
|
||||
word_964EC--;
|
||||
|
||||
if (word_964EC < 3)
|
||||
{
|
||||
ebx = 593;
|
||||
if (word_964EC <= 0) {
|
||||
word_964EC = RandomSize(6) + 4;
|
||||
}
|
||||
}
|
||||
|
||||
ebx += word_964EA;
|
||||
|
||||
loadtile(ebx);
|
||||
|
||||
// TODO - fixme. How big is worktile?
|
||||
uint8_t *pDest = (uint8_t*)&worktile[10441];
|
||||
uint8_t *pSrc = waloff[ebx];
|
||||
|
||||
for (int i = 0; i < 97; i++)
|
||||
{
|
||||
memcpy(pDest, pSrc, 106);
|
||||
|
||||
pDest += 212;
|
||||
pSrc += 106;
|
||||
}
|
||||
|
||||
if (nTalkTime)
|
||||
{
|
||||
if (nMouthTile < 2) {
|
||||
nMouthTile++;
|
||||
}
|
||||
}
|
||||
else if (nMouthTile != 0)
|
||||
{
|
||||
nMouthTile--;
|
||||
}
|
||||
|
||||
if (nMouthTile)
|
||||
{
|
||||
loadtile(nMouthTile + 598);
|
||||
|
||||
short nTileSizeX = tilesizx[nMouthTile + 598];
|
||||
short nTileSizeY = tilesizy[nMouthTile + 598];
|
||||
|
||||
// TODO - checkme. near loc_133AA
|
||||
// uint8_t *pDest = (uint8_t*)worktile;
|
||||
// pDest += (212 * (97 - nTileSizeX / 2)) + (159 - nTileSizeY);
|
||||
|
||||
uint8_t *pDest = (uint8_t*)&worktile[212 * (97 - nTileSizeX / 2)] + (159 - nTileSizeY);
|
||||
uint8_t *pSrc = waloff[nMouthTile + 598];
|
||||
|
||||
while (nTileSizeX > 0)
|
||||
{
|
||||
memcpy(pDest, pSrc, nTileSizeY);
|
||||
|
||||
nTileSizeX--;
|
||||
pDest += 212;
|
||||
pSrc += nTileSizeY;
|
||||
}
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
nPixelsToShow = ((int)totalclock - nHeadTimeStart) * 15;
|
||||
|
||||
if (nPixelsToShow > nPixels) {
|
||||
nPixelsToShow = nPixels;
|
||||
}
|
||||
|
||||
if (nHeadStage < 3)
|
||||
{
|
||||
UpdateSwirlies();
|
||||
|
||||
if (sprite[nSpiritSprite].shade > -127) {
|
||||
sprite[nSpiritSprite].shade--;
|
||||
}
|
||||
|
||||
word_964E6--;
|
||||
if (word_964E6 < 0)
|
||||
{
|
||||
DimSector(sprite[nSpiritSprite].sectnum);
|
||||
word_964E6 = 5;
|
||||
}
|
||||
|
||||
if (!nHeadStage)
|
||||
{
|
||||
if (((int)totalclock - nHeadTimeStart) > 480)
|
||||
{
|
||||
nHeadStage = 1;
|
||||
nHeadTimeStart = (int)totalclock + 480;
|
||||
}
|
||||
|
||||
// int ecx = 0;
|
||||
|
||||
// loc_1362C
|
||||
for (int i = 0; i < nPixelsToShow; i++)
|
||||
{
|
||||
if (destvely[i] < 0)
|
||||
{
|
||||
vely[i]--;
|
||||
|
||||
if (vely[i] <= destvely[i])
|
||||
{
|
||||
destvely[i] = RandomSize(2) + 1;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
vely[i]++;
|
||||
|
||||
if (vely[i] >= destvely[i])
|
||||
{
|
||||
destvely[i] = -(RandomSize(2) + 1);
|
||||
}
|
||||
}
|
||||
|
||||
// loc_13541
|
||||
if (destvelx[i] >= 0)
|
||||
{
|
||||
velx[i]--;
|
||||
|
||||
if (velx[i] <= destvelx[i])
|
||||
{
|
||||
destvelx[i] = RandomSize(2) + 1;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
velx[i]++;
|
||||
|
||||
if (velx[i] >= destvelx[i])
|
||||
{
|
||||
destvelx[i] = -(RandomSize(2) + 1);
|
||||
}
|
||||
}
|
||||
|
||||
// loc_13593
|
||||
int esi = vely[i] + (cury[i] >> 8);
|
||||
|
||||
if (esi >= 106)
|
||||
{
|
||||
vely[i] = 0;
|
||||
esi = 0;
|
||||
}
|
||||
else if (esi < -105)
|
||||
{
|
||||
vely[i] = 0;
|
||||
esi = 0;
|
||||
}
|
||||
|
||||
// loc_135C6
|
||||
int ebx = velx[i] + (curx[i] >> 8);
|
||||
|
||||
if (ebx >= 97)
|
||||
{
|
||||
velx[i] = 0;
|
||||
ebx = 0;
|
||||
}
|
||||
else if (ebx < -96)
|
||||
{
|
||||
velx[i] = 0;
|
||||
ebx = 0;
|
||||
}
|
||||
|
||||
// loc_135F9
|
||||
curx[i] = ebx << 8;
|
||||
cury[i] = esi << 8;
|
||||
|
||||
//ecx += 2;
|
||||
// ecx++;
|
||||
|
||||
// uint8_t *pVal = (uint8_t*)worktile;
|
||||
|
||||
worktile[106 + esi + (ebx + 97) * 212] = pixelval[i];
|
||||
//pVal += (106 + esi);
|
||||
//*pVal = pixelval[i];
|
||||
}
|
||||
}
|
||||
else if (nHeadStage == 1)
|
||||
{
|
||||
uint8_t nXRepeat = sprite[nSpiritSprite].xrepeat;
|
||||
if (nXRepeat > nSpiritRepeatX)
|
||||
{
|
||||
sprite[nSpiritSprite].xrepeat -= 2;
|
||||
|
||||
nXRepeat = sprite[nSpiritSprite].xrepeat;
|
||||
if (nXRepeat < nSpiritRepeatX)
|
||||
{
|
||||
sprite[nSpiritSprite].xrepeat = nSpiritRepeatX;
|
||||
}
|
||||
}
|
||||
|
||||
uint8_t nYRepeat = sprite[nSpiritSprite].yrepeat;
|
||||
if (nYRepeat > nSpiritRepeatY)
|
||||
{
|
||||
sprite[nSpiritSprite].yrepeat -= 2;
|
||||
|
||||
nYRepeat = sprite[nSpiritSprite].yrepeat;
|
||||
if (nYRepeat < nSpiritRepeatY)
|
||||
{
|
||||
sprite[nSpiritSprite].yrepeat = nSpiritRepeatY;
|
||||
}
|
||||
}
|
||||
|
||||
// loc_13705
|
||||
int esi = 0;
|
||||
// int edx = 0;
|
||||
|
||||
// loc_137E7:
|
||||
for (int i = 0; i < nPixels; i++)
|
||||
{
|
||||
int eax = (origx[i] << 8) - curx[i];
|
||||
int ecx = eax;
|
||||
|
||||
if (eax && klabs(eax) < 8)
|
||||
{
|
||||
curx[i] = origx[i] << 8;
|
||||
ecx = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
ecx >>= 3;
|
||||
}
|
||||
|
||||
// loc_1374B
|
||||
int var_1C = (origy[i] << 8) - cury[i];
|
||||
int ebp = var_1C;
|
||||
|
||||
if (ebp && klabs(ebp) < 8)
|
||||
{
|
||||
cury[i] = origy[i] << 8;
|
||||
var_1C = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
var_1C >>= 3;
|
||||
}
|
||||
|
||||
if (var_1C | ecx)
|
||||
{
|
||||
curx[i] += ecx;
|
||||
cury[i] += var_1C;
|
||||
|
||||
esi++;
|
||||
}
|
||||
|
||||
// edx++;
|
||||
|
||||
// uint8_t *pVal = (uint8_t*)worktile;
|
||||
|
||||
worktile[106 + (((curx[i] >> 8) + 97) * 212) + (cury[i] >> 8)] = pixelval[i];
|
||||
|
||||
//pVal += (106 + ecx);
|
||||
//*pVal = pixelval[i];
|
||||
}
|
||||
|
||||
if (((int)totalclock - lHeadStartClock) > 600) {
|
||||
CopyHeadToWorkTile(kTileRamsesGold);
|
||||
}
|
||||
|
||||
int eax = (nPixels * 15) / 16;
|
||||
|
||||
if (esi < eax)
|
||||
{
|
||||
// SoundBigEntrance(); // TODO
|
||||
AddGlow(sprite[nSpiritSprite].sectnum, 20);
|
||||
AddFlash(
|
||||
sprite[nSpiritSprite].sectnum,
|
||||
sprite[nSpiritSprite].x,
|
||||
sprite[nSpiritSprite].y,
|
||||
sprite[nSpiritSprite].z,
|
||||
128);
|
||||
|
||||
nHeadStage = 3;
|
||||
TintPalette(255, 255, 255);
|
||||
CopyHeadToWorkTile(kTileRamsesNormal);
|
||||
}
|
||||
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
// loc_138A7
|
||||
FixPalette();
|
||||
|
||||
if (!nPalDiff)
|
||||
{
|
||||
nFreeze = 2;
|
||||
nHeadStage++;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
END_PS_NS
|
||||
|
|
Loading…
Reference in a new issue