Available in LEADTOOLS Medical Imaging toolkits. |
L_DispContainerSaveRegion
#include "l_bitmap.h"
L_LTIVW_API L_INT EXT_FUNCTION L_DispContainerSaveRegion(hCon, pFileName, nCellIndex, nSubCellIndex, nStartPage, uFlags)
HDISPCONTAINER hCon; |
/* handle to the container */ |
LPTSTR pFileName; |
/* output file name */ |
L_INT nCellIndex; |
/* index of the cell */ |
L_INT nSubCellIndex; |
/* index into the image list attached to the cell */ |
L_INT nStartPage; |
/* the page number of a multi-page file */ |
L_UINT uFlags; |
/* flag */ |
Saves the region of the specified cell or sub-cell image to a file.
Parameter |
Description |
|
hCon |
Handle to the Container. |
|
pFileName |
Character string that contains the name of the file to save. |
|
nCellIndex |
A zero-based index of the cell for which to save the region. Pass -2 to save the region of the selected cell. |
|
nSubCellIndex |
A zero-based index into the image list attached to the cell specified in nCellIndex. This sub-cell contains the image region that will be saved. Pass -2 to refer to the selected sub-cell. If the cell contains 1 frame then the nSubCellIndex should be 0. |
|
nStartPage |
The page number of a multi-page file, which can contain more than one image. |
|
uFlags |
Flag that is used to determine the way of saving the region. Possible values are: |
|
|
Value |
Meaning |
|
CONTAINER_FILE_CREATE |
[0x00000000] Create a file. |
|
CONTAINER_FILE_APPEND |
[0x00000001] Append an existing file. |
|
CONTAINER_FILE_REPLACE |
[0x00000002] Replace the region in the index nStartPage in the existing file with the new region. |
|
CONTAINER_FILE_INSERT |
[0x00000003] Insert the region in the index nStartPage in the existing file. |
Returns
SUCCESS |
The function was successful. |
< 1 |
An error occurred. Refer to Return Codes. |
Comments
This function saves the region into an encrypted file. To load the saved region file use L_DispContainerLoadRegion.
Required DLLs and Libraries
LTIVW |
See Also
Functions: |
L_DispContainerLoadRegion, L_DispContainerAnnToRgn, L_DispContainerSetRegionCallBack, L_DispContainerGetRegionCallBack, DISPCONTAINERREGIONCALLBACK |
Topics: |
|
|
|
|
Example
This example will create a bitmap region on the first frame of the first image, save it, and then apply it to the rest of the frames.
L_INT DispContainerSaveBitmapRegionExample(HDISPCONTAINER hCon) { L_INT nRet; BITMAPHANDLE Bitmap; RECT rcRect; L_INT nI; L_INT nCount; HBITMAPLIST hBitmapList; nRet = L_DispContainerGetBitmapHandle(hCon, 0, 0, &Bitmap, 0); if (nRet != SUCCESS) return nRet; nRet = L_DispContainerGetCellBitmapList(hCon, 0, &hBitmapList, 0); if (nRet != SUCCESS) return nRet; L_GetBitmapListCount(hBitmapList, (L_UINT *)&nCount); L_INT nBitmapCenterX = BITMAPWIDTH(&Bitmap) >> 1; L_INT nBitmapCenterY = BITMAPHEIGHT(&Bitmap) >> 1; SetRect(&rcRect, nBitmapCenterX - (nBitmapCenterX >> 1), nBitmapCenterY - (nBitmapCenterY >> 1), nBitmapCenterX + (nBitmapCenterX >> 1), nBitmapCenterY + (nBitmapCenterY >> 1)); L_SetBitmapRgnRect(&Bitmap, NULL, &rcRect, L_RGN_OR); L_DispContainerSetBitmapHandle(hCon, 0, 0, &Bitmap, TRUE, 0); L_DispContainerSaveRegion(hCon, TEXT("C:\\Region.rgn"), 0, 0, 0, 0); for (nI = 0; nI < nCount; nI++) L_DispContainerLoadRegion(hCon, TEXT("C:\\Region.rgn"), 0, nI, 0, 0); return SUCCESS; }