//***************************************************************************************
// 
// File name: RegionManager.cpp
// Location: See Matrox Example Launcher in the MIL Control Center
// 
//
// Synopsis: This file contains the implementation of the CRegionMngr class
//           which is the class that manages the use of a region in an inspection task.
//
// Copyright (C) Matrox Electronic Systems Ltd., 1992-2020.
// All Rights Reserved

#include <mil.h>
#include "RegionManager.h"

//*****************************************************************************
// Constants.
//*****************************************************************************

//*****************************************************************************
// Constructor.
//*****************************************************************************
CRegionMngr::CRegionMngr()
 : m_MilRasterRegion(M_NULL)
   {
   }

//*****************************************************************************
// Destructor.
//*****************************************************************************
CRegionMngr::~CRegionMngr()
   {
   CRegionMngr::Free();   
   }  

//*****************************************************************************
// Initialization function.
//*****************************************************************************
void CRegionMngr::Init(MIL_ID MilSystem, MIL_INT ImageSizeX /* = 0 */, MIL_INT ImageSizeY /* = 0 */)
   {
   // Allocate the raster region and clear it.
   if(ImageSizeX && ImageSizeY)
      {
      MbufAlloc2d(MilSystem, ImageSizeX, ImageSizeY, 8+M_UNSIGNED, M_IMAGE+M_PROC, &m_MilRasterRegion);
      MbufClear(m_MilRasterRegion, 0);
      }
   }

//*****************************************************************************
// Function to set the region in an image.
//*****************************************************************************
void CRegionMngr::SetRegion(MIL_ID MilImage, MIL_ID MilRegionGraList)
   {
   MbufSetRegion(MilImage, MilRegionGraList, M_DEFAULT, M_NO_RASTERIZE, M_DEFAULT);   
   }

//*****************************************************************************
// Function that rasterizes the region in the raster image.
// Returns the rasterized image id.
//*****************************************************************************
MIL_ID CRegionMngr::RasterizeRegion(MIL_ID MilCalibration, MIL_ID MilRegionGraList)
   {
   // Associate the calibration to the rasterize image.
   McalAssociate(MilCalibration, m_MilRasterRegion, M_DEFAULT);

   // Draw the region in the buffer.
   MgraDraw(MilRegionGraList, m_MilRasterRegion, M_DEFAULT);
     
   return m_MilRasterRegion;
   }

//*****************************************************************************
// Function that frees the region manager.
//*****************************************************************************
void CRegionMngr::Free()
   {
   if(m_MilRasterRegion)
      {
      MbufFree(m_MilRasterRegion);
      m_MilRasterRegion = M_NULL;
      }
   }

//*****************************************************************************
// Function that draws the text in the region.
//*****************************************************************************
void CRegionMngr::DrawTextInRegion(MIL_ID MilGraContext, MIL_ID MilRegionGraList, MIL_ID MilDest, MIL_INT RegionIndex, MIL_CONST_TEXT_PTR String)
   {
   if(MilRegionGraList)
      {
      // Get the original text alignment.
      MIL_INT CurTextAlignHorizontal = MgraInquire(MilGraContext, M_TEXT_ALIGN_HORIZONTAL, M_NULL);
      MIL_INT CurTextAlignVertical = MgraInquire(MilGraContext, M_TEXT_ALIGN_VERTICAL, M_NULL);
      
      // Draw the text centered on the position.
      MIL_DOUBLE PosX, PosY;
      MgraInquireList(MilRegionGraList, M_GRAPHIC_INDEX(RegionIndex), M_DEFAULT, M_POSITION_X, &PosX);
      MgraInquireList(MilRegionGraList, M_GRAPHIC_INDEX(RegionIndex), M_DEFAULT, M_POSITION_Y, &PosY);
      MgraControl(MilGraContext, M_TEXT_ALIGN_HORIZONTAL, M_CENTER);
      MgraControl(MilGraContext, M_TEXT_ALIGN_VERTICAL, M_CENTER);

      // Draw the text.
      MgraText(MilGraContext, MilDest, PosX, PosY, String);

      // Put the text alignment back.
      MgraControl(MilGraContext, M_TEXT_ALIGN_HORIZONTAL, (MIL_DOUBLE)CurTextAlignHorizontal);
      MgraControl(MilGraContext, M_TEXT_ALIGN_VERTICAL, (MIL_DOUBLE)CurTextAlignVertical);
      }
   else
      // Draw the text.
      MgraText(MilGraContext, MilDest, 0, 0, String);
   }