#include <mil.h>
void PrintHeader()
{
MosPrintf(MIL_TEXT("[EXAMPLE NAME]\n"));
MosPrintf(MIL_TEXT("FixturedCodeRead\n\n"));
MosPrintf(MIL_TEXT("[SYNOPSIS]\n"));
MosPrintf(MIL_TEXT("This example will establish a fixtured code reading operation in a setup image,\n"));
MosPrintf(MIL_TEXT("by:\n"));
MosPrintf(MIL_TEXT("- Defining a model in the setup image.\n"));
MosPrintf(MIL_TEXT("- Learning the offset of this model from the origin of the setup image.\n"));
MosPrintf(MIL_TEXT("- Preparing a region around the code.\n\n"));
MosPrintf(MIL_TEXT("Then, for each image in a set of images, this example will perform a fixtured\n"));
MosPrintf(MIL_TEXT("code read operation, by:\n"));
MosPrintf(MIL_TEXT("- Searching for model in the image.\n"));
MosPrintf(MIL_TEXT("- Moving the relative coordinate system according to the found model\n"));
MosPrintf(MIL_TEXT(" location and the learned offset.\n"));
MosPrintf(MIL_TEXT("- Setting the region in the image,\n"));
MosPrintf(MIL_TEXT("- Reading the code in the region of the image.\n\n"));
MosPrintf(MIL_TEXT("[MODULES USED]\n"));
MosPrintf(MIL_TEXT("Modules used: application, system, display, buffer, graphic, code and\n"));
MosPrintf(MIL_TEXT("pattern matching.\n\n"));
MosPrintf(MIL_TEXT("Press <Enter> to continue.\n\n"));
MosGetch();
}
static MIL_CONST_TEXT_PTR IMAGE_FILE = M_IMAGE_PATH MIL_TEXT("FixturedCodeRead/BoardSetup.mim");
static const MIL_INT NUMBER_OF_IMAGES = 5L;
static MIL_CONST_TEXT_PTR ImageFileName[NUMBER_OF_IMAGES] =
{
M_IMAGE_PATH MIL_TEXT("FixturedCodeRead/Board1.mim"),
M_IMAGE_PATH MIL_TEXT("FixturedCodeRead/Board2.mim"),
M_IMAGE_PATH MIL_TEXT("FixturedCodeRead/Board3.mim"),
M_IMAGE_PATH MIL_TEXT("FixturedCodeRead/Board4.mim"),
M_IMAGE_PATH MIL_TEXT("FixturedCodeRead/Board5.mim"),
};
static const MIL_INT CODE_TYPE = M_CODE39;
static const MIL_INT MODEL_OFFSET_X = 196;
static const MIL_INT MODEL_OFFSET_Y = 226;
static const MIL_INT MODEL_SIZE_X = 93;
static const MIL_INT MODEL_SIZE_Y = 91;
static const MIL_INT REGION_OFFSET_X = 70;
static const MIL_INT REGION_OFFSET_Y = 317;
static const MIL_INT REGION_SIZE_X = 430;
static const MIL_INT REGION_SIZE_Y = 100;
class CFixturedCodeRead
{
public:
CFixturedCodeRead();
~CFixturedCodeRead();
void Setup(MIL_ID MilSystem, MIL_ID MilDisplay, MIL_ID MilOverlayImage, MIL_ID MilSrcImage);
void Run(MIL_ID MilSystem, MIL_ID MilDisplay, MIL_ID MilOverlayImage, MIL_ID MilSrcImage);
void Free();
protected:
MIL_ID m_MilModelContext;
MIL_ID m_MilFixturingOffset;
MIL_ID m_MilRegionGraphicList;
MIL_ID m_MilCodeContext;
MIL_ID m_MilCodeResult;
void Reset();
void ReadCodeWithRegion(MIL_ID MilSrcImage, MIL_ID MilOverlayImage);
};
int MosMain(void)
{
MIL_ID MilApplication,
MilSystem,
MilDisplay;
MappAlloc(M_NULL, M_DEFAULT, &MilApplication);
MsysAlloc(M_DEFAULT, M_SYSTEM_HOST, M_DEFAULT, M_DEFAULT, &MilSystem);
MdispAlloc(MilSystem, M_DEFAULT, MIL_TEXT("M_DEFAULT"), M_WINDOWED, &MilDisplay);
PrintHeader();
MIL_ID MilSrcImage;
MbufRestore(IMAGE_FILE, MilSystem, &MilSrcImage);
McalUniform(MilSrcImage, 0.0, 0.0, 1.0, 1.0, 0.0, M_DEFAULT);
MdispSelect(MilDisplay, MilSrcImage);
MIL_ID MilOverlayImage;
MdispControl(MilDisplay, M_OVERLAY, M_ENABLE);
MdispInquire(MilDisplay, M_OVERLAY_ID, &MilOverlayImage);
MdispControl(MilDisplay, M_OVERLAY_CLEAR, M_DEFAULT);
MdispControl(MilDisplay, M_REGION_OUTSIDE_SHOW, M_OPAQUE);
CFixturedCodeRead Fixture;
Fixture.Setup(MilSystem, MilDisplay, MilOverlayImage, MilSrcImage);
MosPrintf(MIL_TEXT("Press <Enter> to continue.\n\n"));
MosGetch();
for(MIL_INT ii = 0; ii < NUMBER_OF_IMAGES; ii++)
{
MbufLoad(ImageFileName[ii], MilSrcImage);
Fixture.Run(MilSystem, MilDisplay, MilOverlayImage, MilSrcImage);
}
Fixture.Free();
MbufFree(MilSrcImage);
MdispFree(MilDisplay);
MsysFree(MilSystem);
MappFree(MilApplication);
return 0;
}
CFixturedCodeRead::CFixturedCodeRead()
{
Reset();
}
CFixturedCodeRead::~CFixturedCodeRead()
{
Free();
}
void CFixturedCodeRead::Reset()
{
m_MilModelContext = M_NULL;
m_MilFixturingOffset = M_NULL;
m_MilRegionGraphicList = M_NULL;
m_MilCodeContext = M_NULL;
m_MilCodeResult = M_NULL;
}
void CFixturedCodeRead::Free()
{
if(m_MilModelContext != M_NULL) MpatFree(m_MilModelContext);
if(m_MilFixturingOffset != M_NULL) McalFree(m_MilFixturingOffset);
if(m_MilRegionGraphicList != M_NULL) MgraFree(m_MilRegionGraphicList);
if(m_MilCodeContext != M_NULL) McodeFree(m_MilCodeContext);
if(m_MilCodeResult != M_NULL) McodeFree(m_MilCodeResult);
Reset();
}
void CFixturedCodeRead::Setup(MIL_ID MilSystem, MIL_ID MilDisplay, MIL_ID MilOverlayImage, MIL_ID MilSrcImage)
{
MpatAlloc(MilSystem, M_NORMALIZED, M_DEFAULT, &m_MilModelContext);
MpatDefine(m_MilModelContext, M_REGULAR_MODEL, MilSrcImage,
MODEL_OFFSET_X, MODEL_OFFSET_Y,
MODEL_SIZE_X, MODEL_SIZE_Y, M_DEFAULT);
MpatControl(m_MilModelContext, 0, M_SEARCH_ANGLE_MODE, M_ENABLE);
MpatControl(m_MilModelContext, 0, M_SEARCH_ANGLE_DELTA_NEG, 180.0);
MpatControl(m_MilModelContext, 0, M_SEARCH_ANGLE_DELTA_POS, 180.0);
MpatControl(m_MilModelContext, 0, M_SEARCH_ANGLE_ACCURACY, 0.5);
MpatPreprocess(m_MilModelContext, M_DEFAULT, M_NULL);
MdispControl(MilDisplay, M_OVERLAY_CLEAR, M_DEFAULT);
MgraColor(M_DEFAULT, M_COLOR_RED);
MgraControl(M_DEFAULT, M_INPUT_UNITS, M_PIXEL);
MpatDraw(M_DEFAULT, m_MilModelContext, MilOverlayImage, M_DRAW_BOX+M_DRAW_POSITION, M_DEFAULT, M_ORIGINAL);
MosPrintf(MIL_TEXT("A model is defined in the source image.\n\n"));
MosPrintf(MIL_TEXT("Press <Enter> to continue.\n\n"));
MosGetch();
McalAlloc(MilSystem, M_FIXTURING_OFFSET, M_DEFAULT, &m_MilFixturingOffset);
McalFixture(M_NULL, m_MilFixturingOffset, M_LEARN_OFFSET, M_MODEL_PAT, m_MilModelContext, MilSrcImage, 0, M_DEFAULT, M_DEFAULT);
MgraColor(M_DEFAULT, M_COLOR_LIGHT_BLUE);
MgraBackColor(M_DEFAULT, M_COLOR_GRAY);
McalDraw(M_DEFAULT, M_NULL, MilOverlayImage,
M_DRAW_RELATIVE_COORDINATE_SYSTEM, M_DEFAULT, M_DEFAULT);
MgraColor(M_DEFAULT, M_COLOR_GREEN);
McalDraw(M_DEFAULT, m_MilFixturingOffset, MilOverlayImage,
M_DRAW_FIXTURING_OFFSET, M_DEFAULT, M_DEFAULT);
MosPrintf(MIL_TEXT("The offset, from the origin of the template image to the model, is learned.\n\n"));
MosPrintf(MIL_TEXT("Press <Enter> to continue.\n\n"));
MosGetch();
MgraAllocList(MilSystem, M_DEFAULT, &m_MilRegionGraphicList);
MgraControl(M_DEFAULT, M_INPUT_UNITS, M_WORLD);
MgraRectAngle(M_DEFAULT, m_MilRegionGraphicList,
REGION_OFFSET_X, REGION_OFFSET_Y,
REGION_SIZE_X, REGION_SIZE_Y,
0.0, M_CORNER_AND_DIMENSION+M_FILLED);
McodeAlloc(MilSystem, M_DEFAULT, M_DEFAULT, &m_MilCodeContext);
McodeModel(m_MilCodeContext, M_ADD, CODE_TYPE, M_NULL, M_DEFAULT, M_NULL);
McodeControl(m_MilCodeContext, M_SEARCH_ANGLE, M_ACCORDING_TO_REGION);
McodeControl(m_MilCodeContext, M_POSITION_ACCURACY, M_HIGH);
McodeAllocResult(MilSystem, M_DEFAULT, &m_MilCodeResult);
ReadCodeWithRegion(MilSrcImage, MilOverlayImage);
}
void CFixturedCodeRead::Run(MIL_ID MilSystem, MIL_ID MilDisplay, MIL_ID MilOverlayImage, MIL_ID MilSrcImage)
{
MdispControl(MilDisplay, M_OVERLAY_CLEAR, M_DEFAULT);
MbufSetRegion(MilSrcImage, M_NULL, M_DEFAULT, M_DELETE, M_DEFAULT);
MIL_ID MilPatResult;
MpatAllocResult(MilSystem, M_DEFAULT, &MilPatResult);
MpatFind(m_MilModelContext, MilSrcImage, MilPatResult);
MIL_INT NbFound;
MpatGetResult(MilPatResult, M_GENERAL, M_NUMBER+M_TYPE_MIL_INT, &NbFound);
if(NbFound != 1)
{
MosPrintf(MIL_TEXT("Unable to find the model in source image.\n\n"));
}
else
{
MgraControl(M_DEFAULT, M_INPUT_UNITS, M_PIXEL);
MgraColor(M_DEFAULT, M_COLOR_RED);
MpatDraw(M_DEFAULT, MilPatResult, MilOverlayImage, M_DRAW_BOX+M_DRAW_POSITION, 0, M_DEFAULT);
McalFixture(MilSrcImage, m_MilFixturingOffset, M_MOVE_RELATIVE, M_RESULT_PAT,
MilPatResult, 0,
M_DEFAULT, M_DEFAULT, M_DEFAULT);
MgraColor(M_DEFAULT, M_COLOR_LIGHT_BLUE);
MgraBackColor(M_DEFAULT, M_COLOR_GRAY);
McalDraw(M_DEFAULT, M_NULL, MilOverlayImage,
M_DRAW_RELATIVE_COORDINATE_SYSTEM, M_DEFAULT, M_DEFAULT);
MgraColor(M_DEFAULT, M_COLOR_GREEN);
McalDraw(M_DEFAULT, m_MilFixturingOffset, MilOverlayImage,
M_DRAW_FIXTURING_OFFSET, M_DEFAULT, M_DEFAULT);
MosPrintf(MIL_TEXT("The model is found in the source image.\n\n"));
MosPrintf(MIL_TEXT("Press <Enter> to continue.\n\n"));
MosGetch();
ReadCodeWithRegion(MilSrcImage, MilOverlayImage);
}
MosPrintf(MIL_TEXT("Press <Enter> to continue.\n\n"));
MosGetch();
MpatFree(MilPatResult);
}
void CFixturedCodeRead::ReadCodeWithRegion(MIL_ID MilSrcImage, MIL_ID MilOverlayImage)
{
MbufSetRegion(MilSrcImage, m_MilRegionGraphicList, M_DEFAULT, M_NO_RASTERIZE, M_DEFAULT);
MosPrintf(MIL_TEXT("A read region is set.\n\n"));
MosPrintf(MIL_TEXT("Press <Enter> to continue.\n\n"));
MosGetch();
McodeRead(m_MilCodeContext, MilSrcImage, m_MilCodeResult);
MIL_INT ReadStatus;
McodeGetResult(m_MilCodeResult, M_GENERAL, M_GENERAL, M_STATUS+M_TYPE_MIL_INT, &ReadStatus);
if (ReadStatus == M_STATUS_READ_OK)
{
MIL_INT ResultStringSize;
McodeGetResult(m_MilCodeResult, 0, M_GENERAL, M_STRING + M_STRING_SIZE+M_TYPE_MIL_INT, &ResultStringSize);
MIL_TEXT_CHAR* ResultString = new MIL_TEXT_CHAR[ResultStringSize];
McodeGetResult(m_MilCodeResult, 0, M_GENERAL, M_STRING, ResultString);
MIL_CONST_TEXT_PTR PrefixString = MIL_TEXT("Read code: ");
MIL_INT OutputStringSize = ResultStringSize + MosStrlen(PrefixString);
MIL_TEXT_CHAR* OutputString = new MIL_TEXT_CHAR[OutputStringSize];
MosSprintf(OutputString, OutputStringSize, MIL_TEXT("%s%s"), PrefixString, ResultString);
MgraColor(M_DEFAULT, M_COLOR_GREEN);
McodeDraw(M_DEFAULT, m_MilCodeResult, MilOverlayImage, M_DRAW_BOX, 0, M_GENERAL, M_DEFAULT);
double PositionX, PositionY;
McodeGetResult(m_MilCodeResult, 0, M_GENERAL, M_POSITION_X, &PositionX);
McodeGetResult(m_MilCodeResult, 0, M_GENERAL, M_POSITION_Y, &PositionY);
MgraControl(M_DEFAULT, M_INPUT_UNITS, M_WORLD);
MgraBackColor(M_DEFAULT, M_COLOR_GRAY);
MgraControl(M_DEFAULT, M_TEXT_ALIGN_HORIZONTAL, M_CENTER);
MgraControl(M_DEFAULT, M_TEXT_ALIGN_VERTICAL, M_CENTER);
MgraText(M_DEFAULT, MilOverlayImage, PositionX, PositionY, OutputString);
MosPrintf(MIL_TEXT("Reading in the region was successful and the string was written on the code.\n\n"));
}
else
{
MosPrintf(MIL_TEXT("Code read operation failed.\n\n"));
}
}