Browse Source

Clean up CelDecodeHdrLightOnly

pull/88/head
Anders Jenbo 7 years ago
parent
commit
4d6d0d8592
  1. 27
      Source/engine.cpp

27
Source/engine.cpp

@ -611,8 +611,8 @@ void __fastcall CelDecodeLightOnly(int sx, int sy, BYTE *pCelBuff, int nCel, int
*/ */
void __fastcall CelDecodeHdrLightOnly(int sx, int sy, BYTE *pCelBuff, int nCel, int nWidth, int CelSkip, int CelCap) void __fastcall CelDecodeHdrLightOnly(int sx, int sy, BYTE *pCelBuff, int nCel, int nWidth, int CelSkip, int CelCap)
{ {
int hdr, nDataSize, v1, v2; int nDataStart, nDataSize, nDataCap;
BYTE *pRLEBytes, *pDecodeTo, *v9; BYTE *pRLEBytes, *pDecodeTo;
DWORD *pFrameTable; DWORD *pFrameTable;
/// ASSERT: assert(gpBuffer); /// ASSERT: assert(gpBuffer);
@ -622,23 +622,24 @@ void __fastcall CelDecodeHdrLightOnly(int sx, int sy, BYTE *pCelBuff, int nCel,
if (!pCelBuff) if (!pCelBuff)
return; return;
pFrameTable = (DWORD *)&pCelBuff[4 * nCel]; pFrameTable = (DWORD *)pCelBuff;
v9 = &pCelBuff[pFrameTable[0]]; pRLEBytes = &pCelBuff[pFrameTable[nCel]];
hdr = *(WORD *)&v9[CelSkip]; nDataStart = *(WORD *)&pRLEBytes[CelSkip];
if (!hdr) if (!nDataStart)
return; return;
v1 = pFrameTable[1] - pFrameTable[0]; nDataSize = pFrameTable[nCel + 1] - pFrameTable[nCel];
if (CelCap == 8) if (CelCap == 8)
v2 = 0; nDataCap = 0;
else else
v2 = *(WORD *)&v9[CelCap]; nDataCap = *(WORD *)&pRLEBytes[CelCap];
if (v2) if (nDataCap)
nDataSize = v2 - hdr; nDataSize = nDataCap - nDataStart;
else else
nDataSize = v1 - hdr; nDataSize -= nDataStart;
pRLEBytes = &v9[hdr]; pRLEBytes = &pRLEBytes[nDataStart];
pDecodeTo = &gpBuffer[sx + screen_y_times_768[sy - 16 * CelSkip]]; pDecodeTo = &gpBuffer[sx + screen_y_times_768[sy - 16 * CelSkip]];
if (light_table_index) if (light_table_index)

Loading…
Cancel
Save