зеркало из https://github.com/mozilla/pjs.git
3829 строки
120 KiB
C
3829 строки
120 KiB
C
/* ************************************************************************** */
|
|
/* * For conditions of distribution and use, * */
|
|
/* * see copyright notice in libmng.h * */
|
|
/* ************************************************************************** */
|
|
/* * * */
|
|
/* * project : libmng * */
|
|
/* * file : libmng_object_prc.c copyright (c) 2000 G.Juyn * */
|
|
/* * version : 1.0.2 * */
|
|
/* * * */
|
|
/* * purpose : Object processing routines (implementation) * */
|
|
/* * * */
|
|
/* * author : G.Juyn * */
|
|
/* * web : http://www.3-t.com * */
|
|
/* * email : mailto:info@3-t.com * */
|
|
/* * * */
|
|
/* * comment : implementation of the internal object processing routines * */
|
|
/* * * */
|
|
/* * changes : 0.5.1 - 05/08/2000 - G.Juyn * */
|
|
/* * - changed strict-ANSI stuff * */
|
|
/* * 0.5.1 - 05/12/2000 - G.Juyn * */
|
|
/* * - changed trace to macro for callback error-reporting * */
|
|
/* * * */
|
|
/* * 0.5.2 - 05/20/2000 - G.Juyn * */
|
|
/* * - fixed to support JNG objects * */
|
|
/* * 0.5.2 - 05/24/2000 - G.Juyn * */
|
|
/* * - added support for global color-chunks in animation * */
|
|
/* * - added support for global PLTE,tRNS,bKGD in animation * */
|
|
/* * - added SAVE & SEEK animation objects * */
|
|
/* * 0.5.2 - 05/29/2000 - G.Juyn * */
|
|
/* * - added initialization of framenr/layernr/playtime * */
|
|
/* * - changed ani_object create routines not to return the * */
|
|
/* * created object (wasn't necessary) * */
|
|
/* * 0.5.2 - 05/30/2000 - G.Juyn * */
|
|
/* * - added object promotion routine (PROM handling) * */
|
|
/* * - added ani-object routines for delta-image processing * */
|
|
/* * - added compression/filter/interlace fields to * */
|
|
/* * object-buffer for delta-image processing * */
|
|
/* * * */
|
|
/* * 0.5.3 - 06/17/2000 - G.Juyn * */
|
|
/* * - changed support for delta-image processing * */
|
|
/* * 0.5.3 - 06/20/2000 - G.Juyn * */
|
|
/* * - fixed some small things (as precaution) * */
|
|
/* * 0.5.3 - 06/21/2000 - G.Juyn * */
|
|
/* * - added processing of PLTE/tRNS & color-info for * */
|
|
/* * delta-images in the ani_objects chain * */
|
|
/* * 0.5.3 - 06/22/2000 - G.Juyn * */
|
|
/* * - added support for PPLT chunk * */
|
|
/* * * */
|
|
/* * 0.9.1 - 07/07/2000 - G.Juyn * */
|
|
/* * - added support for freeze/restart/resume & go_xxxx * */
|
|
/* * 0.9.1 - 07/16/2000 - G.Juyn * */
|
|
/* * - fixed support for mng_display() after mng_read() * */
|
|
/* * * */
|
|
/* * 0.9.2 - 07/29/2000 - G.Juyn * */
|
|
/* * - fixed small bugs in display processing * */
|
|
/* * 0.9.2 - 08/05/2000 - G.Juyn * */
|
|
/* * - changed file-prefixes * */
|
|
/* * * */
|
|
/* * 0.9.3 - 08/07/2000 - G.Juyn * */
|
|
/* * - B111300 - fixup for improved portability * */
|
|
/* * 0.9.3 - 08/26/2000 - G.Juyn * */
|
|
/* * - added MAGN chunk * */
|
|
/* * 0.9.3 - 09/10/2000 - G.Juyn * */
|
|
/* * - fixed DEFI behavior * */
|
|
/* * 0.9.3 - 10/17/2000 - G.Juyn * */
|
|
/* * - added valid-flag to stored objects for read() / display()* */
|
|
/* * - added routine to discard "invalid" objects * */
|
|
/* * 0.9.3 - 10/18/2000 - G.Juyn * */
|
|
/* * - fixed delta-processing behavior * */
|
|
/* * 0.9.3 - 10/19/2000 - G.Juyn * */
|
|
/* * - added storage for pixel-/alpha-sampledepth for delta's * */
|
|
/* * * */
|
|
/* * 0.9.4 - 1/18/2001 - G.Juyn * */
|
|
/* * - removed "old" MAGN methods 3 & 4 * */
|
|
/* * - added "new" MAGN methods 3, 4 & 5 * */
|
|
/* * * */
|
|
/* * 0.9.5 - 1/22/2001 - G.Juyn * */
|
|
/* * - B129681 - fixed compiler warnings SGI/Irix * */
|
|
/* * * */
|
|
/* * 1.0.2 - 06/23/2001 - G.Juyn * */
|
|
/* * - added optimization option for MNG-video playback * */
|
|
/* * * */
|
|
/* ************************************************************************** */
|
|
|
|
#include "libmng.h"
|
|
#include "libmng_data.h"
|
|
#include "libmng_error.h"
|
|
#include "libmng_trace.h"
|
|
#ifdef __BORLANDC__
|
|
#pragma hdrstop
|
|
#endif
|
|
#include "libmng_memory.h"
|
|
#include "libmng_objects.h"
|
|
#include "libmng_display.h"
|
|
#include "libmng_pixels.h"
|
|
#include "libmng_object_prc.h"
|
|
|
|
#if defined(__BORLANDC__) && defined(MNG_STRICT_ANSI)
|
|
#pragma option -A /* force ANSI-C */
|
|
#endif
|
|
|
|
/* ************************************************************************** */
|
|
|
|
#ifdef MNG_INCLUDE_DISPLAY_PROCS
|
|
|
|
/* ************************************************************************** */
|
|
/* * * */
|
|
/* * Generic object routines * */
|
|
/* * * */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode drop_invalid_objects (mng_datap pData)
|
|
{
|
|
mng_objectp pObject;
|
|
mng_objectp pNext;
|
|
mng_cleanupobject fCleanup;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_DROP_INVALID_OBJECTS, MNG_LC_START)
|
|
#endif
|
|
|
|
pObject = pData->pFirstimgobj; /* get first stored image-object (if any) */
|
|
|
|
while (pObject) /* more objects to check ? */
|
|
{
|
|
pNext = ((mng_object_headerp)pObject)->pNext;
|
|
/* invalid ? */
|
|
if (!((mng_imagep)pObject)->bValid)
|
|
{ /* call appropriate cleanup */
|
|
fCleanup = ((mng_object_headerp)pObject)->fCleanup;
|
|
fCleanup (pData, pObject);
|
|
}
|
|
|
|
pObject = pNext; /* neeeext */
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_DROP_INVALID_OBJECTS, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* * * */
|
|
/* * Image-data-object routines * */
|
|
/* * * */
|
|
/* * these handle the "object buffer" as defined by the MNG specification * */
|
|
/* * * */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_imagedataobject (mng_datap pData,
|
|
mng_bool bConcrete,
|
|
mng_bool bViewable,
|
|
mng_uint32 iWidth,
|
|
mng_uint32 iHeight,
|
|
mng_uint8 iBitdepth,
|
|
mng_uint8 iColortype,
|
|
mng_uint8 iCompression,
|
|
mng_uint8 iFilter,
|
|
mng_uint8 iInterlace,
|
|
mng_imagedatap *ppObject)
|
|
{
|
|
mng_imagedatap pImagedata;
|
|
mng_uint32 iSamplesize = 0;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_IMGDATAOBJECT, MNG_LC_START)
|
|
#endif
|
|
/* get a buffer */
|
|
MNG_ALLOC (pData, pImagedata, sizeof (mng_imagedata))
|
|
/* fill the appropriate fields */
|
|
pImagedata->sHeader.fCleanup = (mng_cleanupobject)free_imagedataobject;
|
|
pImagedata->sHeader.fProcess = 0;
|
|
pImagedata->iRefcount = 1;
|
|
pImagedata->bFrozen = MNG_FALSE;
|
|
pImagedata->bConcrete = bConcrete;
|
|
pImagedata->bViewable = bViewable;
|
|
pImagedata->iWidth = iWidth;
|
|
pImagedata->iHeight = iHeight;
|
|
pImagedata->iBitdepth = iBitdepth;
|
|
pImagedata->iColortype = iColortype;
|
|
pImagedata->iCompression = iCompression;
|
|
pImagedata->iFilter = iFilter;
|
|
pImagedata->iInterlace = iInterlace;
|
|
pImagedata->iAlphabitdepth = 0;
|
|
pImagedata->iJHDRcompression = 0;
|
|
pImagedata->iJHDRinterlace = 0;
|
|
pImagedata->iPixelsampledepth = iBitdepth;
|
|
pImagedata->iAlphasampledepth = iBitdepth;
|
|
/* determine samplesize from color_type/bit_depth */
|
|
switch (iColortype) /* for < 8-bit samples we just reserve 8 bits */
|
|
{
|
|
case 0 : ; /* gray */
|
|
case 8 : { /* JPEG gray */
|
|
if (iBitdepth > 8)
|
|
iSamplesize = 2;
|
|
else
|
|
iSamplesize = 1;
|
|
|
|
break;
|
|
}
|
|
case 2 : ; /* rgb */
|
|
case 10 : { /* JPEG rgb */
|
|
if (iBitdepth > 8)
|
|
iSamplesize = 6;
|
|
else
|
|
iSamplesize = 3;
|
|
|
|
break;
|
|
}
|
|
case 3 : { /* indexed */
|
|
iSamplesize = 1;
|
|
break;
|
|
}
|
|
case 4 : ; /* gray+alpha */
|
|
case 12 : { /* JPEG gray+alpha */
|
|
if (iBitdepth > 8)
|
|
iSamplesize = 4;
|
|
else
|
|
iSamplesize = 2;
|
|
|
|
break;
|
|
}
|
|
case 6 : ; /* rgb+alpha */
|
|
case 14 : { /* JPEG rgb+alpha */
|
|
if (iBitdepth > 8)
|
|
iSamplesize = 8;
|
|
else
|
|
iSamplesize = 4;
|
|
|
|
break;
|
|
}
|
|
}
|
|
/* make sure we remember all this */
|
|
pImagedata->iSamplesize = iSamplesize;
|
|
pImagedata->iRowsize = iSamplesize * iWidth;
|
|
pImagedata->iImgdatasize = pImagedata->iRowsize * iHeight;
|
|
|
|
if (pImagedata->iImgdatasize) /* need a buffer ? */
|
|
{ /* so allocate it */
|
|
MNG_ALLOCX (pData, pImagedata->pImgdata, pImagedata->iImgdatasize)
|
|
|
|
if (!pImagedata->pImgdata) /* enough memory ? */
|
|
{
|
|
MNG_FREEX (pData, pImagedata, sizeof (mng_imagedata))
|
|
MNG_ERROR (pData, MNG_OUTOFMEMORY)
|
|
}
|
|
}
|
|
/* check global stuff */
|
|
pImagedata->bHasGAMA = pData->bHasglobalGAMA;
|
|
pImagedata->bHasCHRM = pData->bHasglobalCHRM;
|
|
pImagedata->bHasSRGB = pData->bHasglobalSRGB;
|
|
pImagedata->bHasICCP = pData->bHasglobalICCP;
|
|
pImagedata->bHasBKGD = pData->bHasglobalBKGD;
|
|
|
|
if (pData->bHasglobalGAMA) /* global gAMA present ? */
|
|
pImagedata->iGamma = pData->iGlobalGamma;
|
|
|
|
if (pData->bHasglobalCHRM) /* global cHRM present ? */
|
|
{
|
|
pImagedata->iWhitepointx = pData->iGlobalWhitepointx;
|
|
pImagedata->iWhitepointy = pData->iGlobalWhitepointy;
|
|
pImagedata->iPrimaryredx = pData->iGlobalPrimaryredx;
|
|
pImagedata->iPrimaryredy = pData->iGlobalPrimaryredy;
|
|
pImagedata->iPrimarygreenx = pData->iGlobalPrimarygreenx;
|
|
pImagedata->iPrimarygreeny = pData->iGlobalPrimarygreeny;
|
|
pImagedata->iPrimarybluex = pData->iGlobalPrimarybluex;
|
|
pImagedata->iPrimarybluey = pData->iGlobalPrimarybluey;
|
|
}
|
|
|
|
if (pData->bHasglobalSRGB) /* glbal sRGB present ? */
|
|
pImagedata->iRenderingintent = pData->iGlobalRendintent;
|
|
|
|
if (pData->bHasglobalICCP) /* glbal iCCP present ? */
|
|
{
|
|
pImagedata->iProfilesize = pData->iGlobalProfilesize;
|
|
|
|
if (pImagedata->iProfilesize)
|
|
{
|
|
MNG_ALLOCX (pData, pImagedata->pProfile, pImagedata->iProfilesize)
|
|
|
|
if (!pImagedata->pProfile) /* enough memory ? */
|
|
{
|
|
MNG_FREEX (pData, pImagedata->pImgdata, pImagedata->iImgdatasize)
|
|
MNG_FREEX (pData, pImagedata, sizeof (mng_imagedata))
|
|
MNG_ERROR (pData, MNG_OUTOFMEMORY)
|
|
}
|
|
|
|
MNG_COPY (pImagedata->pProfile, pData->pGlobalProfile, pImagedata->iProfilesize)
|
|
}
|
|
}
|
|
|
|
if (pData->bHasglobalBKGD) /* global bKGD present ? */
|
|
{
|
|
pImagedata->iBKGDred = pData->iGlobalBKGDred;
|
|
pImagedata->iBKGDgreen = pData->iGlobalBKGDgreen;
|
|
pImagedata->iBKGDblue = pData->iGlobalBKGDblue;
|
|
}
|
|
|
|
*ppObject = pImagedata; /* return it */
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_IMGDATAOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_imagedataobject (mng_datap pData,
|
|
mng_imagedatap pImagedata)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_IMGDATAOBJECT, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pImagedata->iRefcount) /* decrease reference count */
|
|
pImagedata->iRefcount--;
|
|
|
|
if (!pImagedata->iRefcount) /* reached zero ? */
|
|
{
|
|
if (pImagedata->iProfilesize) /* stored an iCCP profile ? */
|
|
MNG_FREEX (pData, pImagedata->pProfile, pImagedata->iProfilesize)
|
|
|
|
if (pImagedata->iImgdatasize) /* sample-buffer present ? */
|
|
MNG_FREEX (pData, pImagedata->pImgdata, pImagedata->iImgdatasize)
|
|
/* drop the buffer */
|
|
MNG_FREEX (pData, pImagedata, sizeof (mng_imagedata))
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_IMGDATAOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode clone_imagedataobject (mng_datap pData,
|
|
mng_bool bConcrete,
|
|
mng_imagedatap pSource,
|
|
mng_imagedatap *ppClone)
|
|
{
|
|
mng_imagedatap pNewdata;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CLONE_IMGDATAOBJECT, MNG_LC_START)
|
|
#endif
|
|
/* get a buffer */
|
|
MNG_ALLOC (pData, pNewdata, sizeof (mng_imagedata))
|
|
/* blatently copy the original buffer */
|
|
MNG_COPY (pNewdata, pSource, sizeof (mng_imagedata))
|
|
|
|
pNewdata->iRefcount = 1; /* only the reference count */
|
|
pNewdata->bConcrete = bConcrete; /* and concrete-flag are different */
|
|
|
|
if (pNewdata->iImgdatasize) /* sample buffer present ? */
|
|
{
|
|
MNG_ALLOCX (pData, pNewdata->pImgdata, pNewdata->iImgdatasize)
|
|
|
|
if (!pNewdata->pImgdata) /* not enough memory ? */
|
|
{
|
|
MNG_FREEX (pData, pNewdata, sizeof (mng_imagedata))
|
|
MNG_ERROR (pData, MNG_OUTOFMEMORY)
|
|
}
|
|
/* make a copy */
|
|
MNG_COPY (pNewdata->pImgdata, pSource->pImgdata, pNewdata->iImgdatasize)
|
|
}
|
|
|
|
if (pNewdata->iProfilesize) /* iCCP profile present ? */
|
|
{
|
|
MNG_ALLOCX (pData, pNewdata->pProfile, pNewdata->iProfilesize)
|
|
|
|
if (!pNewdata->pProfile) /* enough memory ? */
|
|
{
|
|
MNG_FREEX (pData, pNewdata, sizeof (mng_imagedata))
|
|
MNG_ERROR (pData, MNG_OUTOFMEMORY)
|
|
}
|
|
/* make a copy */
|
|
MNG_COPY (pNewdata->pProfile, pSource->pProfile, pNewdata->iProfilesize)
|
|
}
|
|
|
|
*ppClone = pNewdata; /* return the clone */
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CLONE_IMGDATAOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* * * */
|
|
/* * Image-object routines * */
|
|
/* * * */
|
|
/* * these handle the "object" as defined by the MNG specification * */
|
|
/* * * */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_imageobject (mng_datap pData,
|
|
mng_uint16 iId,
|
|
mng_bool bConcrete,
|
|
mng_bool bVisible,
|
|
mng_bool bViewable,
|
|
mng_uint32 iWidth,
|
|
mng_uint32 iHeight,
|
|
mng_uint8 iBitdepth,
|
|
mng_uint8 iColortype,
|
|
mng_uint8 iCompression,
|
|
mng_uint8 iFilter,
|
|
mng_uint8 iInterlace,
|
|
mng_int32 iPosx,
|
|
mng_int32 iPosy,
|
|
mng_bool bClipped,
|
|
mng_int32 iClipl,
|
|
mng_int32 iClipr,
|
|
mng_int32 iClipt,
|
|
mng_int32 iClipb,
|
|
mng_imagep *ppObject)
|
|
{
|
|
mng_imagep pImage;
|
|
mng_imagep pPrev, pNext;
|
|
mng_retcode iRetcode;
|
|
mng_imagedatap pImgbuf;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_IMGOBJECT, MNG_LC_START)
|
|
#endif
|
|
/* get a buffer */
|
|
MNG_ALLOC (pData, pImage, sizeof (mng_image))
|
|
/* now get a new "object buffer" */
|
|
iRetcode = create_imagedataobject (pData, bConcrete, bViewable,
|
|
iWidth, iHeight, iBitdepth, iColortype,
|
|
iCompression, iFilter, iInterlace,
|
|
&pImgbuf);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
{
|
|
MNG_FREEX (pData, pImage, sizeof (mng_image))
|
|
return iRetcode;
|
|
}
|
|
/* fill the appropriate fields */
|
|
pImage->sHeader.fCleanup = (mng_cleanupobject)free_imageobject;
|
|
pImage->sHeader.fProcess = 0;
|
|
pImage->iId = iId;
|
|
pImage->bFrozen = MNG_FALSE;
|
|
pImage->bVisible = bVisible;
|
|
pImage->bViewable = bViewable;
|
|
pImage->bValid = (mng_bool)((pData->bDisplaying) &&
|
|
(pData->bRunning ) &&
|
|
(!pData->bFreezing ) );
|
|
pImage->iPosx = iPosx;
|
|
pImage->iPosy = iPosy;
|
|
pImage->bClipped = bClipped;
|
|
pImage->iClipl = iClipl;
|
|
pImage->iClipr = iClipr;
|
|
pImage->iClipt = iClipt;
|
|
pImage->iClipb = iClipb;
|
|
pImage->iMAGN_MethodX = 0;
|
|
pImage->iMAGN_MethodY = 0;
|
|
pImage->iMAGN_MX = 0;
|
|
pImage->iMAGN_MY = 0;
|
|
pImage->iMAGN_ML = 0;
|
|
pImage->iMAGN_MR = 0;
|
|
pImage->iMAGN_MT = 0;
|
|
pImage->iMAGN_MB = 0;
|
|
pImage->pImgbuf = pImgbuf;
|
|
|
|
if (iId) /* only if not object 0 ! */
|
|
{ /* find previous lower object-id */
|
|
pPrev = (mng_imagep)pData->pLastimgobj;
|
|
|
|
while ((pPrev) && (pPrev->iId > iId))
|
|
pPrev = (mng_imagep)pPrev->sHeader.pPrev;
|
|
|
|
if (pPrev) /* found it ? */
|
|
{
|
|
pImage->sHeader.pPrev = pPrev; /* than link it in place */
|
|
pImage->sHeader.pNext = pPrev->sHeader.pNext;
|
|
pPrev->sHeader.pNext = pImage;
|
|
}
|
|
else /* if not found, it becomes the first ! */
|
|
{
|
|
pImage->sHeader.pNext = pData->pFirstimgobj;
|
|
pData->pFirstimgobj = pImage;
|
|
}
|
|
|
|
pNext = (mng_imagep)pImage->sHeader.pNext;
|
|
|
|
if (pNext)
|
|
pNext->sHeader.pPrev = pImage;
|
|
else
|
|
pData->pLastimgobj = pImage;
|
|
|
|
}
|
|
|
|
*ppObject = pImage; /* and return the new buffer */
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_IMGOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR; /* okido */
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_imageobject (mng_datap pData,
|
|
mng_imagep pImage)
|
|
{
|
|
mng_retcode iRetcode;
|
|
mng_imagep pPrev = pImage->sHeader.pPrev;
|
|
mng_imagep pNext = pImage->sHeader.pNext;
|
|
mng_imagedatap pImgbuf = pImage->pImgbuf;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_IMGOBJECT, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pImage->iId) /* not for object 0 */
|
|
{
|
|
if (pPrev) /* unlink from the list first ! */
|
|
pPrev->sHeader.pNext = pImage->sHeader.pNext;
|
|
else
|
|
pData->pFirstimgobj = pImage->sHeader.pNext;
|
|
|
|
if (pNext)
|
|
pNext->sHeader.pPrev = pImage->sHeader.pPrev;
|
|
else
|
|
pData->pLastimgobj = pImage->sHeader.pPrev;
|
|
|
|
}
|
|
/* unlink the image-data buffer */
|
|
iRetcode = free_imagedataobject (pData, pImgbuf);
|
|
/* drop it's own buffer */
|
|
MNG_FREEX (pData, pImage, sizeof (mng_image))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_IMGOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return iRetcode;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_imagep find_imageobject (mng_datap pData,
|
|
mng_uint16 iId)
|
|
{
|
|
mng_imagep pImage = (mng_imagep)pData->pFirstimgobj;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACEX (pData, MNG_FN_FIND_IMGOBJECT, MNG_LC_START)
|
|
#endif
|
|
/* look up the right id */
|
|
while ((pImage) && (pImage->iId != iId))
|
|
pImage = (mng_imagep)pImage->sHeader.pNext;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACEX (pData, MNG_FN_FIND_IMGOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return pImage;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode clone_imageobject (mng_datap pData,
|
|
mng_uint16 iId,
|
|
mng_bool bPartial,
|
|
mng_bool bVisible,
|
|
mng_bool bAbstract,
|
|
mng_bool bHasloca,
|
|
mng_uint8 iLocationtype,
|
|
mng_int32 iLocationx,
|
|
mng_int32 iLocationy,
|
|
mng_imagep pSource,
|
|
mng_imagep *ppClone)
|
|
{
|
|
mng_imagep pNew;
|
|
mng_imagep pPrev, pNext;
|
|
mng_retcode iRetcode;
|
|
mng_imagedatap pImgbuf;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CLONE_IMGOBJECT, MNG_LC_START)
|
|
#endif
|
|
|
|
if ((pSource->iId) && /* needs magnification ? */
|
|
((pSource->iMAGN_MethodX) || (pSource->iMAGN_MethodY)))
|
|
{
|
|
iRetcode = magnify_imageobject (pData, pSource);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
}
|
|
/* get a buffer */
|
|
MNG_ALLOC (pData, pNew, sizeof (mng_image))
|
|
/* fill or copy the appropriate fields */
|
|
pNew->sHeader.fCleanup = (mng_cleanupobject)free_imageobject;
|
|
pNew->sHeader.fProcess = 0;
|
|
pNew->iId = iId;
|
|
pNew->bFrozen = MNG_FALSE;
|
|
pNew->bVisible = bVisible;
|
|
pNew->bViewable = pSource->bViewable;
|
|
|
|
if (bHasloca) /* location info available ? */
|
|
{
|
|
if (iLocationtype == 0) /* absolute position ? */
|
|
{
|
|
pNew->iPosx = iLocationx;
|
|
pNew->iPosy = iLocationy;
|
|
}
|
|
else /* relative */
|
|
{
|
|
pNew->iPosx = pSource->iPosx + iLocationx;
|
|
pNew->iPosy = pSource->iPosy + iLocationy;
|
|
}
|
|
}
|
|
else /* copy from source */
|
|
{
|
|
pNew->iPosx = pSource->iPosx;
|
|
pNew->iPosy = pSource->iPosy;
|
|
}
|
|
/* copy clipping info */
|
|
pNew->bClipped = pSource->bClipped;
|
|
pNew->iClipl = pSource->iClipl;
|
|
pNew->iClipr = pSource->iClipr;
|
|
pNew->iClipt = pSource->iClipt;
|
|
pNew->iClipb = pSource->iClipb;
|
|
/* copy magnification info */
|
|
pNew->iMAGN_MethodX = pSource->iMAGN_MethodX;
|
|
pNew->iMAGN_MethodY = pSource->iMAGN_MethodY;
|
|
pNew->iMAGN_MX = pSource->iMAGN_MX;
|
|
pNew->iMAGN_MY = pSource->iMAGN_MY;
|
|
pNew->iMAGN_ML = pSource->iMAGN_ML;
|
|
pNew->iMAGN_MR = pSource->iMAGN_MR;
|
|
pNew->iMAGN_MT = pSource->iMAGN_MT;
|
|
pNew->iMAGN_MB = pSource->iMAGN_MB;
|
|
|
|
if (iId) /* not for object 0 */
|
|
{ /* find previous lower object-id */
|
|
pPrev = (mng_imagep)pData->pLastimgobj;
|
|
while ((pPrev) && (pPrev->iId > iId))
|
|
pPrev = (mng_imagep)pPrev->sHeader.pPrev;
|
|
|
|
if (pPrev) /* found it ? */
|
|
{
|
|
pNew->sHeader.pPrev = pPrev; /* than link it in place */
|
|
pNew->sHeader.pNext = pPrev->sHeader.pNext;
|
|
pPrev->sHeader.pNext = pNew;
|
|
}
|
|
else /* if not found, it becomes the first ! */
|
|
{
|
|
pNew->sHeader.pNext = pData->pFirstimgobj;
|
|
pData->pFirstimgobj = pNew;
|
|
}
|
|
|
|
pNext = (mng_imagep)pNew->sHeader.pNext;
|
|
|
|
if (pNext)
|
|
pNext->sHeader.pPrev = pNew;
|
|
else
|
|
pData->pLastimgobj = pNew;
|
|
|
|
}
|
|
|
|
if (bPartial) /* partial clone ? */
|
|
{
|
|
pNew->pImgbuf = pSource->pImgbuf; /* use the same object buffer */
|
|
pNew->pImgbuf->iRefcount++; /* and increase the reference count */
|
|
}
|
|
else /* create a full clone ! */
|
|
{
|
|
mng_bool bConcrete = MNG_FALSE; /* it's abstract by default (?) */
|
|
|
|
if (!bAbstract) /* determine concreteness from source ? */
|
|
bConcrete = pSource->pImgbuf->bConcrete;
|
|
/* create a full clone ! */
|
|
iRetcode = clone_imagedataobject (pData, bConcrete, pSource->pImgbuf, &pImgbuf);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
{
|
|
MNG_FREEX (pData, pNew, sizeof (mng_image))
|
|
return iRetcode;
|
|
}
|
|
|
|
pNew->pImgbuf = pImgbuf; /* and remember it */
|
|
}
|
|
|
|
*ppClone = pNew; /* return it */
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CLONE_IMGOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode renum_imageobject (mng_datap pData,
|
|
mng_imagep pSource,
|
|
mng_uint16 iId,
|
|
mng_bool bVisible,
|
|
mng_bool bAbstract,
|
|
mng_bool bHasloca,
|
|
mng_uint8 iLocationtype,
|
|
mng_int32 iLocationx,
|
|
mng_int32 iLocationy)
|
|
{
|
|
mng_imagep pPrev, pNext;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_RENUM_IMGOBJECT, MNG_LC_START)
|
|
#endif
|
|
|
|
pSource->bVisible = bVisible; /* store the new visibility */
|
|
|
|
if (bHasloca) /* location info available ? */
|
|
{
|
|
if (iLocationtype == 0) /* absolute position ? */
|
|
{
|
|
pSource->iPosx = iLocationx;
|
|
pSource->iPosy = iLocationy;
|
|
}
|
|
else /* relative */
|
|
{
|
|
pSource->iPosx = pSource->iPosx + iLocationx;
|
|
pSource->iPosy = pSource->iPosy + iLocationy;
|
|
}
|
|
}
|
|
|
|
if (iId) /* not for object 0 */
|
|
{ /* find previous lower object-id */
|
|
pPrev = (mng_imagep)pData->pLastimgobj;
|
|
while ((pPrev) && (pPrev->iId > iId))
|
|
pPrev = (mng_imagep)pPrev->sHeader.pPrev;
|
|
/* different from current ? */
|
|
if (pPrev != (mng_imagep)pSource->sHeader.pPrev)
|
|
{
|
|
if (pSource->sHeader.pPrev) /* unlink from current position !! */
|
|
((mng_imagep)pSource->sHeader.pPrev)->sHeader.pNext = pSource->sHeader.pNext;
|
|
else
|
|
pData->pFirstimgobj = pSource->sHeader.pNext;
|
|
|
|
if (pSource->sHeader.pNext)
|
|
((mng_imagep)pSource->sHeader.pNext)->sHeader.pPrev = pSource->sHeader.pPrev;
|
|
else
|
|
pData->pLastimgobj = pSource->sHeader.pPrev;
|
|
|
|
if (pPrev) /* found the previous ? */
|
|
{ /* than link it in place */
|
|
pSource->sHeader.pPrev = pPrev;
|
|
pSource->sHeader.pNext = pPrev->sHeader.pNext;
|
|
pPrev->sHeader.pNext = pSource;
|
|
}
|
|
else /* if not found, it becomes the first ! */
|
|
{
|
|
pSource->sHeader.pNext = pData->pFirstimgobj;
|
|
pData->pFirstimgobj = pSource;
|
|
}
|
|
|
|
pNext = (mng_imagep)pSource->sHeader.pNext;
|
|
|
|
if (pNext)
|
|
pNext->sHeader.pPrev = pSource;
|
|
else
|
|
pData->pLastimgobj = pSource;
|
|
|
|
}
|
|
}
|
|
|
|
pSource->iId = iId; /* now set the new id! */
|
|
|
|
if (bAbstract) /* force it to abstract ? */
|
|
pSource->pImgbuf->bConcrete = MNG_FALSE;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_RENUM_IMGOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode reset_object_details (mng_datap pData,
|
|
mng_imagep pImage,
|
|
mng_uint32 iWidth,
|
|
mng_uint32 iHeight,
|
|
mng_uint8 iBitdepth,
|
|
mng_uint8 iColortype,
|
|
mng_uint8 iCompression,
|
|
mng_uint8 iFilter,
|
|
mng_uint8 iInterlace,
|
|
mng_bool bResetall)
|
|
{
|
|
mng_imagedatap pBuf = pImage->pImgbuf;
|
|
mng_uint32 iSamplesize = 0;
|
|
mng_uint32 iRowsize;
|
|
mng_uint32 iImgdatasize;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_RESET_OBJECTDETAILS, MNG_LC_START)
|
|
#endif
|
|
|
|
pBuf->iWidth = iWidth; /* set buffer characteristics */
|
|
pBuf->iHeight = iHeight;
|
|
pBuf->iBitdepth = iBitdepth;
|
|
pBuf->iColortype = iColortype;
|
|
pBuf->iCompression = iCompression;
|
|
pBuf->iFilter = iFilter;
|
|
pBuf->iInterlace = iInterlace;
|
|
pBuf->iAlphabitdepth = 0;
|
|
/* determine samplesize from color_type/bit_depth */
|
|
switch (iColortype) /* for < 8-bit samples we just reserve 8 bits */
|
|
{
|
|
case 0 : ; /* gray */
|
|
case 8 : { /* JPEG gray */
|
|
if (iBitdepth > 8)
|
|
iSamplesize = 2;
|
|
else
|
|
iSamplesize = 1;
|
|
|
|
break;
|
|
}
|
|
case 2 : ; /* rgb */
|
|
case 10 : { /* JPEG rgb */
|
|
if (iBitdepth > 8)
|
|
iSamplesize = 6;
|
|
else
|
|
iSamplesize = 3;
|
|
|
|
break;
|
|
}
|
|
case 3 : { /* indexed */
|
|
iSamplesize = 1;
|
|
break;
|
|
}
|
|
case 4 : ; /* gray+alpha */
|
|
case 12 : { /* JPEG gray+alpha */
|
|
if (iBitdepth > 8)
|
|
iSamplesize = 4;
|
|
else
|
|
iSamplesize = 2;
|
|
|
|
break;
|
|
}
|
|
case 6 : ; /* rgb+alpha */
|
|
case 14 : { /* JPEG rgb+alpha */
|
|
if (iBitdepth > 8)
|
|
iSamplesize = 8;
|
|
else
|
|
iSamplesize = 4;
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
iRowsize = iSamplesize * iWidth;
|
|
iImgdatasize = iRowsize * iHeight;
|
|
/* buffer size changed ? */
|
|
if (iImgdatasize != pBuf->iImgdatasize)
|
|
{ /* drop the old one */
|
|
MNG_FREE (pData, pBuf->pImgdata, pBuf->iImgdatasize)
|
|
|
|
if (iImgdatasize) /* allocate new sample-buffer ? */
|
|
MNG_ALLOC (pData, pBuf->pImgdata, iImgdatasize)
|
|
}
|
|
|
|
pBuf->iSamplesize = iSamplesize; /* remember new sizes */
|
|
pBuf->iRowsize = iRowsize;
|
|
pBuf->iImgdatasize = iImgdatasize;
|
|
/* dimension set and clipping not ? */
|
|
if ((iWidth) && (iHeight) && (!pImage->bClipped))
|
|
{
|
|
pImage->iClipl = 0; /* set clipping to dimension by default */
|
|
pImage->iClipr = iWidth;
|
|
pImage->iClipt = 0;
|
|
pImage->iClipb = iHeight;
|
|
}
|
|
|
|
if (pImage->iId) /* reset magnification info ? */
|
|
{
|
|
pImage->iMAGN_MethodX = 0;
|
|
pImage->iMAGN_MethodY = 0;
|
|
pImage->iMAGN_MX = 0;
|
|
pImage->iMAGN_MY = 0;
|
|
pImage->iMAGN_ML = 0;
|
|
pImage->iMAGN_MR = 0;
|
|
pImage->iMAGN_MT = 0;
|
|
pImage->iMAGN_MB = 0;
|
|
}
|
|
|
|
if (bResetall) /* reset the other characteristics ? */
|
|
{
|
|
pBuf->bHasPLTE = MNG_FALSE;
|
|
pBuf->bHasTRNS = MNG_FALSE;
|
|
pBuf->bHasGAMA = pData->bHasglobalGAMA;
|
|
pBuf->bHasCHRM = pData->bHasglobalCHRM;
|
|
pBuf->bHasSRGB = pData->bHasglobalSRGB;
|
|
pBuf->bHasICCP = pData->bHasglobalICCP;
|
|
pBuf->bHasBKGD = pData->bHasglobalBKGD;
|
|
|
|
if (pBuf->iProfilesize) /* drop possibly old ICC profile */
|
|
{
|
|
MNG_FREE (pData, pBuf->pProfile, pBuf->iProfilesize)
|
|
pBuf->iProfilesize = 0;
|
|
}
|
|
|
|
if (pData->bHasglobalGAMA) /* global gAMA present ? */
|
|
pBuf->iGamma = pData->iGlobalGamma;
|
|
|
|
if (pData->bHasglobalCHRM) /* global cHRM present ? */
|
|
{
|
|
pBuf->iWhitepointx = pData->iGlobalWhitepointx;
|
|
pBuf->iWhitepointy = pData->iGlobalWhitepointy;
|
|
pBuf->iPrimaryredx = pData->iGlobalPrimaryredx;
|
|
pBuf->iPrimaryredy = pData->iGlobalPrimaryredy;
|
|
pBuf->iPrimarygreenx = pData->iGlobalPrimarygreenx;
|
|
pBuf->iPrimarygreeny = pData->iGlobalPrimarygreeny;
|
|
pBuf->iPrimarybluex = pData->iGlobalPrimarybluex;
|
|
pBuf->iPrimarybluey = pData->iGlobalPrimarybluey;
|
|
}
|
|
|
|
if (pData->bHasglobalSRGB) /* global sRGB present ? */
|
|
pBuf->iRenderingintent = pData->iGlobalRendintent;
|
|
|
|
if (pData->bHasglobalICCP) /* global iCCP present ? */
|
|
{
|
|
if (pData->iGlobalProfilesize)
|
|
{
|
|
MNG_ALLOC (pData, pBuf->pProfile, pData->iGlobalProfilesize)
|
|
MNG_COPY (pBuf->pProfile, pData->pGlobalProfile, pData->iGlobalProfilesize)
|
|
}
|
|
|
|
pBuf->iProfilesize = pData->iGlobalProfilesize;
|
|
}
|
|
|
|
if (pData->bHasglobalBKGD) /* global bKGD present ? */
|
|
{
|
|
pBuf->iBKGDred = pData->iGlobalBKGDred;
|
|
pBuf->iBKGDgreen = pData->iGlobalBKGDgreen;
|
|
pBuf->iBKGDblue = pData->iGlobalBKGDblue;
|
|
}
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_RESET_OBJECTDETAILS, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode promote_imageobject (mng_datap pData,
|
|
mng_imagep pImage,
|
|
mng_uint8 iBitdepth,
|
|
mng_uint8 iColortype,
|
|
mng_uint8 iFilltype)
|
|
{
|
|
mng_uint8p pNewbuf;
|
|
mng_uint32 iNewbufsize;
|
|
mng_uint32 iNewrowsize;
|
|
mng_uint32 iNewsamplesize;
|
|
mng_uint32 iX, iY;
|
|
mng_uint8p pSrcline, pDstline;
|
|
mng_uint8 iB;
|
|
mng_imagedatap pBuf = pImage->pImgbuf;
|
|
mng_uint32 iW = pBuf->iWidth;
|
|
mng_uint32 iH = pBuf->iHeight;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROMOTE_IMGOBJECT, MNG_LC_START)
|
|
#endif
|
|
|
|
if ((pBuf->iColortype == 3) && (iColortype == 2))
|
|
{ /* indexed -> rgb */
|
|
iNewsamplesize = 3;
|
|
iNewrowsize = iW * iNewsamplesize;
|
|
iNewbufsize = iH * iNewrowsize;
|
|
|
|
MNG_ALLOC (pData, pNewbuf, iNewbufsize)
|
|
|
|
pSrcline = pBuf->pImgdata;
|
|
pDstline = pNewbuf;
|
|
|
|
for (iY = 0; iY < iH; iY++)
|
|
{
|
|
for (iX = 0; iX < iW; iX++)
|
|
{
|
|
iB = *pSrcline;
|
|
|
|
if ((mng_uint32)iB < pBuf->iPLTEcount)
|
|
{
|
|
*pDstline = pBuf->aPLTEentries [iB].iRed;
|
|
*(pDstline+1) = pBuf->aPLTEentries [iB].iGreen;
|
|
*(pDstline+2) = pBuf->aPLTEentries [iB].iBlue;
|
|
}
|
|
|
|
pSrcline++;
|
|
pDstline += 3;
|
|
}
|
|
}
|
|
|
|
MNG_FREEX (pData, pBuf->pImgdata, pBuf->iImgdatasize)
|
|
|
|
pBuf->iBitdepth = iBitdepth;
|
|
pBuf->iColortype = iColortype;
|
|
pBuf->iSamplesize = iNewsamplesize;
|
|
pBuf->iRowsize = iNewrowsize;
|
|
pBuf->iImgdatasize = iNewbufsize;
|
|
pBuf->pImgdata = pNewbuf;
|
|
pBuf->bHasPLTE = MNG_FALSE;
|
|
pBuf->bHasTRNS = MNG_FALSE;
|
|
}
|
|
else
|
|
if ((pBuf->iColortype == 3) && (iColortype == 6))
|
|
{ /* indexed -> rgba */
|
|
iNewsamplesize = 4;
|
|
iNewrowsize = iW * iNewsamplesize;
|
|
iNewbufsize = iH * iNewrowsize;
|
|
|
|
MNG_ALLOC (pData, pNewbuf, iNewbufsize)
|
|
|
|
pSrcline = pBuf->pImgdata;
|
|
pDstline = pNewbuf;
|
|
|
|
for (iY = 0; iY < iH; iY++)
|
|
{
|
|
for (iX = 0; iX < iW; iX++)
|
|
{
|
|
iB = *pSrcline;
|
|
|
|
if ((mng_uint32)iB < pBuf->iPLTEcount)
|
|
{
|
|
*pDstline = pBuf->aPLTEentries [iB].iRed;
|
|
*(pDstline+1) = pBuf->aPLTEentries [iB].iGreen;
|
|
*(pDstline+2) = pBuf->aPLTEentries [iB].iBlue;
|
|
|
|
if ((mng_uint32)iB < pBuf->iTRNScount)
|
|
*(pDstline+3) = pBuf->aTRNSentries [iB];
|
|
else
|
|
*(pDstline+3) = 255;
|
|
}
|
|
|
|
pSrcline++;
|
|
pDstline += 4;
|
|
}
|
|
}
|
|
|
|
MNG_FREEX (pData, pBuf->pImgdata, pBuf->iImgdatasize)
|
|
|
|
pBuf->iBitdepth = iBitdepth;
|
|
pBuf->iColortype = iColortype;
|
|
pBuf->iSamplesize = iNewsamplesize;
|
|
pBuf->iRowsize = iNewrowsize;
|
|
pBuf->iImgdatasize = iNewbufsize;
|
|
pBuf->pImgdata = pNewbuf;
|
|
pBuf->bHasPLTE = MNG_FALSE;
|
|
pBuf->bHasTRNS = MNG_FALSE;
|
|
}
|
|
else
|
|
{
|
|
|
|
/* TODO: other promotion */
|
|
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROMOTE_IMGOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode magnify_imageobject (mng_datap pData,
|
|
mng_imagep pImage)
|
|
{
|
|
mng_uint8p pNewdata;
|
|
mng_uint8p pSrcline1;
|
|
mng_uint8p pSrcline2;
|
|
mng_uint8p pTempline;
|
|
mng_uint8p pDstline;
|
|
mng_uint32 iNewrowsize;
|
|
mng_uint32 iNewsize;
|
|
mng_uint32 iY;
|
|
mng_int32 iS, iM;
|
|
mng_retcode iRetcode;
|
|
|
|
mng_imagedatap pBuf = pImage->pImgbuf;
|
|
mng_uint32 iNewW = pBuf->iWidth;
|
|
mng_uint32 iNewH = pBuf->iHeight;
|
|
mng_magnify_x fMagnifyX = MNG_NULL;
|
|
mng_magnify_y fMagnifyY = MNG_NULL;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_MAGNIFY_IMGOBJECT, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pBuf->iColortype == 3) /* indexed color ? */
|
|
{ /* concrete buffer ? */
|
|
if ((pBuf->bConcrete) && (pImage->iId))
|
|
MNG_ERROR (pData, MNG_INVALIDCOLORTYPE)
|
|
|
|
if (pBuf->iTRNScount) /* with transparency ? */
|
|
iRetcode = promote_imageobject (pData, pImage, 8, 6, 0);
|
|
else
|
|
iRetcode = promote_imageobject (pData, pImage, 8, 2, 0);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
}
|
|
|
|
if (pImage->iMAGN_MethodX) /* determine new width */
|
|
{
|
|
if (pImage->iMAGN_MethodX == 1)
|
|
{
|
|
iNewW = pImage->iMAGN_ML;
|
|
if (pBuf->iWidth > 1)
|
|
iNewW = iNewW + pImage->iMAGN_MR;
|
|
if (pBuf->iWidth > 2)
|
|
iNewW = iNewW + (pBuf->iWidth - 2) * (pImage->iMAGN_MX);
|
|
}
|
|
else
|
|
{
|
|
iNewW = pBuf->iWidth + pImage->iMAGN_ML - 1;
|
|
if (pBuf->iWidth > 2)
|
|
iNewW = iNewW + pImage->iMAGN_MR - 1;
|
|
if (pBuf->iWidth > 3)
|
|
iNewW = iNewW + (pBuf->iWidth - 3) * (pImage->iMAGN_MX - 1);
|
|
}
|
|
}
|
|
|
|
if (pImage->iMAGN_MethodY) /* determine new height */
|
|
{
|
|
if (pImage->iMAGN_MethodY == 1)
|
|
{
|
|
iNewH = pImage->iMAGN_MT;
|
|
if (pBuf->iHeight > 1)
|
|
iNewH = iNewH + pImage->iMAGN_ML;
|
|
if (pBuf->iHeight > 2)
|
|
iNewH = iNewH + (pBuf->iHeight - 2) * (pImage->iMAGN_MY);
|
|
}
|
|
else
|
|
{
|
|
iNewH = pBuf->iHeight + pImage->iMAGN_MT - 1;
|
|
if (pBuf->iHeight > 2)
|
|
iNewH = iNewH + pImage->iMAGN_MB - 1;
|
|
if (pBuf->iHeight > 3)
|
|
iNewH = iNewH + (pBuf->iHeight - 3) * (pImage->iMAGN_MY - 1);
|
|
}
|
|
}
|
|
/* get new buffer */
|
|
iNewrowsize = iNewW * pBuf->iSamplesize;
|
|
iNewsize = iNewH * iNewrowsize;
|
|
|
|
MNG_ALLOC (pData, pNewdata, iNewsize);
|
|
|
|
switch (pBuf->iColortype) /* determine magnification routines */
|
|
{
|
|
case 0 : ;
|
|
case 8 : {
|
|
if (pBuf->iBitdepth <= 8)
|
|
{
|
|
switch (pImage->iMAGN_MethodX)
|
|
{
|
|
case 1 : { fMagnifyX = magnify_g8_x1; break; }
|
|
case 2 : { fMagnifyX = magnify_g8_x2; break; }
|
|
case 3 : { fMagnifyX = magnify_g8_x3; break; }
|
|
case 4 : { fMagnifyX = magnify_g8_x2; break; }
|
|
case 5 : { fMagnifyX = magnify_g8_x3; break; }
|
|
}
|
|
|
|
switch (pImage->iMAGN_MethodY)
|
|
{
|
|
case 1 : { fMagnifyY = magnify_g8_y1; break; }
|
|
case 2 : { fMagnifyY = magnify_g8_y2; break; }
|
|
case 3 : { fMagnifyY = magnify_g8_y3; break; }
|
|
case 4 : { fMagnifyY = magnify_g8_y2; break; }
|
|
case 5 : { fMagnifyY = magnify_g8_y3; break; }
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
/* TODO: magnify 16-bit */
|
|
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
case 2 : ;
|
|
case 10 : {
|
|
if (pBuf->iBitdepth <= 8)
|
|
{
|
|
switch (pImage->iMAGN_MethodX)
|
|
{
|
|
case 1 : { fMagnifyX = magnify_rgb8_x1; break; }
|
|
case 2 : { fMagnifyX = magnify_rgb8_x2; break; }
|
|
case 3 : { fMagnifyX = magnify_rgb8_x3; break; }
|
|
case 4 : { fMagnifyX = magnify_rgb8_x2; break; }
|
|
case 5 : { fMagnifyX = magnify_rgb8_x3; break; }
|
|
}
|
|
|
|
switch (pImage->iMAGN_MethodY)
|
|
{
|
|
case 1 : { fMagnifyY = magnify_rgb8_y1; break; }
|
|
case 2 : { fMagnifyY = magnify_rgb8_y2; break; }
|
|
case 3 : { fMagnifyY = magnify_rgb8_y3; break; }
|
|
case 4 : { fMagnifyY = magnify_rgb8_y2; break; }
|
|
case 5 : { fMagnifyY = magnify_rgb8_y3; break; }
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
/* TODO: magnify 16-bit */
|
|
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
case 4 : ;
|
|
case 12 : {
|
|
if (pBuf->iBitdepth <= 8)
|
|
{
|
|
switch (pImage->iMAGN_MethodX)
|
|
{
|
|
case 1 : { fMagnifyX = magnify_ga8_x1; break; }
|
|
case 2 : { fMagnifyX = magnify_ga8_x2; break; }
|
|
case 3 : { fMagnifyX = magnify_ga8_x3; break; }
|
|
case 4 : { fMagnifyX = magnify_ga8_x4; break; }
|
|
case 5 : { fMagnifyX = magnify_ga8_x5; break; }
|
|
}
|
|
|
|
switch (pImage->iMAGN_MethodY)
|
|
{
|
|
case 1 : { fMagnifyY = magnify_ga8_y1; break; }
|
|
case 2 : { fMagnifyY = magnify_ga8_y2; break; }
|
|
case 3 : { fMagnifyY = magnify_ga8_y3; break; }
|
|
case 4 : { fMagnifyY = magnify_ga8_y4; break; }
|
|
case 5 : { fMagnifyY = magnify_ga8_y5; break; }
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
/* TODO: magnify 16-bit */
|
|
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
case 6 : ;
|
|
case 14 : {
|
|
if (pBuf->iBitdepth <= 8)
|
|
{
|
|
switch (pImage->iMAGN_MethodX)
|
|
{
|
|
case 1 : { fMagnifyX = magnify_rgba8_x1; break; }
|
|
case 2 : { fMagnifyX = magnify_rgba8_x2; break; }
|
|
case 3 : { fMagnifyX = magnify_rgba8_x3; break; }
|
|
case 4 : { fMagnifyX = magnify_rgba8_x4; break; }
|
|
case 5 : { fMagnifyX = magnify_rgba8_x5; break; }
|
|
}
|
|
|
|
switch (pImage->iMAGN_MethodY)
|
|
{
|
|
case 1 : { fMagnifyY = magnify_rgba8_y1; break; }
|
|
case 2 : { fMagnifyY = magnify_rgba8_y2; break; }
|
|
case 3 : { fMagnifyY = magnify_rgba8_y3; break; }
|
|
case 4 : { fMagnifyY = magnify_rgba8_y4; break; }
|
|
case 5 : { fMagnifyY = magnify_rgba8_y5; break; }
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
/* TODO: magnify 16-bit */
|
|
|
|
}
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
pSrcline1 = pBuf->pImgdata; /* initialize row-loop variables */
|
|
pDstline = pNewdata;
|
|
/* allocate temporary row */
|
|
MNG_ALLOC (pData, pTempline, iNewrowsize)
|
|
|
|
for (iY = 0; iY < pBuf->iHeight; iY++)
|
|
{
|
|
pSrcline2 = pSrcline1 + pBuf->iRowsize;
|
|
|
|
if (fMagnifyX) /* magnifying in X-direction ? */
|
|
{
|
|
iRetcode = fMagnifyX (pData, pImage->iMAGN_MX,
|
|
pImage->iMAGN_ML, pImage->iMAGN_MR,
|
|
pBuf->iWidth, pSrcline1, pDstline);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
{
|
|
MNG_FREEX (pData, pTempline, iNewrowsize)
|
|
MNG_FREEX (pData, pNewdata, iNewsize)
|
|
return iRetcode;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
MNG_COPY (pDstline, pSrcline1, iNewrowsize)
|
|
}
|
|
|
|
pDstline += iNewrowsize;
|
|
/* magnifying in Y-direction ? */
|
|
if ((fMagnifyY) &&
|
|
((iY < pBuf->iHeight - 1) || (pBuf->iHeight == 1) || (pImage->iMAGN_MethodY == 1)))
|
|
{
|
|
if (iY == 0) /* first interval ? */
|
|
{
|
|
if (pBuf->iHeight == 1) /* single row ? */
|
|
pSrcline2 = MNG_NULL;
|
|
|
|
iM = (mng_int32)pImage->iMAGN_MT;
|
|
}
|
|
else /* last interval ? */
|
|
if (((pImage->iMAGN_MethodY == 1) && (iY == (pBuf->iHeight - 1))) ||
|
|
((pImage->iMAGN_MethodY != 1) && (iY == (pBuf->iHeight - 2))) )
|
|
iM = (mng_int32)pImage->iMAGN_MB;
|
|
else /* middle interval */
|
|
iM = (mng_int32)pImage->iMAGN_MY;
|
|
|
|
for (iS = 1; iS < iM; iS++)
|
|
{
|
|
iRetcode = fMagnifyY (pData, iS, iM, pBuf->iWidth,
|
|
pSrcline1, pSrcline2, pTempline);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
{
|
|
MNG_FREEX (pData, pTempline, iNewrowsize)
|
|
MNG_FREEX (pData, pNewdata, iNewsize)
|
|
return iRetcode;
|
|
}
|
|
|
|
if (fMagnifyX) /* magnifying in X-direction ? */
|
|
{
|
|
iRetcode = fMagnifyX (pData, pImage->iMAGN_MX,
|
|
pImage->iMAGN_ML, pImage->iMAGN_MR,
|
|
pBuf->iWidth, pTempline, pDstline);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
{
|
|
MNG_FREEX (pData, pTempline, iNewrowsize)
|
|
MNG_FREEX (pData, pNewdata, iNewsize)
|
|
return iRetcode;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
MNG_COPY (pDstline, pTempline, iNewrowsize)
|
|
}
|
|
|
|
pDstline += iNewrowsize;
|
|
}
|
|
}
|
|
|
|
pSrcline1 += pBuf->iRowsize;
|
|
}
|
|
/* drop temporary row */
|
|
MNG_FREEX (pData, pTempline, iNewrowsize)
|
|
/* drop old pixel-data */
|
|
MNG_FREEX (pData, pBuf->pImgdata, pBuf->iImgdatasize)
|
|
|
|
pBuf->pImgdata = pNewdata; /* save new buffer dimensions */
|
|
pBuf->iRowsize = iNewrowsize;
|
|
pBuf->iImgdatasize = iNewsize;
|
|
pBuf->iWidth = iNewW;
|
|
pBuf->iHeight = iNewH;
|
|
|
|
if (pImage->iId) /* real object ? */
|
|
{
|
|
pImage->iMAGN_MethodX = 0; /* it's done; don't do it again !!! */
|
|
pImage->iMAGN_MethodY = 0;
|
|
pImage->iMAGN_MX = 0;
|
|
pImage->iMAGN_MY = 0;
|
|
pImage->iMAGN_ML = 0;
|
|
pImage->iMAGN_MR = 0;
|
|
pImage->iMAGN_MT = 0;
|
|
pImage->iMAGN_MB = 0;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_MAGNIFY_IMGOBJECT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* * * */
|
|
/* * Animation-object routines * */
|
|
/* * * */
|
|
/* * these handle the animation objects used to re-run parts of a MNG. * */
|
|
/* * eg. during LOOP or TERM processing * */
|
|
/* * * */
|
|
/* ************************************************************************** */
|
|
|
|
void add_ani_object (mng_datap pData,
|
|
mng_object_headerp pObject)
|
|
{
|
|
mng_object_headerp pLast = (mng_object_headerp)pData->pLastaniobj;
|
|
|
|
if (pLast) /* link it as last in the chain */
|
|
{
|
|
pObject->pPrev = pLast;
|
|
pLast->pNext = pObject;
|
|
}
|
|
else
|
|
{
|
|
pObject->pPrev = MNG_NULL; /* be on the safe side */
|
|
pData->pFirstaniobj = pObject;
|
|
}
|
|
|
|
pObject->pNext = MNG_NULL; /* be on the safe side */
|
|
pData->pLastaniobj = pObject;
|
|
/* keep track for jumping */
|
|
pObject->iFramenr = pData->iFrameseq;
|
|
pObject->iLayernr = pData->iLayerseq;
|
|
pObject->iPlaytime = pData->iFrametime;
|
|
/* save restart object ? */
|
|
if ((pData->bDisplaying) && (!pData->bRunning) && (!pData->pCurraniobj))
|
|
pData->pCurraniobj = pObject;
|
|
|
|
return;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_image (mng_datap pData)
|
|
{
|
|
mng_ani_imagep pImage;
|
|
mng_imagep pCurrent;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_IMAGE, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
if (pData->bHasDHDR) /* processing delta-image ? */
|
|
pCurrent = (mng_imagep)pData->pObjzero;
|
|
else /* get the current object */
|
|
pCurrent = (mng_imagep)pData->pCurrentobj;
|
|
|
|
if (!pCurrent) /* otherwise object 0 */
|
|
pCurrent = (mng_imagep)pData->pObjzero;
|
|
/* now just clone the object !!! */
|
|
iRetcode = clone_imageobject (pData, 0, MNG_FALSE, pCurrent->bVisible,
|
|
MNG_FALSE, MNG_FALSE, 0, 0, 0, pCurrent, &pImage);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
pImage->sHeader.fCleanup = free_ani_image;
|
|
pImage->sHeader.fProcess = process_ani_image;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pImage);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_IMAGE, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR; /* okido */
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_image (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_imagep pImage = (mng_ani_imagep)pObject;
|
|
mng_imagedatap pImgbuf = pImage->pImgbuf;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_IMAGE, MNG_LC_START)
|
|
#endif
|
|
/* unlink the image-data buffer */
|
|
iRetcode = free_imagedataobject (pData, pImgbuf);
|
|
/* drop it's own buffer */
|
|
MNG_FREEX (pData, pImage, sizeof (mng_ani_image))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_IMAGE, MNG_LC_END)
|
|
#endif
|
|
|
|
return iRetcode;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_image (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_retcode iRetcode = MNG_NOERROR;
|
|
mng_ani_imagep pImage = (mng_imagep)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_IMAGE, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bHasDHDR) /* processing delta-image ? */
|
|
{
|
|
mng_imagep pDelta = (mng_imagep)pData->pDeltaImage;
|
|
|
|
if (!pData->iBreakpoint) /* only execute if not broken before */
|
|
{ /* make sure to process pixels as well */
|
|
pData->bDeltaimmediate = MNG_FALSE;
|
|
/* execute the delta process */
|
|
iRetcode = execute_delta_image (pData, pDelta, (mng_imagep)pObject);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
}
|
|
/* now go and shoot it off (if required) */
|
|
if ((pDelta->bVisible) && (pDelta->bViewable))
|
|
iRetcode = display_image (pData, pDelta, MNG_FALSE);
|
|
|
|
if (!pData->bTimerset)
|
|
pData->bHasDHDR = MNG_FALSE; /* this image signifies IEND !! */
|
|
|
|
}
|
|
else
|
|
if (pData->pCurrentobj) /* active object ? */
|
|
{
|
|
mng_imagep pCurrent = (mng_imagep)pData->pCurrentobj;
|
|
mng_imagedatap pBuf = pCurrent->pImgbuf;
|
|
|
|
if (!pData->iBreakpoint) /* don't copy it again ! */
|
|
{
|
|
if (pBuf->iImgdatasize) /* buffer present in active object ? */
|
|
/* then drop it */
|
|
MNG_FREE (pData, pBuf->pImgdata, pBuf->iImgdatasize)
|
|
|
|
if (pBuf->iProfilesize) /* iCCP profile present ? */
|
|
/* then drop it */
|
|
MNG_FREE (pData, pBuf->pProfile, pBuf->iProfilesize)
|
|
/* now blatently copy the animation buffer */
|
|
MNG_COPY (pBuf, pImage->pImgbuf, sizeof (mng_imagedata))
|
|
/* copy viewability */
|
|
pCurrent->bViewable = pImage->bViewable;
|
|
|
|
if (pBuf->iImgdatasize) /* sample buffer present ? */
|
|
{ /* then make a copy */
|
|
MNG_ALLOC (pData, pBuf->pImgdata, pBuf->iImgdatasize)
|
|
MNG_COPY (pBuf->pImgdata, pImage->pImgbuf->pImgdata, pBuf->iImgdatasize)
|
|
}
|
|
|
|
if (pBuf->iProfilesize) /* iCCP profile present ? */
|
|
{ /* then make a copy */
|
|
MNG_ALLOC (pData, pBuf->pProfile, pBuf->iProfilesize)
|
|
MNG_COPY (pBuf->pProfile, pImage->pImgbuf->pProfile, pBuf->iProfilesize)
|
|
}
|
|
}
|
|
/* now go and shoot it off (if required) */
|
|
if ((pCurrent->bVisible) && (pCurrent->bViewable))
|
|
iRetcode = display_image (pData, pCurrent, MNG_FALSE);
|
|
}
|
|
else
|
|
{
|
|
mng_imagep pObjzero = (mng_imagep)pData->pObjzero;
|
|
/* overlay with object 0 status */
|
|
pImage->bVisible = pObjzero->bVisible;
|
|
pImage->bViewable = pObjzero->bViewable;
|
|
pImage->iPosx = pObjzero->iPosx;
|
|
pImage->iPosy = pObjzero->iPosy;
|
|
pImage->bClipped = pObjzero->bClipped;
|
|
pImage->iClipl = pObjzero->iClipl;
|
|
pImage->iClipr = pObjzero->iClipr;
|
|
pImage->iClipt = pObjzero->iClipt;
|
|
pImage->iClipb = pObjzero->iClipb;
|
|
/* now this should do the trick */
|
|
if ((pImage->bVisible) && (pImage->bViewable))
|
|
iRetcode = display_image (pData, pImage, MNG_FALSE);
|
|
}
|
|
|
|
if (!iRetcode) /* all's well ? */
|
|
{
|
|
if (pData->bTimerset) /* timer break ? */
|
|
pData->iBreakpoint = 99; /* fictive number; no more processing needed! */
|
|
else
|
|
pData->iBreakpoint = 0; /* else clear it */
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_IMAGE, MNG_LC_END)
|
|
#endif
|
|
|
|
return iRetcode;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_plte (mng_datap pData,
|
|
mng_uint32 iEntrycount,
|
|
mng_palette8ep paEntries)
|
|
{
|
|
mng_ani_pltep pPLTE;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_PLTE, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pPLTE, sizeof (mng_ani_plte))
|
|
|
|
pPLTE->sHeader.fCleanup = free_ani_plte;
|
|
pPLTE->sHeader.fProcess = process_ani_plte;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pPLTE);
|
|
|
|
pPLTE->iEntrycount = iEntrycount;
|
|
|
|
MNG_COPY (pPLTE->aEntries, paEntries, sizeof (pPLTE->aEntries))
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_PLTE, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_plte (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_PLTE, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_plte))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_PLTE, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_plte (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_pltep pPLTE = (mng_ani_pltep)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_PLTE, MNG_LC_START)
|
|
#endif
|
|
|
|
pData->bHasglobalPLTE = MNG_TRUE;
|
|
pData->iGlobalPLTEcount = pPLTE->iEntrycount;
|
|
|
|
MNG_COPY (pData->aGlobalPLTEentries, pPLTE->aEntries, sizeof (pPLTE->aEntries))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_PLTE, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_trns (mng_datap pData,
|
|
mng_uint32 iRawlen,
|
|
mng_uint8p pRawdata)
|
|
{
|
|
mng_ani_trnsp pTRNS;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_TRNS, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pTRNS, sizeof (mng_ani_trns))
|
|
|
|
pTRNS->sHeader.fCleanup = free_ani_trns;
|
|
pTRNS->sHeader.fProcess = process_ani_trns;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pTRNS);
|
|
|
|
pTRNS->iRawlen = iRawlen;
|
|
|
|
MNG_COPY (pTRNS->aRawdata, pRawdata, sizeof (pTRNS->aRawdata))
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_TRNS, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_trns (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_TRNS, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_trns))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_TRNS, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_trns (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_trnsp pTRNS = (mng_ani_trnsp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_TRNS, MNG_LC_START)
|
|
#endif
|
|
|
|
pData->bHasglobalTRNS = MNG_TRUE;
|
|
pData->iGlobalTRNSrawlen = pTRNS->iRawlen;
|
|
|
|
MNG_COPY (pData->aGlobalTRNSrawdata, pTRNS->aRawdata, sizeof (pTRNS->aRawdata))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_TRNS, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_gama (mng_datap pData,
|
|
mng_bool bEmpty,
|
|
mng_uint32 iGamma)
|
|
{
|
|
mng_ani_gamap pGAMA;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_GAMA, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pGAMA, sizeof (mng_ani_gama))
|
|
|
|
pGAMA->sHeader.fCleanup = free_ani_gama;
|
|
pGAMA->sHeader.fProcess = process_ani_gama;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pGAMA);
|
|
|
|
pGAMA->bEmpty = bEmpty;
|
|
pGAMA->iGamma = iGamma;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_GAMA, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_gama (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_GAMA, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_gama))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_GAMA, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_gama (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_gamap pGAMA = (mng_ani_gamap)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_GAMA, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pGAMA->bEmpty) /* empty chunk ? */
|
|
{ /* clear global gAMA */
|
|
pData->bHasglobalGAMA = MNG_FALSE;
|
|
pData->iGlobalGamma = 0;
|
|
}
|
|
else
|
|
{ /* set global gAMA */
|
|
pData->bHasglobalGAMA = MNG_TRUE;
|
|
pData->iGlobalGamma = pGAMA->iGamma;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_GAMA, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_chrm (mng_datap pData,
|
|
mng_bool bEmpty,
|
|
mng_uint32 iWhitepointx,
|
|
mng_uint32 iWhitepointy,
|
|
mng_uint32 iRedx,
|
|
mng_uint32 iRedy,
|
|
mng_uint32 iGreenx,
|
|
mng_uint32 iGreeny,
|
|
mng_uint32 iBluex,
|
|
mng_uint32 iBluey)
|
|
{
|
|
mng_ani_chrmp pCHRM;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_CHRM, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pCHRM, sizeof (mng_ani_chrm))
|
|
|
|
pCHRM->sHeader.fCleanup = free_ani_chrm;
|
|
pCHRM->sHeader.fProcess = process_ani_chrm;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pCHRM);
|
|
|
|
pCHRM->bEmpty = bEmpty;
|
|
pCHRM->iWhitepointx = iWhitepointx;
|
|
pCHRM->iWhitepointy = iWhitepointy;
|
|
pCHRM->iRedx = iRedx;
|
|
pCHRM->iRedy = iRedy;
|
|
pCHRM->iGreenx = iGreenx;
|
|
pCHRM->iGreeny = iGreeny;
|
|
pCHRM->iBluex = iBluex;
|
|
pCHRM->iBluey = iBluey;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_CHRM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_chrm (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_CHRM, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_chrm))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_CHRM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_chrm (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_chrmp pCHRM = (mng_ani_chrmp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_CHRM, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pCHRM->bEmpty) /* empty chunk ? */
|
|
{ /* clear global cHRM */
|
|
pData->bHasglobalCHRM = MNG_FALSE;
|
|
pData->iGlobalWhitepointx = 0;
|
|
pData->iGlobalWhitepointy = 0;
|
|
pData->iGlobalPrimaryredx = 0;
|
|
pData->iGlobalPrimaryredy = 0;
|
|
pData->iGlobalPrimarygreenx = 0;
|
|
pData->iGlobalPrimarygreeny = 0;
|
|
pData->iGlobalPrimarybluex = 0;
|
|
pData->iGlobalPrimarybluey = 0;
|
|
}
|
|
else
|
|
{ /* set global cHRM */
|
|
pData->bHasglobalCHRM = MNG_TRUE;
|
|
pData->iGlobalWhitepointx = pCHRM->iWhitepointx;
|
|
pData->iGlobalWhitepointy = pCHRM->iWhitepointy;
|
|
pData->iGlobalPrimaryredx = pCHRM->iRedx;
|
|
pData->iGlobalPrimaryredy = pCHRM->iRedy;
|
|
pData->iGlobalPrimarygreenx = pCHRM->iGreenx;
|
|
pData->iGlobalPrimarygreeny = pCHRM->iGreeny;
|
|
pData->iGlobalPrimarybluex = pCHRM->iBluex;
|
|
pData->iGlobalPrimarybluey = pCHRM->iBluey;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_CHRM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_srgb (mng_datap pData,
|
|
mng_bool bEmpty,
|
|
mng_uint8 iRenderingintent)
|
|
{
|
|
mng_ani_srgbp pSRGB;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_SRGB, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pSRGB, sizeof (mng_ani_srgb))
|
|
|
|
pSRGB->sHeader.fCleanup = free_ani_srgb;
|
|
pSRGB->sHeader.fProcess = process_ani_srgb;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pSRGB);
|
|
|
|
pSRGB->bEmpty = bEmpty;
|
|
pSRGB->iRenderingintent = iRenderingintent;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_SRGB, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_srgb (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_SRGB, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_srgb))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_SRGB, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_srgb (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_srgbp pSRGB = (mng_ani_srgbp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_SRGB, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pSRGB->bEmpty) /* empty chunk ? */
|
|
{ /* clear global sRGB */
|
|
pData->bHasglobalSRGB = MNG_FALSE;
|
|
pData->iGlobalRendintent = 0;
|
|
}
|
|
else
|
|
{ /* set global sRGB */
|
|
pData->bHasglobalSRGB = MNG_TRUE;
|
|
pData->iGlobalRendintent = pSRGB->iRenderingintent;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_SRGB, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_iccp (mng_datap pData,
|
|
mng_bool bEmpty,
|
|
mng_uint32 iProfilesize,
|
|
mng_ptr pProfile)
|
|
{
|
|
mng_ani_iccpp pICCP;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_ICCP, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pICCP, sizeof (mng_ani_iccp))
|
|
|
|
pICCP->sHeader.fCleanup = free_ani_iccp;
|
|
pICCP->sHeader.fProcess = process_ani_iccp;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pICCP);
|
|
|
|
pICCP->bEmpty = bEmpty;
|
|
pICCP->iProfilesize = iProfilesize;
|
|
|
|
if (iProfilesize)
|
|
{
|
|
MNG_ALLOC (pData, pICCP->pProfile, iProfilesize)
|
|
MNG_COPY (pICCP->pProfile, pProfile, iProfilesize)
|
|
}
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_ICCP, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_iccp (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_iccpp pICCP = (mng_ani_iccpp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_ICCP, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pICCP->iProfilesize)
|
|
MNG_FREEX (pData, pICCP->pProfile, pICCP->iProfilesize)
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_iccp))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_ICCP, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_iccp (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_iccpp pICCP = (mng_ani_iccpp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_ICCP, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pICCP->bEmpty) /* empty chunk ? */
|
|
{ /* clear global iCCP */
|
|
pData->bHasglobalICCP = MNG_FALSE;
|
|
|
|
if (pData->iGlobalProfilesize)
|
|
MNG_FREEX (pData, pData->pGlobalProfile, pData->iGlobalProfilesize)
|
|
|
|
pData->iGlobalProfilesize = 0;
|
|
pData->pGlobalProfile = MNG_NULL;
|
|
}
|
|
else
|
|
{ /* set global iCCP */
|
|
pData->bHasglobalICCP = MNG_TRUE;
|
|
pData->iGlobalProfilesize = pICCP->iProfilesize;
|
|
|
|
if (pICCP->iProfilesize)
|
|
{
|
|
MNG_ALLOC (pData, pData->pGlobalProfile, pICCP->iProfilesize)
|
|
MNG_COPY (pData->pGlobalProfile, pICCP->pProfile, pICCP->iProfilesize)
|
|
}
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_ICCP, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_bkgd (mng_datap pData,
|
|
mng_uint16 iRed,
|
|
mng_uint16 iGreen,
|
|
mng_uint16 iBlue)
|
|
{
|
|
mng_ani_bkgdp pBKGD;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_BKGD, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pBKGD, sizeof (mng_ani_bkgd))
|
|
|
|
pBKGD->sHeader.fCleanup = free_ani_bkgd;
|
|
pBKGD->sHeader.fProcess = process_ani_bkgd;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pBKGD);
|
|
|
|
pBKGD->iRed = iRed;
|
|
pBKGD->iGreen = iGreen;
|
|
pBKGD->iBlue = iBlue;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_BKGD, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_bkgd (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_BKGD, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_bkgd))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_BKGD, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_bkgd (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_bkgdp pBKGD = (mng_ani_bkgdp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_BKGD, MNG_LC_START)
|
|
#endif
|
|
|
|
pData->bHasglobalBKGD = MNG_TRUE;
|
|
pData->iGlobalBKGDred = pBKGD->iRed;
|
|
pData->iGlobalBKGDgreen = pBKGD->iGreen;
|
|
pData->iGlobalBKGDblue = pBKGD->iBlue;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_BKGD, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_loop (mng_datap pData,
|
|
mng_uint8 iLevel,
|
|
mng_uint32 iRepeatcount,
|
|
mng_uint8 iTermcond,
|
|
mng_uint32 iItermin,
|
|
mng_uint32 iItermax,
|
|
mng_uint32 iCount,
|
|
mng_uint32p pSignals)
|
|
{
|
|
mng_ani_loopp pLOOP;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_LOOP, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pLOOP, sizeof (mng_ani_loop))
|
|
|
|
pLOOP->sHeader.fCleanup = free_ani_loop;
|
|
pLOOP->sHeader.fProcess = process_ani_loop;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pLOOP);
|
|
|
|
pLOOP->iLevel = iLevel;
|
|
pLOOP->iRepeatcount = iRepeatcount;
|
|
pLOOP->iTermcond = iTermcond;
|
|
pLOOP->iItermin = iItermin;
|
|
pLOOP->iItermax = iItermax;
|
|
pLOOP->iCount = iCount;
|
|
/* running counter starts with repeat_count */
|
|
pLOOP->iRunningcount = iRepeatcount;
|
|
|
|
if (iCount)
|
|
{
|
|
MNG_ALLOC (pData, pLOOP->pSignals, (iCount << 1))
|
|
MNG_COPY (pLOOP->pSignals, pSignals, (iCount << 1))
|
|
}
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_LOOP, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_loop (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_loopp pLOOP = (mng_ani_loopp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_LOOP, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pLOOP->iCount) /* drop signal buffer ? */
|
|
MNG_FREEX (pData, pLOOP->pSignals, (pLOOP->iCount << 1))
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_loop))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_LOOP, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_loop (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_loopp pLOOP = (mng_ani_loopp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_LOOP, MNG_LC_START)
|
|
#endif
|
|
/* just reset the running counter */
|
|
pLOOP->iRunningcount = pLOOP->iRepeatcount;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_LOOP, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_endl (mng_datap pData,
|
|
mng_uint8 iLevel)
|
|
{
|
|
mng_ani_endlp pENDL;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_ENDL, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pENDL, sizeof (mng_ani_endl))
|
|
|
|
pENDL->sHeader.fCleanup = free_ani_endl;
|
|
pENDL->sHeader.fProcess = process_ani_endl;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pENDL);
|
|
|
|
pENDL->iLevel = iLevel;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_ENDL, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_endl (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_ENDL, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_endl))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_ENDL, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_endl (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_endlp pENDL = (mng_ani_endlp)pObject;
|
|
mng_ani_loopp pLOOP;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_ENDL, MNG_LC_START)
|
|
#endif
|
|
|
|
if ((pData->bDisplaying) && (pData->bRunning))
|
|
{
|
|
pLOOP = pENDL->pLOOP; /* determine matching LOOP */
|
|
|
|
if (!pLOOP) /* haven't got it yet ? */
|
|
{ /* go and look back in the list */
|
|
pLOOP = (mng_ani_loopp)pENDL->sHeader.pPrev;
|
|
|
|
while ((pLOOP) &&
|
|
((pLOOP->sHeader.fCleanup != free_ani_loop) ||
|
|
(pLOOP->iLevel != pENDL->iLevel) ))
|
|
pLOOP = pLOOP->sHeader.pPrev;
|
|
}
|
|
/* got it now ? */
|
|
if ((pLOOP) && (pLOOP->iLevel == pENDL->iLevel))
|
|
{
|
|
pENDL->pLOOP = pLOOP; /* save for next time ! */
|
|
/* decrease running counter ? */
|
|
if ((pLOOP->iRunningcount) && (pLOOP->iRunningcount < 0x7fffffffL))
|
|
pLOOP->iRunningcount--;
|
|
|
|
/* TODO: we're cheating out on the termination_condition,
|
|
iteration_min, iteration_max and possible signals;
|
|
the code is just not ready for that can of worms.... */
|
|
|
|
if (!pLOOP->iRunningcount) /* reached zero ? */
|
|
{ /* was this the outer LOOP ? */
|
|
if (pData->pFirstaniobj == (mng_objectp)pLOOP)
|
|
pData->bHasLOOP = MNG_FALSE;
|
|
}
|
|
else
|
|
{
|
|
if (pData->pCurraniobj) /* was we processing objects ? */
|
|
pData->pCurraniobj = pLOOP; /* then restart with LOOP */
|
|
else /* else restart behind LOOP !!! */
|
|
pData->pCurraniobj = pLOOP->sHeader.pNext;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
MNG_ERROR (pData, 1234);
|
|
/* TODO: error abort ??? */
|
|
|
|
}
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_ENDL, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_defi (mng_datap pData)
|
|
{
|
|
mng_ani_defip pDEFI;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_DEFI, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pDEFI, sizeof (mng_ani_defi))
|
|
|
|
pDEFI->sHeader.fCleanup = free_ani_defi;
|
|
pDEFI->sHeader.fProcess = process_ani_defi;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pDEFI);
|
|
|
|
pDEFI->iId = pData->iDEFIobjectid;
|
|
pDEFI->bHasdonotshow = pData->bDEFIhasdonotshow;
|
|
pDEFI->iDonotshow = pData->iDEFIdonotshow;
|
|
pDEFI->bHasconcrete = pData->bDEFIhasconcrete;
|
|
pDEFI->iConcrete = pData->iDEFIconcrete;
|
|
pDEFI->bHasloca = pData->bDEFIhasloca;
|
|
pDEFI->iLocax = pData->iDEFIlocax;
|
|
pDEFI->iLocay = pData->iDEFIlocay;
|
|
pDEFI->bHasclip = pData->bDEFIhasclip;
|
|
pDEFI->iClipl = pData->iDEFIclipl;
|
|
pDEFI->iClipr = pData->iDEFIclipr;
|
|
pDEFI->iClipt = pData->iDEFIclipt;
|
|
pDEFI->iClipb = pData->iDEFIclipb;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_DEFI, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_defi (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_DEFI, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_defi))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_DEFI, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_defi (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_defip pDEFI = (mng_ani_defip)pObject;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_DEFI, MNG_LC_START)
|
|
#endif
|
|
|
|
pData->iDEFIobjectid = pDEFI->iId;
|
|
pData->bDEFIhasdonotshow = pDEFI->bHasdonotshow;
|
|
pData->iDEFIdonotshow = pDEFI->iDonotshow;
|
|
pData->bDEFIhasconcrete = pDEFI->bHasconcrete;
|
|
pData->iDEFIconcrete = pDEFI->iConcrete;
|
|
pData->bDEFIhasloca = pDEFI->bHasloca;
|
|
pData->iDEFIlocax = pDEFI->iLocax;
|
|
pData->iDEFIlocay = pDEFI->iLocay;
|
|
pData->bDEFIhasclip = pDEFI->bHasclip;
|
|
pData->iDEFIclipl = pDEFI->iClipl;
|
|
pData->iDEFIclipr = pDEFI->iClipr;
|
|
pData->iDEFIclipt = pDEFI->iClipt;
|
|
pData->iDEFIclipb = pDEFI->iClipb;
|
|
|
|
iRetcode = process_display_defi (pData);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_DEFI, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_basi (mng_datap pData,
|
|
mng_uint16 iRed,
|
|
mng_uint16 iGreen,
|
|
mng_uint16 iBlue,
|
|
mng_bool bHasalpha,
|
|
mng_uint16 iAlpha,
|
|
mng_uint8 iViewable)
|
|
{
|
|
mng_ani_basip pBASI;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_BASI, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pBASI, sizeof (mng_ani_basi))
|
|
|
|
pBASI->sHeader.fCleanup = free_ani_basi;
|
|
pBASI->sHeader.fProcess = process_ani_basi;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pBASI);
|
|
|
|
pBASI->iRed = iRed;
|
|
pBASI->iGreen = iGreen;
|
|
pBASI->iBlue = iBlue;
|
|
pBASI->bHasalpha = bHasalpha;
|
|
pBASI->iAlpha = iAlpha;
|
|
pBASI->iViewable = iViewable;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_BASI, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_basi (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_BASI, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_basi))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_BASI, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_basi (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_basip pBASI = (mng_ani_basip)pObject;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_BASI, MNG_LC_START)
|
|
#endif
|
|
|
|
iRetcode = process_display_basi (pData, pBASI->iRed, pBASI->iGreen, pBASI->iBlue,
|
|
pBASI->bHasalpha, pBASI->iAlpha, pBASI->iViewable);
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_BASI, MNG_LC_END)
|
|
#endif
|
|
|
|
return iRetcode;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_clon (mng_datap pData,
|
|
mng_uint16 iCloneid,
|
|
mng_uint16 iSourceid,
|
|
mng_uint8 iClonetype,
|
|
mng_bool bHasdonotshow,
|
|
mng_uint8 iDonotshow,
|
|
mng_uint8 iConcrete,
|
|
mng_bool bHasloca,
|
|
mng_uint8 iLocatype,
|
|
mng_int32 iLocax,
|
|
mng_int32 iLocay)
|
|
{
|
|
mng_ani_clonp pCLON;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_CLON, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pCLON, sizeof (mng_ani_clon))
|
|
|
|
pCLON->sHeader.fCleanup = free_ani_clon;
|
|
pCLON->sHeader.fProcess = process_ani_clon;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pCLON);
|
|
|
|
pCLON->iCloneid = iCloneid;
|
|
pCLON->iSourceid = iSourceid;
|
|
pCLON->iClonetype = iClonetype;
|
|
pCLON->bHasdonotshow = bHasdonotshow;
|
|
pCLON->iDonotshow = iDonotshow;
|
|
pCLON->iConcrete = iConcrete;
|
|
pCLON->bHasloca = bHasloca;
|
|
pCLON->iLocatype = iLocatype;
|
|
pCLON->iLocax = iLocax;
|
|
pCLON->iLocay = iLocay;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_CLON, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_clon (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_CLON, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_clon))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_CLON, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_clon (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_clonp pCLON = (mng_ani_clonp)pObject;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_CLON, MNG_LC_START)
|
|
#endif
|
|
|
|
iRetcode = process_display_clon (pData, pCLON->iCloneid, pCLON->iSourceid,
|
|
pCLON->iClonetype, pCLON->bHasdonotshow,
|
|
pCLON->iDonotshow, pCLON->iConcrete,
|
|
pCLON->bHasloca, pCLON->iLocatype,
|
|
pCLON->iLocax, pCLON->iLocay);
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_CLON, MNG_LC_END)
|
|
#endif
|
|
|
|
return iRetcode;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_back (mng_datap pData,
|
|
mng_uint16 iRed,
|
|
mng_uint16 iGreen,
|
|
mng_uint16 iBlue,
|
|
mng_uint8 iMandatory,
|
|
mng_uint16 iImageid,
|
|
mng_uint8 iTile)
|
|
{
|
|
mng_ani_backp pBACK;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_BACK, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pBACK, sizeof (mng_ani_back))
|
|
|
|
pBACK->sHeader.fCleanup = free_ani_back;
|
|
pBACK->sHeader.fProcess = process_ani_back;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pBACK);
|
|
|
|
pBACK->iRed = iRed;
|
|
pBACK->iGreen = iGreen;
|
|
pBACK->iBlue = iBlue;
|
|
pBACK->iMandatory = iMandatory;
|
|
pBACK->iImageid = iImageid;
|
|
pBACK->iTile = iTile;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_BACK, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_back (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_BACK, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_back))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_BACK, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_back (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_backp pBACK = (mng_ani_backp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_BACK, MNG_LC_START)
|
|
#endif
|
|
|
|
pData->iBACKred = pBACK->iRed;
|
|
pData->iBACKgreen = pBACK->iGreen;
|
|
pData->iBACKblue = pBACK->iBlue;
|
|
pData->iBACKmandatory = pBACK->iMandatory;
|
|
pData->iBACKimageid = pBACK->iImageid;
|
|
pData->iBACKtile = pBACK->iTile;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_BACK, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_fram (mng_datap pData,
|
|
mng_uint8 iFramemode,
|
|
mng_uint8 iChangedelay,
|
|
mng_uint32 iDelay,
|
|
mng_uint8 iChangetimeout,
|
|
mng_uint32 iTimeout,
|
|
mng_uint8 iChangeclipping,
|
|
mng_uint8 iCliptype,
|
|
mng_int32 iClipl,
|
|
mng_int32 iClipr,
|
|
mng_int32 iClipt,
|
|
mng_int32 iClipb)
|
|
{
|
|
mng_ani_framp pFRAM;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_FRAM, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pFRAM, sizeof (mng_ani_fram))
|
|
|
|
pFRAM->sHeader.fCleanup = free_ani_fram;
|
|
pFRAM->sHeader.fProcess = process_ani_fram;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pFRAM);
|
|
|
|
pFRAM->iFramemode = iFramemode;
|
|
pFRAM->iChangedelay = iChangedelay;
|
|
pFRAM->iDelay = iDelay;
|
|
pFRAM->iChangetimeout = iChangetimeout;
|
|
pFRAM->iTimeout = iTimeout;
|
|
pFRAM->iChangeclipping = iChangeclipping;
|
|
pFRAM->iCliptype = iCliptype;
|
|
pFRAM->iClipl = iClipl;
|
|
pFRAM->iClipr = iClipr;
|
|
pFRAM->iClipt = iClipt;
|
|
pFRAM->iClipb = iClipb;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_FRAM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_fram (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_FRAM, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_fram))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_FRAM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_fram (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_framp pFRAM = (mng_ani_framp)pObject;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_FRAM, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->iBreakpoint) /* previously broken ? */
|
|
{
|
|
iRetcode = process_display_fram2 (pData);
|
|
pData->iBreakpoint = 0; /* not again */
|
|
}
|
|
else
|
|
iRetcode = process_display_fram (pData, pFRAM->iFramemode,
|
|
pFRAM->iChangedelay, pFRAM->iDelay,
|
|
pFRAM->iChangetimeout, pFRAM->iTimeout,
|
|
pFRAM->iChangeclipping, pFRAM->iCliptype,
|
|
pFRAM->iClipl, pFRAM->iClipr,
|
|
pFRAM->iClipt, pFRAM->iClipb);
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_FRAM, MNG_LC_END)
|
|
#endif
|
|
|
|
return iRetcode;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_move (mng_datap pData,
|
|
mng_uint16 iFirstid,
|
|
mng_uint16 iLastid,
|
|
mng_uint8 iType,
|
|
mng_int32 iLocax,
|
|
mng_int32 iLocay)
|
|
{
|
|
mng_ani_movep pMOVE;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_MOVE, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pMOVE, sizeof (mng_ani_move))
|
|
|
|
pMOVE->sHeader.fCleanup = free_ani_move;
|
|
pMOVE->sHeader.fProcess = process_ani_move;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pMOVE);
|
|
|
|
pMOVE->iFirstid = iFirstid;
|
|
pMOVE->iLastid = iLastid;
|
|
pMOVE->iType = iType;
|
|
pMOVE->iLocax = iLocax;
|
|
pMOVE->iLocay = iLocay;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_MOVE, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_move (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_MOVE, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_move))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_MOVE, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_move (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_retcode iRetcode;
|
|
mng_ani_movep pMOVE = (mng_ani_movep)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_MOVE, MNG_LC_START)
|
|
#endif
|
|
/* re-process the MOVE chunk */
|
|
iRetcode = process_display_move (pData, pMOVE->iFirstid, pMOVE->iLastid,
|
|
pMOVE->iType,
|
|
pMOVE->iLocax, pMOVE->iLocay);
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_MOVE, MNG_LC_END)
|
|
#endif
|
|
|
|
return iRetcode;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_clip (mng_datap pData,
|
|
mng_uint16 iFirstid,
|
|
mng_uint16 iLastid,
|
|
mng_uint8 iType,
|
|
mng_int32 iClipl,
|
|
mng_int32 iClipr,
|
|
mng_int32 iClipt,
|
|
mng_int32 iClipb)
|
|
{
|
|
mng_ani_clipp pCLIP;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_CLIP, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pCLIP, sizeof (mng_ani_clip))
|
|
|
|
pCLIP->sHeader.fCleanup = free_ani_clip;
|
|
pCLIP->sHeader.fProcess = process_ani_clip;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pCLIP);
|
|
|
|
pCLIP->iFirstid = iFirstid;
|
|
pCLIP->iLastid = iLastid;
|
|
pCLIP->iType = iType;
|
|
pCLIP->iClipl = iClipl;
|
|
pCLIP->iClipr = iClipr;
|
|
pCLIP->iClipt = iClipt;
|
|
pCLIP->iClipb = iClipb;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_CLIP, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_clip (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_CLIP, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_clip))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_CLIP, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_clip (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_retcode iRetcode;
|
|
mng_ani_clipp pCLIP = (mng_ani_clipp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_CLIP, MNG_LC_START)
|
|
#endif
|
|
/* re-process the CLIP chunk */
|
|
iRetcode = process_display_clip (pData, pCLIP->iFirstid, pCLIP->iLastid,
|
|
pCLIP->iType,
|
|
pCLIP->iClipl, pCLIP->iClipr,
|
|
pCLIP->iClipt, pCLIP->iClipb);
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_CLIP, MNG_LC_END)
|
|
#endif
|
|
|
|
return iRetcode;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_show (mng_datap pData,
|
|
mng_uint16 iFirstid,
|
|
mng_uint16 iLastid,
|
|
mng_uint8 iMode)
|
|
{
|
|
mng_ani_showp pSHOW;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_SHOW, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pSHOW, sizeof (mng_ani_show))
|
|
|
|
pSHOW->sHeader.fCleanup = free_ani_show;
|
|
pSHOW->sHeader.fProcess = process_ani_show;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pSHOW);
|
|
|
|
pSHOW->iFirstid = iFirstid;
|
|
pSHOW->iLastid = iLastid;
|
|
pSHOW->iMode = iMode;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_SHOW, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_show (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_SHOW, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_show))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_SHOW, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_show (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_retcode iRetcode;
|
|
mng_ani_showp pSHOW = (mng_ani_showp)pObject;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_SHOW, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->iBreakpoint) /* returning from breakpoint ? */
|
|
{
|
|
iRetcode = process_display_show (pData);
|
|
}
|
|
else
|
|
{ /* "re-run" SHOW chunk */
|
|
pData->iSHOWmode = pSHOW->iMode;
|
|
pData->iSHOWfromid = pSHOW->iFirstid;
|
|
pData->iSHOWtoid = pSHOW->iLastid;
|
|
|
|
iRetcode = process_display_show (pData);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_SHOW, MNG_LC_END)
|
|
#endif
|
|
|
|
return iRetcode;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_term (mng_datap pData,
|
|
mng_uint8 iTermaction,
|
|
mng_uint8 iIteraction,
|
|
mng_uint32 iDelay,
|
|
mng_uint32 iItermax)
|
|
{
|
|
mng_ani_termp pTERM;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_TERM, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pTERM, sizeof (mng_ani_term))
|
|
|
|
pTERM->sHeader.fCleanup = free_ani_term;
|
|
pTERM->sHeader.fProcess = process_ani_term;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pTERM);
|
|
|
|
pTERM->iTermaction = iTermaction;
|
|
pTERM->iIteraction = iIteraction;
|
|
pTERM->iDelay = iDelay;
|
|
pTERM->iItermax = iItermax;
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_TERM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_term (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_TERM, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_term))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_TERM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_term (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_TERM, MNG_LC_START)
|
|
#endif
|
|
|
|
/* dummy: no action required! */
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_TERM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_save (mng_datap pData)
|
|
{
|
|
mng_ani_savep pSAVE;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_SAVE, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pSAVE, sizeof (mng_ani_save))
|
|
|
|
pSAVE->sHeader.fCleanup = free_ani_save;
|
|
pSAVE->sHeader.fProcess = process_ani_save;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pSAVE);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_SAVE, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_save (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_SAVE, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_save))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_SAVE, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_save (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_SAVE, MNG_LC_START)
|
|
#endif
|
|
|
|
iRetcode = process_display_save (pData);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_SAVE, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_seek (mng_datap pData)
|
|
{
|
|
mng_ani_seekp pSEEK;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_SEEK, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pSEEK, sizeof (mng_ani_seek))
|
|
|
|
pSEEK->sHeader.fCleanup = free_ani_seek;
|
|
pSEEK->sHeader.fProcess = process_ani_seek;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pSEEK);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_SEEK, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_seek (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_SEEK, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_seek))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_SEEK, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_seek (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_SEEK, MNG_LC_START)
|
|
#endif
|
|
|
|
iRetcode = process_display_seek (pData);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_SEEK, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_dhdr (mng_datap pData,
|
|
mng_uint16 iObjectid,
|
|
mng_uint8 iImagetype,
|
|
mng_uint8 iDeltatype,
|
|
mng_uint32 iBlockwidth,
|
|
mng_uint32 iBlockheight,
|
|
mng_uint32 iBlockx,
|
|
mng_uint32 iBlocky)
|
|
{
|
|
mng_ani_dhdrp pDHDR;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_DHDR, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pDHDR, sizeof (mng_ani_dhdr))
|
|
|
|
pDHDR->sHeader.fCleanup = free_ani_dhdr;
|
|
pDHDR->sHeader.fProcess = process_ani_dhdr;
|
|
|
|
pDHDR->iObjectid = iObjectid;
|
|
pDHDR->iImagetype = iImagetype;
|
|
pDHDR->iDeltatype = iDeltatype;
|
|
pDHDR->iBlockwidth = iBlockwidth;
|
|
pDHDR->iBlockheight = iBlockheight;
|
|
pDHDR->iBlockx = iBlockx;
|
|
pDHDR->iBlocky = iBlocky;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pDHDR);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_DHDR, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_dhdr (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_DHDR, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_dhdr))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_DHDR, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_dhdr (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_dhdrp pDHDR = (mng_ani_dhdrp)pObject;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_DHDR, MNG_LC_START)
|
|
#endif
|
|
|
|
pData->bHasDHDR = MNG_TRUE; /* let everyone know we're inside a DHDR */
|
|
|
|
iRetcode = process_display_dhdr (pData, pDHDR->iObjectid,
|
|
pDHDR->iImagetype, pDHDR->iDeltatype,
|
|
pDHDR->iBlockwidth, pDHDR->iBlockheight,
|
|
pDHDR->iBlockx, pDHDR->iBlocky);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_DHDR, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_prom (mng_datap pData,
|
|
mng_uint8 iBitdepth,
|
|
mng_uint8 iColortype,
|
|
mng_uint8 iFilltype)
|
|
{
|
|
mng_ani_promp pPROM;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_PROM, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pPROM, sizeof (mng_ani_prom))
|
|
|
|
pPROM->sHeader.fCleanup = free_ani_prom;
|
|
pPROM->sHeader.fProcess = process_ani_prom;
|
|
|
|
pPROM->iBitdepth = iBitdepth;
|
|
pPROM->iColortype = iColortype;
|
|
pPROM->iFilltype = iFilltype;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pPROM);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_PROM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_prom (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_PROM, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_prom))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_PROM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_prom (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_promp pPROM = (mng_ani_promp)pObject;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_PROM, MNG_LC_START)
|
|
#endif
|
|
|
|
iRetcode = process_display_prom (pData, pPROM->iBitdepth,
|
|
pPROM->iColortype, pPROM->iFilltype);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_PROM, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_ipng (mng_datap pData)
|
|
{
|
|
mng_ani_ipngp pIPNG;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_IPNG, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pIPNG, sizeof (mng_ani_ipng))
|
|
|
|
pIPNG->sHeader.fCleanup = free_ani_ipng;
|
|
pIPNG->sHeader.fProcess = process_ani_ipng;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pIPNG);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_IPNG, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_ipng (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_IPNG, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_ipng))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_IPNG, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_ipng (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_IPNG, MNG_LC_START)
|
|
#endif
|
|
|
|
iRetcode = process_display_ipng (pData);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_IPNG, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_ijng (mng_datap pData)
|
|
{
|
|
mng_ani_ijngp pIJNG;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_IJNG, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pIJNG, sizeof (mng_ani_ijng))
|
|
|
|
pIJNG->sHeader.fCleanup = free_ani_ijng;
|
|
pIJNG->sHeader.fProcess = process_ani_ijng;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pIJNG);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_IJNG, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_ijng (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_IJNG, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_ijng))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_IJNG, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_ijng (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_IJNG, MNG_LC_START)
|
|
#endif
|
|
|
|
iRetcode = process_display_ijng (pData);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_IJNG, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_pplt (mng_datap pData,
|
|
mng_uint8 iType,
|
|
mng_uint32 iCount,
|
|
mng_palette8ep paIndexentries,
|
|
mng_uint8p paAlphaentries,
|
|
mng_uint8p paUsedentries)
|
|
{
|
|
mng_ani_ppltp pPPLT;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_PPLT, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pPPLT, sizeof (mng_ani_pplt))
|
|
|
|
pPPLT->sHeader.fCleanup = free_ani_pplt;
|
|
pPPLT->sHeader.fProcess = process_ani_pplt;
|
|
|
|
pPPLT->iType = iType;
|
|
pPPLT->iCount = iCount;
|
|
|
|
MNG_COPY (pPPLT->aIndexentries, paIndexentries, sizeof (pPPLT->aIndexentries))
|
|
MNG_COPY (pPPLT->aAlphaentries, paAlphaentries, sizeof (pPPLT->aAlphaentries))
|
|
MNG_COPY (pPPLT->aUsedentries, paUsedentries, sizeof (pPPLT->aUsedentries ))
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pPPLT);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_PPLT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_pplt (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_PPLT, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_pplt))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_PPLT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_pplt (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_ppltp pPPLT = (mng_ani_ppltp)pObject;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_PPLT, MNG_LC_START)
|
|
#endif
|
|
|
|
iRetcode = process_display_pplt (pData, pPPLT->iType, pPPLT->iCount,
|
|
pPPLT->aIndexentries, pPPLT->aAlphaentries,
|
|
pPPLT->aUsedentries);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_PPLT, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode create_ani_magn (mng_datap pData,
|
|
mng_uint16 iFirstid,
|
|
mng_uint16 iLastid,
|
|
mng_uint16 iMethodX,
|
|
mng_uint16 iMX,
|
|
mng_uint16 iMY,
|
|
mng_uint16 iML,
|
|
mng_uint16 iMR,
|
|
mng_uint16 iMT,
|
|
mng_uint16 iMB,
|
|
mng_uint16 iMethodY)
|
|
{
|
|
mng_ani_magnp pMAGN;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_MAGN, MNG_LC_START)
|
|
#endif
|
|
|
|
if (pData->bCacheplayback) /* caching playback info ? */
|
|
{
|
|
MNG_ALLOC (pData, pMAGN, sizeof (mng_ani_magn))
|
|
|
|
pMAGN->sHeader.fCleanup = free_ani_magn;
|
|
pMAGN->sHeader.fProcess = process_ani_magn;
|
|
|
|
pMAGN->iFirstid = iFirstid;
|
|
pMAGN->iLastid = iLastid;
|
|
pMAGN->iMethodX = iMethodX;
|
|
pMAGN->iMX = iMX;
|
|
pMAGN->iMY = iMY;
|
|
pMAGN->iML = iML;
|
|
pMAGN->iMR = iMR;
|
|
pMAGN->iMT = iMT;
|
|
pMAGN->iMB = iMB;
|
|
pMAGN->iMethodY = iMethodY;
|
|
|
|
add_ani_object (pData, (mng_object_headerp)pMAGN);
|
|
}
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_CREATE_ANI_MAGN, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode free_ani_magn (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_MAGN, MNG_LC_START)
|
|
#endif
|
|
|
|
MNG_FREEX (pData, pObject, sizeof (mng_ani_magn))
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_FREE_ANI_MAGN, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
mng_retcode process_ani_magn (mng_datap pData,
|
|
mng_objectp pObject)
|
|
{
|
|
mng_ani_magnp pMAGN = (mng_ani_magnp)pObject;
|
|
mng_retcode iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_MAGN, MNG_LC_START)
|
|
#endif
|
|
|
|
iRetcode = process_display_magn (pData, pMAGN->iFirstid, pMAGN->iLastid,
|
|
pMAGN->iMethodX, pMAGN->iMX, pMAGN->iMY,
|
|
pMAGN->iML, pMAGN->iMR, pMAGN->iMT, pMAGN->iMB,
|
|
pMAGN->iMethodY);
|
|
|
|
if (iRetcode) /* on error bail out */
|
|
return iRetcode;
|
|
|
|
#ifdef MNG_SUPPORT_TRACE
|
|
MNG_TRACE (pData, MNG_FN_PROCESS_ANI_MAGN, MNG_LC_END)
|
|
#endif
|
|
|
|
return MNG_NOERROR;
|
|
}
|
|
|
|
/* ************************************************************************** */
|
|
|
|
#endif /* MNG_INCLUDE_DISPLAY_PROCS */
|
|
|
|
/* ************************************************************************** */
|
|
/* * end of file * */
|
|
/* ************************************************************************** */
|
|
|