Displays the Remap Hue dialog box, and gets the options for L_RemapBitmapHue.
#include "l_bitmap.h"
L_LTDLG_API L_INT L_DlgRemapHue (hWndOwner, pDlgParams)
Handle of the window which owns the dialog.
Pointer to a REMAPHUEDLGPARAMS structure to be updated with the values entered by the user, through the dialog. Set members of this structure, before calling this function, to set the dialogs initial values.
Value | Meaning |
---|---|
SUCCESS_DLG_OK | The "OK" button was pressed, and the dialog exited successfully. |
SUCCESS_DLG_CANCEL | The "Cancel" button was pressed, and the dialog exited successfully. |
< 1 | An error occurred. Refer to Return Codes. |
This dialog has the following fields:
Use this to select the channel to remap. There are three choices:
Use this to select the curve mode to use when remapping. There are four choices:
Curve
Linear
Exponential
Logarithm
Use this to set the factor of the Exponential/Logarithm curve. Enter the value directly in the edit box or use the arrows to set the desired value.
Use these buttons to flip the curve if the Curve Mode is either Curve or Linear. The following options are available:
Both
Vertically
Horizontally
Use the Mask Multi-slider Control to specify the range of values for which to apply the changes specified by the channel, the Curve mode and the factor. The first marker from the left is the minimum value of the range, and the second is the maximum value.
Use the Reset button to set the curve of the current channel to the default values.
Use the Reset All button to set the curve for all the channels to default values.
Use the Load button to load an "*.lrh" file that contains Remap Hue curve settings, using the Load dialog. The loaded file will set a new curve for each channel.
✎ NOTE
Loading curve settings will overwrite all current settings for all channels.
Use the Save button to save all the curve settings for all the channels into an "*.lrh" file. This allows you set the same curve settings for other images by re-loading the file.
L_INT ShowDlgRemapHueExample(HWND hWnd,
pBITMAPHANDLE pBitmap)
{
L_INT nRet;
REMAPHUEDLGPARAMS DlgParams ;
memset ( &DlgParams, 0, sizeof ( REMAPHUEDLGPARAMS ) ) ;
DlgParams.uStructSize = sizeof ( REMAPHUEDLGPARAMS ) ;
DlgParams.pBitmap = pBitmap ;
DlgParams.uDlgFlags = DLG_REMAPHUE_SHOW_PREVIEW |
DLG_REMAPHUE_SHOW_TOOL_ZOOMLEVEL ;
nRet = L_DlgInit ( DLG_INIT_COLOR ) ;
if(nRet != SUCCESS && nRet != ERROR_DLG_ALREADYINITIATED)
return nRet;
nRet = L_DlgRemapHue ( hWnd, &DlgParams ) ;
if(nRet < 1)
return nRet;
if ( NULL != DlgParams.puMaskLookup )
{
GlobalFree ( DlgParams.puMaskLookup ) ;
}
if ( NULL != DlgParams.puHueLookup )
{
GlobalFree ( DlgParams.puHueLookup ) ;
}
if ( NULL != DlgParams.puSaturationLookup )
{
GlobalFree ( DlgParams.puSaturationLookup ) ;
}
if ( NULL != DlgParams.puValueLookup )
{
GlobalFree ( DlgParams.puValueLookup ) ;
}
nRet = L_DlgFree () ;
if(nRet != SUCCESS)
return nRet;
return SUCCESS;
} ;