456 lines
14 KiB
C++
Raw Permalink Normal View History

2001-01-01 00:00:00 +01:00
/* *************************************************************************
** INTEL Corporation Proprietary Information
**
** This listing is supplied under the terms of a license
** agreement with INTEL Corporation and may not be copied
** nor disclosed except in accordance with the terms of
** that agreement.
**
** Copyright (c) 1995,1996 Intel Corporation.
** All Rights Reserved.
**
** *************************************************************************
*/
;//
;// Description: This module implements the following functions.
;// CustomChangeBrightness();
;// CustomChangeContrast();
;// CustomChangeSaturation();
;// CustomResetBrightness();
;// CustomResetContrast();
;// CustomResetSaturation();
;// CustomGetBrightness();
;// CustomGetContrast();
;// CustomGetSaturation();
;//
;// $Author: BECHOLS $
;// $Date: 09 Dec 1996 08:51:44 $
;// $Archive: S:\h26x\src\dec\dxctrls.cpv $
;// $Header: S:\h26x\src\dec\dxctrls.cpv 1.14 09 Dec 1996 08:51:44 BECHOLS $
;// $Log: S:\h26x\src\dec\dxctrls.cpv $
//
// Rev 1.14 09 Dec 1996 08:51:44 BECHOLS
// Fixed reset saturation, so that it modified chroma table, not luma.
//
// Rev 1.13 20 Oct 1996 13:33:32 AGUPTA2
// Changed DBOUT into DbgLog. ASSERT is not changed to DbgAssert.
//
//
// Rev 1.12 10 Sep 1996 10:31:38 KLILLEVO
// changed all GlobalAlloc/GlobalLock calls to HeapAlloc
//
// Rev 1.11 11 Jul 1996 14:09:18 SCDAY
// Added comments re: CustomGetB/C/S functions
//
// Rev 1.10 10 Jul 1996 08:21:26 SCDAY
// Added functions for CustomGetBrightness/Contrast/Saturation (DBrucks)
//
// Rev 1.9 04 Jun 1996 09:04:00 AKASAI
// Fixed bug in CustomResetSaturation where it was reseting the LumaTable
// instead of the ChromaTable. This was discovered in Quartz testing.
//
// Rev 1.8 01 Feb 1996 10:16:24 BNICKERS
// Fix the "knobs".
//
// Rev 1.7 22 Dec 1995 13:53:06 KMILLS
//
// added new copyright notice
//
// Rev 1.6 17 Nov 1995 15:22:12 BECHOLS
//
// Added ring 0 stuff.
//
// Rev 1.5 01 Nov 1995 16:52:24 TRGARDOS
// Fixed unmatched GlobalUnlocks.
//
// Rev 1.4 25 Oct 1995 18:14:02 BNICKERS
//
// Clean up archive stuff.
//
// Rev 1.3 20 Sep 1995 09:23:52 SCDAY
//
// added #ifdef for #include d?dec.h
//
// Rev 1.2 01 Sep 1995 09:49:36 DBRUCKS
// checkin partial ajdust pels changes
//
// Rev 1.1 23 Aug 1995 12:24:04 DBRUCKS
// change to H26X_DEFAULT_* from H263_ as these are shared values.
//
// Rev 1.0 31 Jul 1995 13:00:14 DBRUCKS
// Initial revision.
//
// Rev 1.1 24 Jul 1995 15:00:40 CZHU
//
// Adjust the changes to the decoder catalog structure
//
// Rev 1.0 17 Jul 1995 14:46:18 CZHU
// Initial revision.
//
// Rev 1.0 17 Jul 1995 14:14:22 CZHU
// Initial revision.
;////////////////////////////////////////////////////////////////////////////
#include "precomp.h"
#define SCALE 128
#define ACTIVE_RANGE 256
#define OFFSET_TABLE_COPY 256 + 16
typedef BOOL FAR *LPBOOL;
typedef struct {
LPBYTE LumaTable;
LPBOOL LumaFlag;
LPBYTE ChromaTable;
LPBOOL ChromaFlag;
LPBYTE Brightness;
LPBYTE Contrast;
LPBYTE Saturation;
} PIXDAT, FAR *LPPIXDAT;
/**********************************************************************
* static WORD LockLCTables(LPDECINST, LPPIXDAT);
* Description: This function locks the memory and fills the Pixel Data
* Structure with valid pointers to the tables that I need
* to adjust.
* History: 06/29/94 -BEN-
**********************************************************************/
static LRESULT LockLCTables(LPDECINST lpInst, LPPIXDAT lpPixData)
{
T_H263DecoderCatalog *DC;
FX_ENTRY("LockLCTables")
if(IsBadWritePtr((LPVOID)lpInst, sizeof(DECINSTINFO)))
{
ERRORMESSAGE(("%s: ICERR_BADPARAM\r\n", _fx_));
return(ICERR_BADPARAM);
}
DC = (T_H263DecoderCatalog *) ((((U32) lpInst->pDecoderInst) + 31) & ~0x1F);
lpPixData->LumaTable = (LPBYTE)(DC->p16InstPostProcess +
DC->X16_LumaAdjustment);
lpPixData->ChromaTable = (LPBYTE)(DC->p16InstPostProcess +
DC->X16_ChromaAdjustment);
lpPixData->LumaFlag = (LPBOOL)&(DC->bAdjustLuma);
lpPixData->ChromaFlag = (LPBOOL)&(DC->bAdjustChroma);
lpPixData->Brightness = (LPBYTE)&(DC->BrightnessSetting);
lpPixData->Contrast = (LPBYTE)&(DC->ContrastSetting);
lpPixData->Saturation = (LPBYTE)&(DC->SaturationSetting);
return(ICERR_OK);
}
/*********************************************************************
* static LRESULT UnlockLCTables(LPDECINST, LPPIXDAT);
* Description: This funtion unlocks
* History: 06/30/94 -BEN-
**********************************************************************/
static LRESULT UnlockLCTables(LPDECINST lpInst, LPPIXDAT lpPixData)
{
T_H263DecoderCatalog *DC;
DC = (T_H263DecoderCatalog *) ((((U32) lpInst->pDecoderInst) + 31) & ~0x1F);
lpPixData->LumaTable = (LPBYTE)NULL;
lpPixData->ChromaTable = (LPBYTE)NULL;
lpPixData->LumaFlag = (LPBOOL)NULL;
lpPixData->ChromaFlag = (LPBOOL)NULL;
return(ICERR_OK);
}
/**********************************************************************
* static VOID MassageContrast(BYTE, PBYTE);
* Description: input is 0 to 255, 1/SCALE to 256/SCALE inclusive
* 0 = 1/SCALE
* 1 = 2/SCALE
* n = (n + 1) / SCALE
* SCALE - 1 = 1 yields no change
* 255 = 256/SCALE
* if the response is too coarse, SCALE can be increased
* if the response is too fine, SCALE can be decreased
*
* History: 02/22/94 -BEN- Added header.
**********************************************************************/
static VOID MassageContrast(BYTE offsetfactor, LPBYTE table)
{
int i;
long temp, contrastfactor;
contrastfactor = ((long)((DWORD)offsetfactor)) + 1; // 1 - 256
contrastfactor = (contrastfactor * ACTIVE_RANGE) / 256L;
for(i = 0; i < 256; i++)
{
temp = (long)((DWORD)table[i]);
temp -= (ACTIVE_RANGE / 2L); // add centering
temp *= contrastfactor;
temp /= SCALE;
temp += (ACTIVE_RANGE / 2L); // remove centering
if(temp < 0) // and clamp
table[i] = 0;
else if(temp <= 255)
table[i] = (unsigned char) temp;
else
table[i] = 255;
table[i+OFFSET_TABLE_COPY] = table[i];
}
return;
}
;////////////////////////////////////////////////////////////////////////////
;// Function: LRESULT CustomChangeBrightness(LPDECINST, BYTE);
;//
;// Description: Added header.
;//
;// History: 02/22/94 -BEN-
;////////////////////////////////////////////////////////////////////////////
LRESULT CustomChangeBrightness(LPDECINST lpInst, BYTE offsetdelta)
{
LRESULT lRes;
int delta, temp, i;
PIXDAT PixData;
lRes = LockLCTables(lpInst, &PixData);
if(lRes == ICERR_OK)
{
CustomResetBrightness(lpInst);
if(offsetdelta != H26X_DEFAULT_BRIGHTNESS)
{
delta = ((offsetdelta - 128) * ACTIVE_RANGE) / 256; // -128 to 127
for(i = 0; i < 256; i++)
{
temp = (int)PixData.LumaTable[i] + delta;
if(temp < 0) PixData.LumaTable[i] = 0;
else if(temp <= 255) PixData.LumaTable[i] = (BYTE)temp;
else PixData.LumaTable[i] = 255;
PixData.LumaTable[i+OFFSET_TABLE_COPY] = PixData.LumaTable[i];
}
*(PixData.Brightness) = offsetdelta;
*(PixData.LumaFlag) = TRUE;
}
lRes = UnlockLCTables(lpInst, &PixData);
}
return(lRes);
}
;////////////////////////////////////////////////////////////////////////////
;// Function: LRESULT CustomChangeContrast(LPDECINST, BYTE);
;//
;// Description: Added header.
;//
;// History: 02/22/94 -BEN-
;////////////////////////////////////////////////////////////////////////////
LRESULT CustomChangeContrast(LPDECINST lpInst, BYTE offsetfactor)
{
LRESULT lRes;
PIXDAT PixData;
lRes = LockLCTables(lpInst, &PixData);
if(lRes == ICERR_OK)
{
CustomResetContrast(lpInst);
if(offsetfactor != H26X_DEFAULT_CONTRAST)
{
MassageContrast(offsetfactor, PixData.LumaTable);
*(PixData.Contrast) = offsetfactor;
*(PixData.LumaFlag) = TRUE;
}
lRes = UnlockLCTables(lpInst, &PixData);
}
return(lRes);
}
;////////////////////////////////////////////////////////////////////////////
;// Function: LRESULT CustomChangeSaturation(LPDECINST, BYTE);
;//
;// Description: Added header.
;//
;// History: 02/22/94 -BEN-
;////////////////////////////////////////////////////////////////////////////
LRESULT CustomChangeSaturation(LPDECINST lpInst, BYTE offsetfactor)
{
LRESULT lRes;
PIXDAT PixData;
lRes = LockLCTables(lpInst, &PixData);
if(lRes == ICERR_OK)
{
CustomResetSaturation(lpInst);
if(offsetfactor != H26X_DEFAULT_SATURATION)
{
MassageContrast(offsetfactor, PixData.ChromaTable);
*(PixData.Saturation) = offsetfactor;
*(PixData.ChromaFlag) = TRUE;
}
lRes = UnlockLCTables(lpInst, &PixData);
}
return(lRes);
}
#ifdef QUARTZ
/************************************************************************
* CustomGetBrightness
*
* Gets the current brightness value
***********************************************************************/
LRESULT CustomGetBrightness(
LPDECINST lpInst,
BYTE * pValue)
{
LRESULT lResult = ICERR_ERROR;
T_H263DecoderCatalog *DC;
DC = (T_H263DecoderCatalog *) ((((U32) lpInst->pDecoderInst) + 31) & ~0x1F);
*pValue = (BYTE) DC->BrightnessSetting;
lResult = ICERR_OK;
return lResult;
} /* end CustomGetBrightness() */
/************************************************************************
* CustomGetContrast
*
* Gets the current contrast value
***********************************************************************/
LRESULT CustomGetContrast(
LPDECINST lpInst,
BYTE * pValue)
{
LRESULT lResult = ICERR_ERROR;
T_H263DecoderCatalog *DC;
DC = (T_H263DecoderCatalog *) ((((U32) lpInst->pDecoderInst) + 31) & ~0x1F);
*pValue = (BYTE) DC->ContrastSetting;
lResult = ICERR_OK;
return lResult;
} /* end CustomGetContrast() */
/************************************************************************
*
* CustomGetSaturation
*
* Gets the current saturation value
***********************************************************************/
LRESULT CustomGetSaturation(
LPDECINST lpInst,
BYTE * pValue)
{
LRESULT lResult = ICERR_ERROR;
T_H263DecoderCatalog *DC;
DC = (T_H263DecoderCatalog *) ((((U32) lpInst->pDecoderInst) + 31) & ~0x1F);
*pValue = (BYTE) DC->SaturationSetting;
lResult = ICERR_OK;
return lResult;
} /* end CustomGetSaturation() */
#endif /* QUARTZ */
;////////////////////////////////////////////////////////////////////////////
;// Function: LRESULT CustomResetBrightness(LPDECINST lpInst);
;//
;// Description: Sets the luminance table to identity, and resets
;// flag indicating need to use.
;//
;// History: 02/22/94 -BEN-
;////////////////////////////////////////////////////////////////////////////
LRESULT CustomResetBrightness(LPDECINST lpInst)
{
LRESULT lRes;
int i;
PIXDAT PixData;
lRes = LockLCTables(lpInst, &PixData);
if(lRes == ICERR_OK)
{
for(i = 0; i < 256; i++)
{
PixData.LumaTable[i] = i;
PixData.LumaTable[i+OFFSET_TABLE_COPY] = i;
}
*(PixData.LumaFlag) = FALSE;
*(PixData.Brightness) = H26X_DEFAULT_BRIGHTNESS;
if(*(PixData.Contrast) != H26X_DEFAULT_CONTRAST)
CustomChangeContrast(lpInst, *(PixData.Contrast));
lRes = UnlockLCTables(lpInst, &PixData);
}
return(lRes);
}
;////////////////////////////////////////////////////////////////////////////
;// Function: LRESULT CustomResetContrast(LPDECINST lpInst);
;//
;// Description: Sets the luminance table to identity, and resets
;// flag indicating need to use.
;//
;// History: 02/22/94 -BEN-
;////////////////////////////////////////////////////////////////////////////
LRESULT CustomResetContrast(LPDECINST lpInst)
{
LRESULT lRes;
int i;
PIXDAT PixData;
lRes = LockLCTables(lpInst, &PixData);
if(lRes == ICERR_OK)
{
for(i = 0; i < 256; i++)
{
PixData.LumaTable[i] = i;
PixData.LumaTable[i+OFFSET_TABLE_COPY] = i;
}
*(PixData.LumaFlag) = FALSE;
*(PixData.Contrast) = H26X_DEFAULT_CONTRAST;
if(*(PixData.Brightness) != H26X_DEFAULT_BRIGHTNESS)
CustomChangeBrightness(lpInst, *(PixData.Brightness));
lRes = UnlockLCTables(lpInst, &PixData);
}
return(lRes);
}
;////////////////////////////////////////////////////////////////////////////
;// Function: LRESULT CustomResetSaturation(LPDECINST);
;//
;// Description: Sets chroma tables to identity, and resets
;// flag indicating need to use.
;//
;// History: 02/22/94 -BEN-
;////////////////////////////////////////////////////////////////////////////
LRESULT CustomResetSaturation(LPDECINST lpInst)
{
LRESULT lRes;
int i;
PIXDAT PixData;
lRes = LockLCTables(lpInst, &PixData);
if(lRes == ICERR_OK)
{
for(i = 0; i < 256; i++)
{
PixData.ChromaTable[i] = i;
PixData.ChromaTable[i+OFFSET_TABLE_COPY] = i;
}
*(PixData.ChromaFlag) = FALSE;
*(PixData.Saturation) = H26X_DEFAULT_SATURATION;
lRes = UnlockLCTables(lpInst, &PixData);
}
return(lRes);
}