MIL_TEXT_PTR MemPtrOrFileName, | //in-out |
MIL_ID SysId, | //in |
MIL_INT64 Operation, | //in |
MIL_INT64 StreamType, | //in |
MIL_DOUBLE Version, | //in |
MIL_INT64 ControlFlag, | //in |
MIL_ID *ContextOrResultEdgeIdPtr, | //in-out |
MIL_INT *SizeByteVarPtr | //out |
This function can load, restore, or save an Edge Finder context from/to a file or memory stream. Moreover, this function can save previously calculated edges (edge chains and/or edge approximations), stored in an Edge Finder result buffer, to a file or memory stream in a standard CAD DXF format. Edge chains and edge approximations are saved in the DXF file or memory stream in separate layers.
Note that you cannot load or restore any CAD DXF file or memory stream using this function.
To inquire the number of bytes necessary to save an Edge Finder context or calculated edges to memory stream, you should first call this function (MedgeStream()) with M_INQUIRE_SIZE_BYTE.
The content saved to memory stream is equivalent to the content saved to file. This function is equivalent to a file saved using MedgeSave().
You can use this and other MIL stream functions, for example, to save all required MIL objects, as well as any other custom data, for your application to a memory stream. Once in a memory stream, you can write the stream to a single file or transfer it over a network. You are responsible for concatenating the streams and for saving the stream to file.
Using MedgeStream(), you can choose to save a backwards-compatible version of the Edge Finder context, which will work using a version of MIL that is up to one major release older than the current version (depending on which version is specified). For example, if you allocate an Edge Finder context using MIL 10.0 and save it to version 9.0, you can restore this context on a computer where MIL 9.0 is installed. However, all settings and features unique to the higher version will be ignored when restored using the lower version. Besides saving backwards-compatible versions, you can also load or restore Edge Finder contexts saved using MIL version 7.5 or above. Settings that do not exist in the lower version will be filled with default values when the Edge Finder context is loaded or restored.
Specifies the file or memory stream.
See the Parameter associations section for possible values that can be returned/specified.
Specifies the system on which to restore the Edge Finder context.
See the Parameter associations section for possible values that can be specified.
Specifies the operation to perform.
See the Parameter associations section for possible values that can be specified.
Specifies the type of stream in which to store/from which to restore the Edge Finder context or calculated edges. This parameter must be set to one of the following values:
Specifies the MIL version of the Edge Finder context. When performing an M_LOAD or M_RESTORE operation, this parameter must be set to M_DEFAULT.
See the Parameter associations section for possible values that can be specified.
Specifies the function's control flag.
See the Parameter associations section for possible values that can be specified.
Specifies the address of the variable in which to write or from which to read the identifier of the Edge Finder context or the Edge Finder result buffer.
See the Parameter associations section for possible values that can be returned/specified.
The table below lists possible values for the MemPtrOrFileName, SysId, Operation, Version, ControlFlag, and ContextOrResultEdgeIdPtr parameters.
For performing the stream operation.
|
|||||||||||||||||||||||||||||||||||||||
|
Description | ||||||||||||||||||||||||||||||||||||||
MemPtrOrFileName - Possible values passed or returned |
|||||||||||||||||||||||||||||||||||||||
SysId | |||||||||||||||||||||||||||||||||||||||
Version | |||||||||||||||||||||||||||||||||||||||
ControlFlag | |||||||||||||||||||||||||||||||||||||||
ContextOrResultEdgeIdPtr - Possible values passed or returned |
|||||||||||||||||||||||||||||||||||||||
M_INQUIRE_SIZE_BYTE |
Inquires the number of bytes required to save an Edge Finder context or result buffer to memory stream. This operation is not supported when the StreamType parameter is set to M_FILE. (summarize)Inquires the number of bytes required to save an Edge Finder context or result buffer to memory stream. (more details...) |
||||||||||||||||||||||||||||||||||||||
MemPtrOrFileName |
This parameter must be set to M_NULL. (summarize)This parameter must be set to M_NULL. (more details...) |
||||||||||||||||||||||||||||||||||||||
SysId |
This parameter must be set to M_NULL. (summarize)This parameter must be set to M_NULL. (more details...) |
||||||||||||||||||||||||||||||||||||||
Version |
Specifies the MIL version with which the Edge Finder context or result buffer must be compatible when saved. The size of an Edge Finder context or result buffer might differ from one MIL version to another. (summarize)Specifies the MIL version with which the Edge Finder context or result buffer must be compatible when saved. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_DEFAULT |
Specifies the current version of MIL. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_90 |
Specifies the version as being MIL 9.0. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_90_PP1 |
Specifies the version as being MIL 9.0 Processing Pack 1. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_90_PP2 |
Specifies the version as being MIL 9.0 Processing Pack 2. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100 |
Specifies the version as being MIL 10.0. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100_PP1 |
Specifies the version as being MIL 10.0 Processing Pack 1. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100_PP2 |
Specifies the version as being MIL 10.0 Processing Pack 2. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100_PP3 |
Specifies the version as being MIL 10.0 Processing Pack 3. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100_SP4 |
Specifies the version as being MIL 10.0 Service Pack 4. |
||||||||||||||||||||||||||||||||||||||
ControlFlag |
This parameter must be set to M_DEFAULT. (summarize)This parameter must be set to M_DEFAULT. (more details...) |
||||||||||||||||||||||||||||||||||||||
ContextOrResultEdgeIdPtr |
Specifies the address of the variable containing the identifier of the Edge Finder context or result buffer. (summarize)Specifies the address of the variable containing the identifier of the Edge Finder context or result buffer. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_LOAD |
Loads the content of a specified file or memory stream into a previously allocated Edge Finder context. (summarize)Loads the content of a specified file or memory stream into a previously allocated Edge Finder context. (more details...) |
||||||||||||||||||||||||||||||||||||||
MemPtrOrFileName |
Specifies the file or memory stream from which to load the context. (summarize)Specifies the file or memory stream from which to load the context. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_INTERACTIVE |
[This is
only applicable to Windows]
Opens a dialog box from which you can interactively specify the drive, directory, and name of the file, when the StreamType parameter is set to M_FILE. |
||||||||||||||||||||||||||||||||||||||
MIL_TEXT("FileName") 1 |
Specifies the drive, directory, and name of the file (for example, "C:\mydirectory\myfile"), when the StreamType parameter is set to M_FILE. Edge Finder contexts typically have an MEF file extension. The function handles (internally) the opening and closing of the file. To specify a file on a remote computer (under Distributed MIL), prefix the specified file name string with "remote:///" (for example, "remote:///C:\mydirectory\myfile"). (summarize)Specifies the drive, directory, and name of the file (for example, "C:\mydirectory\myfile"), when the StreamType parameter is set to M_FILE. (more details...) |
||||||||||||||||||||||||||||||||||||||
MemPtr |
Specifies the address of the block of memory, when the StreamType parameter is set to M_MEMORY. The block of memory should be of type MIL_UINT8. The specified address must correspond to the first memory address in which the object is located, and the block of memory must contain the entire object. Note that when using a C compiler (not a C++ or other compiler), you must cast the MIL_UINT8 pointer to a MIL_TEXT_PTR. (summarize)Specifies the address of the block of memory, when the StreamType parameter is set to M_MEMORY. (more details...) |
||||||||||||||||||||||||||||||||||||||
SysId |
This parameter must be set to M_NULL. (summarize)This parameter must be set to M_NULL. (more details...) |
||||||||||||||||||||||||||||||||||||||
Version |
This parameter must be set to M_DEFAULT. (summarize)This parameter must be set to M_DEFAULT. (more details...) |
||||||||||||||||||||||||||||||||||||||
ControlFlag |
This parameter must be set to M_DEFAULT. (summarize)This parameter must be set to M_DEFAULT. (more details...) |
||||||||||||||||||||||||||||||||||||||
ContextOrResultEdgeIdPtr |
Specifies the address of the variable containing the identifier of the Edge Finder context. All previous settings are overwritten with those of the loaded context, or are set to the default value if the settings didn't exist in the version of MIL from which the context is being loaded. (summarize)Specifies the address of the variable containing the identifier of the Edge Finder context. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_RESTORE |
Restores an Edge Finder context from a file or memory stream and assigns it a MIL identifier. (summarize)Restores an Edge Finder context from a file or memory stream and assigns it a MIL identifier. (more details...) |
||||||||||||||||||||||||||||||||||||||
MemPtrOrFileName |
Specifies the file or memory stream from which to restore the context. (summarize)Specifies the file or memory stream from which to restore the context. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_INTERACTIVE |
[This is
only applicable to Windows]
Opens a dialog box from which you can interactively specify the drive, directory, and name of the file, when the StreamType parameter is set to M_FILE. |
||||||||||||||||||||||||||||||||||||||
MIL_TEXT("FileName") 1 |
Specifies the drive, directory, and name of the file (for example, "C:\mydirectory\myfile"), when the StreamType parameter is set to M_FILE. Edge Finder contexts typically have an MEF file extension. The function handles (internally) the opening and closing of the file. To specify a file on a remote computer (under Distributed MIL), prefix the specified file name string with "remote:///" (for example, "remote:///C:\mydirectory\myfile"). (summarize)Specifies the drive, directory, and name of the file (for example, "C:\mydirectory\myfile"), when the StreamType parameter is set to M_FILE. (more details...) |
||||||||||||||||||||||||||||||||||||||
MemPtr |
Specifies the address of the block of memory, when the StreamType parameter is set to M_MEMORY. The block of memory should be of type MIL_UINT8. The specified address must correspond to the first memory address in which the object is located, and the block of memory must contain the entire object. Note that when using a C compiler (not a C++ or other compiler), you must cast the MIL_UINT8 pointer to a MIL_TEXT_PTR. (summarize)Specifies the address of the block of memory, when the StreamType parameter is set to M_MEMORY. (more details...) |
||||||||||||||||||||||||||||||||||||||
SysId |
Specifies the system on which to allocate the Edge Finder context. (summarize)Specifies the system on which to allocate the Edge Finder context. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_DEFAULT_HOST |
Specifies the default Host system of the current MIL application. |
||||||||||||||||||||||||||||||||||||||
MIL system identifier |
Specifies a valid system identifier, previously allocated using MsysAlloc(). |
||||||||||||||||||||||||||||||||||||||
Version |
This parameter must be set to M_DEFAULT. (summarize)This parameter must be set to M_DEFAULT. (more details...) |
||||||||||||||||||||||||||||||||||||||
ControlFlag |
This parameter must be set to M_DEFAULT. (summarize)This parameter must be set to M_DEFAULT. (more details...) |
||||||||||||||||||||||||||||||||||||||
ContextOrResultEdgeIdPtr |
Specifies the address of the variable in which to write the identifier of the Edge Finder context. If the operation is not successful, M_NULL is returned. (summarize)Specifies the address of the variable in which to write the identifier of the Edge Finder context. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_SAVE |
Saves an Edge Finder context or result buffer to a specified file or memory stream; alternatively, if a result buffer is passed, this operation saves the calculated edges stored in the result buffer to the specified file or memory stream in a standard CAD DXF format. (summarize)Saves an Edge Finder context or result buffer to a specified file or memory stream; alternatively, if a result buffer is passed, this operation saves the calculated edges stored in the result buffer to the specified file or memory stream in a standard CAD DXF format. (more details...) |
||||||||||||||||||||||||||||||||||||||
MemPtrOrFileName |
Specifies the file or memory stream. (summarize)Specifies the file or memory stream. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_INTERACTIVE |
[This is
only applicable to Windows]
Opens a dialog box from which you can interactively specify the drive, directory, and name of the file, when the StreamType parameter is set to M_FILE. |
||||||||||||||||||||||||||||||||||||||
MIL_TEXT("FileName") 1 |
Specifies the drive, directory, and name of the file (for example, "C:\mydirectory\myfile"), when the StreamType parameter is set to M_FILE. For easier use with other Matrox Imaging software products, when saving an Edge Finder context to a file, use the MEF file extension, and when saving calculated edges from an Edge Finder result buffer to a CAD file, use the DXF file extension. The function handles (internally) the opening and closing of the file. If the file already exists, it will be overwritten. To specify a file on a remote computer (under Distributed MIL), prefix the specified file name string with "remote:///" (for example, "remote:///C:\mydirectory\myfile"). (summarize)Specifies the drive, directory, and name of the file (for example, "C:\mydirectory\myfile"), when the StreamType parameter is set to M_FILE. (more details...) |
||||||||||||||||||||||||||||||||||||||
MemPtr |
Specifies the address of the block of memory, when the StreamType parameter is set to M_MEMORY. The block of memory should be of type MIL_UINT8. The specified address must correspond to the first memory address in which to write, and the block of memory must be large enough to stream the entire object. To determine the required size, call this function with M_INQUIRE_SIZE_BYTE. Note that when using a C compiler (not a C++ or other compiler), you must cast the MIL_UINT8 pointer to a MIL_TEXT_PTR. (summarize)Specifies the address of the block of memory, when the StreamType parameter is set to M_MEMORY. (more details...) |
||||||||||||||||||||||||||||||||||||||
SysId |
This parameter must be set to M_NULL. (summarize)This parameter must be set to M_NULL. (more details...) |
||||||||||||||||||||||||||||||||||||||
Version |
Specifies the MIL version with which the Edge Finder context or result buffer must be compatible when saved. Note that the Edge Finder context or result buffer can only be up to one major release older (MIL 9.0) than the current version. (summarize)Specifies the MIL version with which the Edge Finder context or result buffer must be compatible when saved. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_DEFAULT |
Specifies the current version of MIL. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_90 |
Specifies the version as being MIL 9.0. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_90_PP1 |
Specifies the version as being MIL 9.0 Processing Pack 1. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_90_PP2 |
Specifies the version as being MIL 9.0 Processing Pack 2. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100 |
Specifies the version as being MIL 10.0. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100_PP1 |
Specifies the version as being MIL 10.0 Processing Pack 1. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100_PP2 |
Specifies the version as being MIL 10.0 Processing Pack 2. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100_PP3 |
Specifies the version as being MIL 10.0 Processing Pack 3. |
||||||||||||||||||||||||||||||||||||||
M_PROC_VERSION_100_SP4 |
Specifies the version as being MIL 10.0 Service Pack 4. |
||||||||||||||||||||||||||||||||||||||
ControlFlag |
For any operation on Edge Finder contexts, this parameter must be set to M_DEFAULT. For calculated edges from an Edge Finder result buffer, this parameter stipulates whether to save edge chains and/or edge approximations to the CAD DXF file or memory stream. In this case, this parameter must be set to one or a combination (M_CHAIN + M_CHAIN_APPROXIMATION) of the following values. (summarize)For any operation on Edge Finder contexts, this parameter must be set to M_DEFAULT. (more details...) |
||||||||||||||||||||||||||||||||||||||
M_DEFAULT |
Specifies the default value. |
||||||||||||||||||||||||||||||||||||||
M_CHAIN |
Specifies that edge chains will be saved. |
||||||||||||||||||||||||||||||||||||||
M_CHAIN_APPROXIMATION |
Specifies that edge approximations will be saved. |
||||||||||||||||||||||||||||||||||||||
ContextOrResultEdgeIdPtr |
Specifies the address of the variable containing the identifier of the Edge Finder context or result buffer to save. (summarize)Specifies the address of the variable containing the identifier of the Edge Finder context or result buffer to save. (more details...) |
1 If you are passing the value in a variable, don't enclose it in MIL_TEXT().
Header | Include mil.h. |
Library | Use mil.lib; miledge.lib. |
DLL | Requires mil.dll; miledge.dll. |