using System;
using System.Collections.Generic;
using System.Text;
using Matrox.MatroxImagingLibrary;
using System.Runtime.InteropServices;
namespace MGraInteractive
{
public class STestParameters
{
public MIL_ID MilDisplay;
public MIL_ID MilGraphicsList;
public MIL_ID MilGraphicsContext;
public MIL_ID MilBinImage;
public MIL_ID MilBlobContext;
public MIL_ID MilBlobResult;
public MIL_INT RegionLabel;
}
public class Program
{
static void Main(string[] args)
{
MIL_ID MilApplication = MIL.M_NULL;
MIL_ID MilSystem = MIL.M_NULL;
MIL_ID MilDisplay = MIL.M_NULL;
MIL.MappAllocDefault(MIL.M_DEFAULT, ref MilApplication, ref MilSystem, ref MilDisplay, MIL.M_NULL, MIL.M_NULL);
Console.WriteLine();
Console.WriteLine("INTERACTIVE REGIONS AND SUBPIXEL ANNOTATIONS:");
Console.WriteLine("---------------------------------------------");
Console.WriteLine();
Console.WriteLine("This program determines the number of blobs in a region");
Console.WriteLine("defined interactively by the user. The extracted blob's");
Console.WriteLine("features are drawn with subpixel accuracy in a zoomable");
Console.WriteLine("display.");
Console.WriteLine();
InteractivityExample(MilSystem, MilDisplay);
MIL.MappFreeDefault(MilApplication, MilSystem, MilDisplay, MIL.M_NULL, MIL.M_NULL);
}
private static readonly string IMAGE_FILE = MIL.M_IMAGE_PATH + "Seals.mim";
private const int IMAGE_THRESHOLD_VALUE = 110;
private const int RECTANGLE_POSITION_X = 160;
private const int RECTANGLE_POSITION_Y = 310;
private const int RECTANGLE_WIDTH = 200;
private const int RECTANGLE_HEIGHT = 175;
private const int RECTANGLE_ANGLE = 0;
private const int ASCII_ENTER = 13;
private static void InteractivityExample(MIL_ID MilSystem, MIL_ID MilDisplay)
{
MIL_ID MilImage = MIL.M_NULL;
MIL_ID MilGraphicsList = MIL.M_NULL;
MIL_ID MilGraphicsContext = MIL.M_NULL;
MIL_ID MilBinImage = MIL.M_NULL;
MIL_ID MilBlobContext = MIL.M_NULL;
MIL_ID MilBlobResult = MIL.M_NULL;
MIL_INT SizeX = 0;
MIL_INT SizeY = 0;
MIL_INT RegionLabel = 0;
STestParameters DataStructure = new STestParameters();
MIL.MbufRestore(IMAGE_FILE, MilSystem, ref MilImage);
MIL.MdispSelect(MilDisplay, MilImage);
MIL.MgraAllocList(MilSystem, MIL.M_DEFAULT, ref MilGraphicsList);
MIL.MdispControl(MilDisplay, MIL.M_ASSOCIATED_GRAPHIC_LIST_ID, MilGraphicsList);
MIL.MgraAlloc(MilSystem, ref MilGraphicsContext);
MIL.MdispControl(MilDisplay, MIL.M_GRAPHIC_LIST_INTERACTIVE, MIL.M_ENABLE);
MIL.MgraControlList(MilGraphicsList, MIL.M_LIST, MIL.M_DEFAULT, MIL.M_ACTION_KEYS, MIL.M_ENABLE);
MIL.MgraRectAngle(MilGraphicsContext, MilGraphicsList, RECTANGLE_POSITION_X, RECTANGLE_POSITION_Y, RECTANGLE_WIDTH, RECTANGLE_HEIGHT, RECTANGLE_ANGLE, MIL.M_CENTER_AND_DIMENSION);
MIL.MgraInquireList(MilGraphicsList, MIL.M_LIST, MIL.M_DEFAULT, MIL.M_LAST_LABEL, ref RegionLabel);
MIL.MgraControl(MilGraphicsContext, MIL.M_SELECTABLE, MIL.M_DISABLE);
MIL.MbufInquire(MilImage, MIL.M_SIZE_X, ref SizeX);
MIL.MbufInquire(MilImage, MIL.M_SIZE_Y, ref SizeY);
MIL.MbufAlloc2d(MilSystem, SizeX, SizeY, 1 + MIL.M_UNSIGNED, MIL.M_IMAGE + MIL.M_PROC, ref MilBinImage);
MIL.MimBinarize(MilImage, MilBinImage, MIL.M_FIXED + MIL.M_LESS, IMAGE_THRESHOLD_VALUE, MIL.M_NULL);
MIL.MblobAlloc(MilSystem, MIL.M_DEFAULT, MIL.M_DEFAULT, ref MilBlobContext);
MIL.MblobAllocResult(MilSystem, MIL.M_DEFAULT, MIL.M_DEFAULT, ref MilBlobResult);
MIL.MblobControl(MilBlobContext, MIL.M_CENTER_OF_GRAVITY + MIL.M_BINARY, MIL.M_ENABLE);
MIL.MblobControl(MilBlobContext, MIL.M_BOX, MIL.M_ENABLE);
MIL.MgraControlList(MilGraphicsList, MIL.M_GRAPHIC_LABEL(RegionLabel), MIL.M_DEFAULT, MIL.M_GRAPHIC_SELECTED, MIL.M_TRUE);
CountObjects(MilDisplay, MilGraphicsList, MilGraphicsContext, MilBinImage, MilBlobContext, MilBlobResult);
DataStructure.MilDisplay = MilDisplay;
DataStructure.MilGraphicsList = MilGraphicsList;
DataStructure.MilGraphicsContext = MilGraphicsContext;
DataStructure.MilBinImage = MilBinImage;
DataStructure.RegionLabel = RegionLabel;
DataStructure.MilBlobContext = MilBlobContext;
DataStructure.MilBlobResult = MilBlobResult;
GCHandle DataStructureHandle = GCHandle.Alloc(DataStructure);
MIL_GRA_HOOK_FUNCTION_PTR HookHandlerDelegate = new MIL_GRA_HOOK_FUNCTION_PTR(HookHandler);
MIL.MgraHookFunction(MilGraphicsList, MIL.M_GRAPHIC_MODIFIED, HookHandlerDelegate, GCHandle.ToIntPtr(DataStructureHandle));
Console.WriteLine("You can try using your mouse or your keyboard to interactively");
Console.WriteLine("modify the displayed region, such as moving, resizing, or");
Console.WriteLine("rotating the region. If you do so, the results and annotations");
Console.WriteLine("will be immediately updated.");
Console.WriteLine();
Console.WriteLine("Press <Enter> to exit.");
int PressedKey = 0;
while (PressedKey != ASCII_ENTER)
PressedKey = (int)Console.ReadKey(true).Key;
MIL.MgraHookFunction(MilGraphicsList, MIL.M_GRAPHIC_MODIFIED + MIL.M_UNHOOK, HookHandlerDelegate, GCHandle.ToIntPtr(DataStructureHandle));
DataStructureHandle.Free();
MIL.MblobFree(MilBlobResult);
MIL.MblobFree(MilBlobContext);
MIL.MbufFree(MilBinImage);
MIL.MgraFree(MilGraphicsContext);
MIL.MgraFree(MilGraphicsList);
MIL.MbufFree(MilImage);
}
private static MIL_INT HookHandler(MIL_INT HookType, MIL_ID EventId, IntPtr UserDataPtr)
{
if (!IntPtr.Zero.Equals(UserDataPtr))
{
GCHandle hUserData = GCHandle.FromIntPtr(UserDataPtr);
STestParameters DataStructure = hUserData.Target as STestParameters;
MIL_INT ModifiedGraphicLabel = 0;
MIL.MgraGetHookInfo(EventId, MIL.M_GRAPHIC_LABEL_VALUE, ref ModifiedGraphicLabel);
if (ModifiedGraphicLabel == DataStructure.RegionLabel)
{
CountObjects(DataStructure.MilDisplay,
DataStructure.MilGraphicsList,
DataStructure.MilGraphicsContext,
DataStructure.MilBinImage,
DataStructure.MilBlobContext,
DataStructure.MilBlobResult);
}
}
return MIL.M_NULL;
}
private const int MAX_TEXT_SIZE = 100;
private static void CountObjects(MIL_ID MilDisplay, MIL_ID MilGraphicsList, MIL_ID MilGraphicsContext, MIL_ID MilBinImage, MIL_ID MilBlobContext, MIL_ID MilBlobResult)
{
MIL_INT NumberOfBlobs = 0;
MIL_INT NumberOfPrimitives = 0;
MIL_INT Index;
string TextLabel;
MIL.MdispControl(MilDisplay, MIL.M_UPDATE, MIL.M_DISABLE);
MIL.MgraInquireList(MilGraphicsList, MIL.M_LIST, MIL.M_DEFAULT, MIL.M_NUMBER_OF_GRAPHICS, ref NumberOfPrimitives);
for (Index = NumberOfPrimitives-1; Index > 0; Index--)
{
MIL.MgraControlList(MilGraphicsList, MIL.M_GRAPHIC_INDEX(Index), MIL.M_DEFAULT, MIL.M_DELETE, MIL.M_DEFAULT);
}
MIL.MbufSetRegion(MilBinImage, MilGraphicsList, MIL.M_DEFAULT, MIL.M_RASTERIZE + MIL.M_FILL_REGION, MIL.M_DEFAULT);
MIL.MblobCalculate(MilBlobContext, MilBinImage, MIL.M_NULL, MilBlobResult);
MIL.MblobGetResult(MilBlobResult, MIL.M_GENERAL, MIL.M_NUMBER + MIL.M_TYPE_MIL_INT, ref NumberOfBlobs);
MIL.MgraControl(MilGraphicsContext, MIL.M_INPUT_UNITS, MIL.M_DISPLAY);
TextLabel = string.Format(" Number of blobs found: {0,2} ", NumberOfBlobs);
MIL.MgraColor(MilGraphicsContext, MIL.M_COLOR_WHITE);
MIL.MgraText(MilGraphicsContext, MilGraphicsList, 10, 10, TextLabel);
MIL.MgraControl(MilGraphicsContext, MIL.M_INPUT_UNITS, MIL.M_PIXEL);
MIL.MgraColor(MilGraphicsContext, MIL.M_COLOR_RED);
MIL.MblobDraw(MilGraphicsContext, MilBlobResult, MilGraphicsList, MIL.M_DRAW_CENTER_OF_GRAVITY, MIL.M_INCLUDED_BLOBS, MIL.M_DEFAULT);
MIL.MgraColor(MilGraphicsContext, MIL.M_COLOR_GREEN);
MIL.MblobDraw(MilGraphicsContext, MilBlobResult, MilGraphicsList, MIL.M_DRAW_BOX, MIL.M_INCLUDED_BLOBS, MIL.M_DEFAULT);
MIL.MdispControl(MilDisplay, MIL.M_UPDATE, MIL.M_ENABLE);
}
}
}