LDialogColor::DoModalRemapIntensity
#include "ltwrappr.h"
virtual L_INT LDialogColor::DoModalRemapIntensity(hWndOwner)
HWND hWndOwner; |
/* handle of the window which owns the dialog */ |
Displays the Remap Intensity dialog box, and gets the options for LBitmap::RemapIntensity.
Parameter |
Description |
hWndOwner |
Handle of the window which owns the dialog. |
Returns
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. |
Comments
LDialogColor::SetRemapIntensityParams must be called before using this function to set the initial values for the dialog. You can get the updated REMAPINTENSITYDLGPARAMS with the values entered by the user through the dialog by using LDialogColor::GetRemapIntensityParams.
The Remap Intensity dialog is shown in the following figure:
This dialog has the following fields:
Use this to select the channel to remap. There are four choices:
- RGB: remap all channels.
- Red: remap the red channel.
- Green: remap the green channel.
- Blue: remap the blue channel.
Use this to select the curve mode to use when remapping. There are four choices:
- Curve: remaps the selected channel using curve data.
- Linear: remaps the selected channel using linear data.
- Exponential: remaps the selected channel using exponential data, which is affected by the Factor value.
- Logarithm: remaps the selected channel using logarithmic data, which is affected by the Factor value.
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. Flip the curve vertically and horizontally.
- Vertically. Flip the curve vertically.
- Horizontally. Flip the curve horizontally.
Use the Reset button to set the curve of the current channel to 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 "*.lri" file that contains Remap Intensity 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 "*.lri" file. This allows you set the same curve settings for other images by re-loading the file.
Required DLLs and Libraries
LTDLGCLR For a listing of the exact DLLs and Libraries needed, based on the toolkit version, refer to Files To Be Included With Your Application |
See Also
Functions: |
|
Topics: |
|
|
Example
void TestFunction(LBitmap * pBitmap, HWND hWnd)
{
LDialogColor DlgColor;
DlgColor.Initialize(DLG_INIT_COLOR
);
DlgColor.SetBitmap(pBitmap);
REMAPINTENSITYDLGPARAMS DlgParams;
memset ( &DlgParams, 0, sizeof ( REMAPINTENSITYDLGPARAMS
) ) ;
DlgParams.uStructSize = sizeof ( REMAPINTENSITYDLGPARAMS
) ;
DlgParams.uChannel = CHANNEL_RED ;
DlgColor.EnableCallBack(FALSE);
DlgColor.EnablePreview(TRUE);
DlgColor.EnableAutoProcess(TRUE);
DlgColor.EnableToolbar(TRUE);
DlgColor.SetRemapIntensityParams(&DlgParams)
;
DlgColor.DoModalRemapIntensity(hWnd);
// Gets the updated values for the structure
DlgColor.GetRemapIntensityParams(&DlgParams,
sizeof(DlgParams)) ;
DlgColor.Free();
if ( NULL != DlgParams.puRGBLookup )
{
GlobalFree ( DlgParams.puRGBLookup
) ;
}
if ( NULL != DlgParams.puRedLookup )
{
GlobalFree ( DlgParams.puRedLookup
) ;
}
if ( NULL != DlgParams.puGreenLookup )
{
GlobalFree ( DlgParams.puGreenLookup
) ;
}
if ( NULL != DlgParams.puBlueLookup )
{
GlobalFree ( DlgParams.puBlueLookup
) ;
}
}