further animlib improvements... like the previous commits, this probably speeds up playback of giant .anm files on very slow systems (handhelds like the Dingoo, etc)

git-svn-id: https://svn.eduke32.com/eduke32@1617 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
terminx 2010-03-15 00:06:48 +00:00
parent 36564f5070
commit e7f91d9b84

View file

@ -55,6 +55,7 @@ static void CheckAnimStarted(char * funcname)
if (!Anim_Started)
Error("ANIMLIB_%s: Anim has not been initialized\n",funcname);
}
//****************************************************************************
//
// findpage ()
@ -64,18 +65,19 @@ static void CheckAnimStarted(char * funcname)
uint16_t findpage(uint16_t framenumber)
{
uint16_t i;
// curlpnum is initialized to 0xffff, obviously
uint16_t i = (uint16_t)(anim->curlpnum & ~0xffff);
CheckAnimStarted("findpage");
for (i=0; i<anim->lpheader.nLps; i++)
{
if
(
anim->LpArray[i].baseRecord <= framenumber &&
anim->LpArray[i].baseRecord + anim->LpArray[i].nRecords > framenumber
)
if (framenumber < anim->currentframe)
i = 0;
for (; i<anim->lpheader.nLps; i++)
if (anim->LpArray[i].baseRecord <= framenumber &&
anim->LpArray[i].baseRecord + anim->LpArray[i].nRecords > framenumber)
return(i);
}
return(i);
}
@ -89,105 +91,95 @@ uint16_t findpage(uint16_t framenumber)
void loadpage(uint16_t pagenumber, uint16_t **pagepointer)
{
uint8_t * buffer;
CheckAnimStarted("loadpage");
buffer = anim->buffer;
if (anim->curlpnum != pagenumber)
{
anim->curlpnum = pagenumber;
buffer += 0xb00 + (pagenumber*IMAGEBUFFERSIZE);
anim->curlp = &anim->LpArray[pagenumber];
buffer += sizeof(lp_descriptor) + sizeof(uint16_t);
if (anim->curlpnum == pagenumber)
return;
*pagepointer = (uint16_t *)buffer;
}
anim->curlp = &anim->LpArray[(anim->curlpnum = pagenumber)];
*pagepointer = (uint16_t *)(anim->buffer + 0xb00 + (pagenumber*IMAGEBUFFERSIZE) +
sizeof(lp_descriptor) + sizeof(uint16_t));
}
//****************************************************************************
//
// CPlayRunSkipDump ()
// - This version of the decompressor is here for portability to non PC's
// - I found this less obfuscated version of the anm decompressor around,
// says it's (c) 1998 "Jari Komppa aka Sol/Trauma". This code is
// public domain and has been modified a bit by me.
//
// - As a side note, it looks like this format came about in 1989 and
// never went anywhere after that, and appears to have been the format
// used by Electronic Arts' DeluxePaint Animation, which never made it
// past version 1.0.
//
//****************************************************************************
void CPlayRunSkipDump(uint8_t *srcP, uint8_t *dstP)
static void CPlayRunSkipDump(uint8_t * srcP, uint8_t * dstP)
{
int8_t cnt;
uint16_t wordCnt;
uint8_t pixel;
nextOp:
cnt = (int8_t) *srcP++;
if (cnt > 0)
goto dump;
if (cnt == 0)
goto run;
cnt -= 0x80;
if (cnt == 0)
goto longOp;
/* shortSkip */
dstP += cnt; /* adding 7-bit count to 32-bit pointer */
goto nextOp;
dump:
do
{
*dstP++ = *srcP++;
}
while (--cnt);
goto nextOp;
run:
wordCnt = (uint8_t)*srcP++; /* 8-bit unsigned count */
pixel = *srcP++;
do
int32_t color, count=*srcP++;
if (count==0)
{
*dstP++ = pixel;
/* Short RLE */
count=*srcP;
color=*(srcP+1);
srcP += 2;
Bmemset(dstP,color,count);
dstP+=count;
}
while (--wordCnt);
goto nextOp;
longOp:
wordCnt = B_LITTLE16(*((uint16_t *)srcP));
srcP += sizeof(uint16_t);
if ((int16_t)wordCnt <= 0)
goto notLongSkip; /* Do SIGNED test. */
/* longSkip. */
dstP += wordCnt;
goto nextOp;
notLongSkip:
if (wordCnt == 0)
goto stop;
wordCnt -= 0x8000; /* Remove sign bit. */
if (wordCnt >= 0x4000)
goto longRun;
/* longDump. */
do
else if ((count&0x80) == 0)
{
*dstP++ = *srcP++;
/* Short copy */
Bmemcpy(dstP,srcP,count);
dstP+=count;
srcP+=count;
}
while (--wordCnt);
goto nextOp;
longRun:
wordCnt -= 0x4000; /* Clear "longRun" bit. */
pixel = *srcP++;
do
else
{
*dstP++ = pixel;
}
while (--wordCnt);
goto nextOp;
/* long op or short skip */
count &= ~0x80;
stop: /* all done */
;
if (count > 0) /* short skip */
dstP+=count;
else
{
/* long op */
count = *srcP+((*(srcP+1))<<8);
srcP += 2;
if (count==0) /* stop sign */
return;
if ((count&0x8000) == 0) /* long skip */
dstP+=count;
else
{
count &= ~0x8000;
if ((count&0x4000) == 0)
{
/* long copy */
Bmemcpy(dstP,srcP,count);
dstP+=count;
srcP+=count;
continue;
}
/* and finally, long RLE. */
count &= ~0x4000;
color=*srcP++;
Bmemset(dstP,color,count);
dstP+=count;
}
}
}
}
while (1);
}
//****************************************************************************