LDialogImageEffect::DoModalSpherize

#include "ltwrappr.h"

virtual L_INT LDialogImageEffect::DoModalSpherize(hWndOwner)

HWND hWndOwner;

/* handle of the window which owns the dialog */

Displays the Spherize dialog box, and gets the options for LBitmap::Spherize. This function is available in the Raster Pro and above toolkits.

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

LDialogImageEffect::SetSpherizeParams must be called before using this function to set the initial values for the dialog. You can get the updated SPHERIZEDLGPARAMS with the values entered by the user through the dialog by using LDialogImageEffect::GetSpherizeParams.

The Spherize dialog is shown in the following figure:

image\BeforeAfterZoomToFit.gif Zoom to fit

Use this button to fit entire preview images on both the Before and After views.

image\BeforeAfterZoomToNormal.gif Zoom to Normal

Use this button to view images with normal scale on both the Before and After views.

Before View

This view shows the original image before the dialog applies any changes to it.

The view can be dragged when it is not in Zoom to Fit zoom mode. Place the mouse cursor over the view window (the cursor will change to a hand), then click and drag.

After View

This view shows the original image with the dialog changes applied. This enables the user to see a preview of what the image should look like when the changes are applied.

The view can be dragged when it is not in Zoom to Fit zoom mode. Place the mouse cursor over the view window (the cursor will change to a hand), then click and drag.

Value Edit box and Slider:

Use the Value edit box or slider to set the amount of stretching. Positive values stretch the image toward the edges, and negative values stretch the image toward its center.

Exposed Area Group

Specifies how to fill the exposed area, if found.

image\sqrblit.gif Use Color, use the color from color picker button; to select the color that will fill exposed area lift unfilled. Clicking the color picker button will activate a Color Dialog that will be used to set the required color.

image\sqrblit.gif Stretch Image, stretches the image edges to fill the exposed area.

image\sqrblit.gif Don’t Change, leaves the exposed area without changing it.

Rotate Check box:

Check this to rotate the image inside the spherical pattern. It is available only if the Value edit box contains a positive value.

image\Icon_Pivot.gif Pivot Section:

This section contains two edit boxes and a display area for setting the pivot point. You can also set the pivot point by right clicking on the Before view. The Pivot point image\Icon_Pivot.gif appears on the point you just clicked.

X Edit box:

Use this to set the pivot's x-axis position in the image. Enter the value directly in the edit box or use the arrows to set the desired value.

Y Edit box:

Use this to set the pivot's y-axis position in the image. Enter the value directly in the edit box or use the arrows to set the desired value.

Cursor Pos (x,y)

Displays the mouse position with respect to the image.

Center Button:

Use the Center button to center the Before and After views with respect to image\Icon_Pivot.gif the pivot point position.

OK

Use the OK button to close the dialog and apply the changes.

Cancel

Use the Cancel button to close the dialog and discard the changes.

Progress Bar

image\BeforeAfterProgressBar.gif

Located at the bottom of the dialog, this progress bar shows the percentage of the current dialog operation that has been completed.

Required DLLs and Libraries

LTDLGIMGEFX
LTDLGKRN
LTDLGUTL
LTDLGCTRL
LTDLGCOM
LTDIS
LTIMG

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:

LDialogBase::Initialize, LBitmap::Spherize, LBase::EnableCallBack, LDialogBase::EnablePreview, LDialogBase::EnableAutoProcess, LDialogBase::EnableToolbar, LDialogBase::Free, LDialogImageEffect::SetSpherizeParams, LDialogImageEffect::GetSpherizeParams

Topics:

Using Imaging Common Dialog

Example

void TestFunction(LBitmap * pBitmap, HWND hWnd)
{
   LDialogImageEffect DlgImageEffect;
   LDialogImageEffect::Initialize(DLG_INIT_COLOR );
   DlgImageEffect.SetBitmap(pBitmap);

   SPHERIZEDLGPARAMS DlgParams; 

   memset ( &DlgParams, 0, sizeof ( SPHERIZEDLGPARAMS ) );

   DlgParams.uStructSize  = sizeof ( SPHERIZEDLGPARAMS );

   DlgImageEffect.EnableCallBack(FALSE);
   DlgImageEffect.EnablePreview(TRUE);
   DlgImageEffect.EnableAutoProcess(TRUE);
   DlgImageEffect.EnableToolbar(TRUE);
   DlgImageEffect.SetSpherizeParams(&DlgParams);
   DlgImageEffect.DoModalSpherize(hWnd);

   // Gets the updated values for the structure
   DlgImageEffect.GetSpherizeParams(&DlgParams, sizeof(DlgParams));

   LDialogImageEffect::Free();
}