LEADCAPTUREAREAOPTION

typedef struct tagLEADCAPTUREAREAOPTION
{
   L_UINT uStructSize; 
   L_UINT uAreaType; 
   L_INT nFillPattern; 
   COLORREF crFillForeColor; 
   COLORREF crFillBackColor; 
   L_UINT uDrawLineStyle; 
   COLORREF crDrawLineColor; 
   L_UINT uEllipseWidth; 
   L_UINT uEllipseHeight; 
   L_UINT uFlags; 
   HCURSOR hDrawCursor;
   COLORREF crTextForeColor; 
   COLORREF crTextBackColor; 
   L_INT nInfoLeft; 
   L_INT nInfoTop; 
   L_INT nInfoWidth; 
   L_INT nInfoHeight; 
} LEADCAPTUREAREAOPTION, * LPLEADCAPTUREAREAOPTION;

This structure is used to define the options of the L_CaptureArea function.

Member

Description

uStructSize

Size of this structure in bytes, for versioning. Use the sizeof() macro to calculate this value.

uAreaType

Type of area to capture. Possible values for enumeration AREATYPEENUM are:

 

CAPTURE_AREA_TRIANGLE

Triangle

 

CAPTURE_AREA_RECT

Rectangle

 

CAPTURE_AREA_ROUNDRECT

Rounded Rectangle

 

CAPTURE_AREA_ELLIPSE

Ellipse

 

CAPTURE_AREA_POLYGON

Polygon (each click defines point)

 

CAPTURE_AREA_FREEHAND

Freehand (click and drag)

nFillPattern

Fill pattern for the bitmap. Possible values are:

 

CAPTURE_AREA_PATTERN_HORIZONTAL

HS_HORIZONTAL /* ----- */

 

CAPTURE_AREA_PATTERN_VERTICAL

HS_VERTICAL /* ||||| */

 

CAPTURE_AREA_PATTERN_FDIAGONAL

HS_FDIAGONAL /* \\\\\ */

 

CAPTURE_AREA_PATTERN_BDIAGONAL

HS_BDIAGONAL /* ///// */

 

CAPTURE_AREA_PATTERN_CROSS

HS_CROSS /* +++++ */

 

CAPTURE_AREA_PATTERN_DIAGCROSS

HS_DIAGCROSS /* xxxxx */

 

CAPTURE_AREA_PATTERN_SOLID

HS_DIAGCROSS+1 /*Solid Fill*/

crFillForeColor

Foreground color.

crFillBackColor

Background color.

uDrawLineStyle

Draw line style. Possible values are:

 

CAPTURE_AREA_LINE_SOLID

PS_SOLID /*________*/

 

CAPTURE_AREA_LINE_DASH

PS_DASH /*----------*/

 

CAPTURE_AREA_LINE_DOT

PS_DOT /*..........*/

 

CAPTURE_AREA_LINE_DASHDOT

PS_DASHDOT /*-.-.-.-.-.*/

 

CAPTURE_AREA_LINE_DASHDOTDOT

PS_DASHDOTDOT /*-..-..-*/

crDrawLineColor

Line color for drawing.

uEllipseWidth

Width of the ellipse used when drawing a rounded rectangle.

uEllipseHeight

Height of the ellipse used when drawing a rounded rectangle.

uFlags

Flags for options. Possible values are:

 

CAPTURE_AREA_SHOW_DRAWCURSOR

[0x0001] Show cursor during drawing.

 

CAPTURE_AREA_INCLUDE_CURSOR

[0x0002] Include cursor in captured image (this is the hCursor from LEADCAPTUREOPTION).

 

CAPTURE_AREA_ENABLE_KEYBOARD

[0x0004] Allow Ctrl, Shift,+,- keys during capture.

 

 

(+/-) Are used for Zooming In/Out in the info window

 

 

(Ctrl) If Area is Rect, RoundRect, or Ellipse, pressing CTRL will center the drawing.

 

 

(Shift) If Area is Rect, RoundRect, or Ellipse, pressing SHIFT will draw regular shapes (that is Ellipse becomes a circle , Rectangle becomes a Square, etc.).

 

CAPTURE_AREA_SHOW_OPAQUE_TEXT

[0x0008] Text for cursor position and capture size should have an opaque back color. (Used only for the above CAPTURE_AREA_SHOW_CURSORPOS and CAPTURE_AREA_SHOW_CAPTURESIZE. The info window has opaque text).

 

CAPTURE_AREA_SHOW_CURSORPOS

[0x0010] Show cursor position during drawing right next to the cursor

 

CAPTURE_AREA_SHOW_CAPTURESIZE

[0x0020] Show the width and height of the capture.

 

CAPTURE_AREA_SHOW_INFOWINDOW

[0x0040] Display the info window, the current cursor location, the coordinates of the cursor, and the width and height of the area.

 

