Modifies the point pptMove based on the angle from line (pptAnchor
, pptMove
) and the horizontal.
#include "l_bitmap.h"
L_LTANN_API L_INT L_AnnAdjustPoint(pptAnchor, pptMove, dAngle, nType)
Pointer to an ANNPOINT structure representing the anchor point.
Pointer to an ANNPOINT structure representing the point to be adjusted
Angle of rotation in radians. Ranges from -Pi to Pi, (-3.1415 - 3.1415) where a positive angle corresponds to clockwise rotation.
Type of adjustment to point. Possible values are:
Type | Value |
---|---|
ANNADJUST_HORIZONTAL | [1] |
ANNADJUST_VERTICAL | [2] |
ANNADJUST_45_DEGREES_FAVOR_X | [3] |
ANNADJUST_45_DEGREES_FAVOR_Y | [4] |
Value | Meaning |
---|---|
SUCCESS | The function was successful. |
< 1 | An error occurred. Refer to Return Codes. |
This utility function is used when creating custom annotation objects. It can be used to calculate the horizontal, vertical, or 45 degree component of a rotated annotation object. It can also be used to easily restrict the mouse cursor on rotated annotation objects.
As an example, consider a rectangle that is rotated 35 degrees in the clockwise direction.
The user has clicked on the Anchor point, and moved the mouse to the Move point.
To find the horizontal component of the line that goes from (Anchor, Move), make the following call, and the ptMove point is adjusted to contain only the horizontal component.
The adjusted ptMove can be seen in step 4.
L_AnnAdjustPoint(&ptAnchor, &ptMove, 35 * PI / 180, ANNADJUST_HORIZONTAL)
Conceptually, the following occurs:
Initial situation.
Points and rectangle are rotated 35 degrees counter clockwise.
Move point is adjusted to contain only the horizontal component.
Points and rectangle are rotated 35 degrees clockwise to give adjusted Move point.
Win32, x64.
This is part of the custom annotations demo (from example1.c).
This handler gets called when there is a mouse move message on
a user handle.
There are four user handles that are processed differently.
The HANDLE_ID_VERTICAL_LEFT and HANDLE_ID_VERTICAL_RIGHT handles
restrict the mouse cursor to a line parallel to the top of the
rectangle, even if the rectangle is rotated.
The HANDLE_ID_HORIZONTAL_BOTTOM handle restricts the mouse cursor
to a line parallel to the side of the rectangle, even if the rectangle
is rotated.
The HANDLE_ID_HORIZONTAL_TOP handle rotates the rectangle around the
bottom handle (HANDLE_ID_HORIZONTAL_BOTTOM).
// Handle IDs
#define HANDLE_ID_HORIZONTAL_TOP 100
#define HANDLE_ID_HORIZONTAL_BOTTOM 101
#define HANDLE_ID_VERTICAL_LEFT 102
#define HANDLE_ID_VERTICAL_RIGHT 103
#define ALMOST_ZERO 0.9 /* small float value suitable for comparing coordinates */
#define DIFFERENT(val1,val2,epsilon) (((val1) < (val2)-(epsilon))||((val1) > (val2)+(epsilon)))
typedef struct _ANNCHILDDATA
{
HANNOBJECT hObjectChange;
L_POINT pt0;
L_POINT pt;
L_INT nUserHandleID;
HANNOBJECT AnnObjectNeighbors[2];
} ANNCHILDDATA, * LPANNCHILDDATA;
static L_INT ROUND(L_DOUBLE a)
{
return (L_INT)((a < 0) ? a - 0.5 : a + 0.5);
}
static L_INT ISDIFFERENT(pANNPOINT pptAnn, LPPOINT ppt)
{
return DIFFERENT(pptAnn->x, ppt->x, ALMOST_ZERO) || DIFFERENT(pptAnn->y, ppt->y, ALMOST_ZERO);
}
extern "C" L_INT AnnAdjustPointExample(LPANNCHILDDATA pData, pANNMOUSEPOS pMousePos)
{
L_INT nRet;
L_DOUBLE dAngle;
ANNPOINT ptAnchor, ptMove;
nRet = L_AnnGetRotateAngle(pData->hObjectChange, &dAngle);
if (nRet != SUCCESS)
return nRet;
ptAnchor.x = pData->pt0.x;
ptAnchor.y = pData->pt0.y;
ptMove.x = pMousePos->pt.x;
ptMove.y = pMousePos->pt.y;
switch (pData->nUserHandleID)
{
case HANDLE_ID_VERTICAL_LEFT:
case HANDLE_ID_VERTICAL_RIGHT:
{
L_DOUBLE dx, dy;
L_POINT pt;
nRet = L_AnnAdjustPoint(&ptAnchor, &ptMove, dAngle, ANNADJUST_HORIZONTAL);
if (nRet != SUCCESS)
return nRet;
dx = (ptMove.x - ptAnchor.x) / 2;
dy = (ptMove.y - ptAnchor.y) / 2;
pt = pMousePos->pt;
pt.x = (LONG)(ptAnchor.x + dx);
pt.y = (LONG)(ptAnchor.y + dy);
nRet = L_AnnDefine(pData->hObjectChange, &pMousePos->pt, ANNDEFINE_APPEND);
if (nRet != SUCCESS)
return nRet;
nRet = L_AnnDefine(pData->AnnObjectNeighbors[1], &pt, ANNDEFINE_APPEND);
if (nRet != SUCCESS)
return nRet;
}
break;
case HANDLE_ID_HORIZONTAL_BOTTOM:
nRet = L_AnnAdjustPoint(&ptAnchor, &ptMove, dAngle, ANNADJUST_VERTICAL);
if (nRet != SUCCESS)
return nRet;
nRet = L_AnnDefine(pData->hObjectChange, &pMousePos->pt, ANNDEFINE_APPEND);
if (nRet != SUCCESS)
return nRet;
nRet = L_AnnDefine(pData->AnnObjectNeighbors[1], &pMousePos->pt, ANNDEFINE_APPEND);
if (nRet != SUCCESS)
return nRet;
break;
case HANDLE_ID_HORIZONTAL_TOP:
nRet = L_AnnDefine(pData->hObjectChange, &pMousePos->pt, ANNDEFINE_APPEND);
if (nRet != SUCCESS)
return nRet;
nRet = L_AnnDefine(pData->AnnObjectNeighbors[1], &pMousePos->pt, ANNDEFINE_APPEND);
if (nRet != SUCCESS)
return nRet;
break;
}
pMousePos->fUpdatePos = L_FALSE;
if ((pData->nUserHandleID == HANDLE_ID_VERTICAL_LEFT) ||
(pData->nUserHandleID == HANDLE_ID_VERTICAL_RIGHT) ||
(pData->nUserHandleID == HANDLE_ID_HORIZONTAL_TOP) ||
(pData->nUserHandleID == HANDLE_ID_HORIZONTAL_BOTTOM))
{
if (ISDIFFERENT(&ptMove, &pMousePos->pt))
{
pMousePos->pt.x = ROUND(ptMove.x);
pMousePos->pt.y = ROUND(ptMove.y);
pMousePos->fUpdatePos = L_TRUE;
}
}
return SUCCESS;
}
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document