CAPTURE_AREA_SENSITIVE_INFOWINDOW

[0x0080] Enable Sensitive detection for the Info window position.

 

CAPTURE_AREA_BITMAP_WITH_REGION

[0x0100] Captured bitmap will contain a region selected by user. This region will be the shape indicated in Area.

 

CAPTURE_AREA_USE_DEFAULT_VALUES

[0x0200] Use default capture area options, all the other flags will be ignored if this flag is set.

 

 

When this flag is set, uAreaType and uSize must be set.

 

CAPTURE_AREA_ZOOM_NORM

[0x1000] The image is not zoomed.

 

CAPTURE_AREA_ZOOM_BY2X

[0x2000] the image is zoomed 2X.

 

CAPTURE_AREA_ZOOM_BY3X

[0x3000] the image is zoomed 3X.

 

CAPTURE_AREA_ZOOM_BY4X

[0x4000] the image is zoomed 4X.

 

CAPTURE_AREA_ZOOM_BY5X

[0x5000] the image is zoomed 5X.

 

CAPTURE_AREA_ZOOM_BY6X

[0x6000] the image is zoomed 6X.

 

CAPTURE_AREA_ZOOM_BY7X

[0x7000] the images is zoomed 7X.

 

CAPTURE_AREA_ZOOM_BY8X

[0x8000] the image is zoomed 8X.

 

CAPTURE_AREA_ZOOM_BY9X

[0x9000] the image is zoomed 9X.

 

CAPTURE_AREA_ZOOM_BY10X

[0xA000] the image is zoomed 10X.

 

CAPTURE_AREA_ZOOM_BY11X

[0xB000] the image is zoomed 11X.

 

CAPTURE_AREA_ZOOM_BY12X

[0xC000] the image is zoomed 12X.

 

CAPTURE_AREA_ZOOM_BY13X

[0xD000] the image is zoomed 13X.

 

CAPTURE_AREA_ZOOM_BY14X

[0xE000] the image is zoomed 14X.

 

CAPTURE_AREA_ZOOM_BY15X

[0xF000] the image is zoomed 15X.

 

CAPTURE_AREA_ZOOM_MASK

[0xF000] the image is zoomed by the mask.

hDrawCursor

Cursor for drawing area.

crTextForeColor

Foreground color of info text.

crTextBackColor

Background color of info text.

nInfoLeft

Left coordinate of the info window. Possible values are listed below. In addition, any other positive value specified by the user to define left position for the Info Window may be used.

 

CAPTURE_AREA_INFOWND_POS_LEFT

-1

 

CAPTURE_AREA_INFOWND_POS_RIGHT

-2

nInfoTop

Top coordinate of the info window. Possible values are listed below. In addition, any other positive value specified by the user to define the top position for the Info Window may be used.

 

CAPTURE_AREA_INFOWND_POS_TOP

-3

 

CAPTURE_AREA_INFOWND_POS_BOTTOM

-4

nInfoWidth

Width of the info window. Possible values are listed below. In addition, any other positive value specified by the user to define custom width and height for the info window may be used.

 

CAPTURE_AREA_INFOWND_SIZE_TINY

-1

 

CAPTURE_AREA_INFOWND_SIZE_SMALL

-2

 

CAPTURE_AREA_INFOWND_SIZE_MEDIUM

-3

 

CAPTURE_AREA_INFOWND_SIZE_LARGE

-4

 

CAPTURE_AREA_INFOWND_SIZE_XLARGE

-5

nInfoHeight

Height of the info window. Possible values are the same as for nInfoWidth. Both nInfoWidth and nInfoHeight must be positive values or values from the table in nInfoWidth.

Comments

The area of the bitmap outside the user-defined region will be filled with the pattern defined by nFillPattern, crFillForeColor, and crFillBackColor.

The zoom factor can be obtained from the flags as follows:

zoom_factor = ((uFlags & CAPTURE_AREA_ZOOM_MASK) >> 12)

The flag can be obtained from the zoom factor as follows

Flag = (zoom_factor)<< 12

 

nInfoWidth, nInfoTop, nInfoWidth and nInfoHeight are ignored if CAPTURE_AREA_SHOW_INFOWINDOW is not set.

CAPTURE_AREA_SHOW_INFOWINDOW and CAPTURE_AREA_SHOW_CAPTURESIZE are not mutually exclusive. If both flags are set, you will have both an info window and the size of the captured area. Likewise, if CAPTURE_AREA_SHOW_INFOWINDOW and CAPTURE_AREA_SHOW_CURSORPOS are set, you will have both an info window and the position of the cursor.

After the initial placement of the info window, the window will be moved to another corner of the screen whenever the mouse cursor becomes near the info window. This way, the user will not be disturbed during the selection of the area he wants, and he will be able to see a zoomed image for the current cursor position. The info window will look like this:

image\info.gif