• 大小: 18.6MB
    文件类型: .zip
    金币: 1
    下载: 0 次
    发布日期: 2023-08-01
  • 语言: C/C++
  • 标签: MFC  OpenCV  图像显示  ROI  

资源简介

此程序中我们实现选取路径并加载显示图片,然后还可在显示的图片中标记ROI感兴趣区域。

资源截图

代码片段和文件信息

#include “StdAfx.h“
#include “CvvImage.h“
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
CV_INLINE RECT NormalizeRect( RECT r );
CV_INLINE RECT NormalizeRect( RECT r )
{
 int t;
 if( r.left > r.right )
 {
  t = r.left;
  r.left = r.right;
  r.right = t;
 }
 if( r.top > r.bottom )
 {
  t = r.top;
  r.top = r.bottom;
  r.bottom = t;
 }
 return r;
}
CV_INLINE CvRect RectToCvRect( RECT sr );
CV_INLINE CvRect RectToCvRect( RECT sr )
{
 sr = NormalizeRect( sr );
 return cvRect( sr.left sr.top sr.right - sr.left sr.bottom - sr.top );
}
CV_INLINE RECT CvRectToRect( CvRect sr );
CV_INLINE RECT CvRectToRect( CvRect sr )
{
 RECT dr;
 dr.left = sr.x;
 dr.top = sr.y;
 dr.right = sr.x + sr.width;
 dr.bottom = sr.y + sr.height;
 return dr;
}
CV_INLINE IplROI RectToROI( RECT r );
CV_INLINE IplROI RectToROI( RECT r )
{
 IplROI roi;
 r = NormalizeRect( r );
 roi.xOffset = r.left;
 roi.yOffset = r.top;
 roi.width = r.right - r.left;
 roi.height = r.bottom - r.top;
 roi.coi = 0;
 return roi;
}
void  FillBitmapInfo( BITMAPINFO* bmi int width int height int bpp int origin )
{
 assert( bmi && width >= 0 && height >= 0 && (bpp == 8 || bpp == 24 || bpp == 32));
 BITMAPINFOHEADER* bmih = &(bmi->bmiHeader);
 memset( bmih 0 sizeof(*bmih));
 bmih->biSize = sizeof(BITMAPINFOHEADER);
 bmih->biWidth = width;
 bmih->biHeight = origin ? abs(height) : -abs(height);
 bmih->biPlanes = 1;
 bmih->biBitCount = (unsigned short)bpp;
 bmih->biCompression = BI_RGB;
 if( bpp == 8 )
 {
  RGBQUAD* palette = bmi->bmiColors;
  int i;
  for( i = 0; i < 256; i++ )
  {
   palette[i].rgbBlue = palette[i].rgbGreen = palette[i].rgbRed = (BYTE)i;
   palette[i].rgbReserved = 0;
  }
 }
}
CvvImage::CvvImage()
{
 m_img = 0;
}
void CvvImage::Destroy()
{
 cvReleaseImage( &m_img );
}
CvvImage::~CvvImage()
{
 Destroy();
}
bool  CvvImage::Create( int w int h int bpp int origin )
{
 const unsigned max_img_size = 10000;
 if( (bpp != 8 && bpp != 24 && bpp != 32) ||
  (unsigned)w >=  max_img_size || (unsigned)h >= max_img_size ||
  (origin != IPL_ORIGIN_TL && origin != IPL_ORIGIN_BL))
 {
  assert(0); // most probably it is a programming error
  return false;
 }
 if( !m_img || Bpp() != bpp || m_img->width != w || m_img->height != h )
 {
  if( m_img && m_img->nSize == sizeof(IplImage))
   Destroy();
  
  m_img = cvCreateImage( cvSize( w h ) IPL_DEPTH_8U bpp/8 );
 }
 if( m_img )
  m_img->origin = origin == 0 ? IPL_ORIGIN_TL : IPL_ORIGIN_BL;
 return m_img != 0;
}
void  CvvImage::CopyOf( CvvImage& image int desired_color )
{
 IplImage* img = image.GetImage();
 if( img )
 {
  CopyOf( img desired_color );
 }
}

#define HG_IS_IMAGE(img)                                                  \
 ((img) != 0 && ((const IplImage*)(img))->nSize == sizeof(IplImage) && \
 ((IplImag

 属性            大小     日期    时间   名称
----------- ---------  ---------- -----  ----
     目录           0  2014-11-13 16:04  MFC_OpencvTest2_ROI\
     目录           0  2014-11-13 19:49  MFC_OpencvTest2_ROI\Debug\
     文件      114688  2014-11-14 15:12  MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROI.exe
     文件     1077628  2014-11-14 15:12  MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROI.ilk
     文件     4844544  2014-11-14 15:12  MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROI.pdb
     目录           0  2014-11-14 15:19  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\
     文件    28412928  2014-11-14 15:20  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI.ncb
     文件         923  2014-11-13 16:03  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI.sln
     文件       38912  2014-11-14 15:20  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI.suo
     文件        6546  2014-11-11 20:55  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\CvvImage.cpp
     文件        1536  2014-11-11 21:30  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\CvvImage.h
     目录           0  2014-11-14 15:12  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\
     文件       18604  2014-11-14 15:12  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\BuildLog.htm
     文件      140195  2014-11-13 19:57  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\CvvImage.obj
     文件      118606  2014-11-14 15:12  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\ImageInfo.obj
     文件         920  2014-11-13 16:04  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROI.exe.embed.manifest
     文件         984  2014-11-13 16:04  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROI.exe.embed.manifest.res
     文件         861  2014-11-14 15:12  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROI.exe.intermediate.manifest
     文件      162704  2014-11-14 15:12  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROI.obj
     文件    24838144  2014-11-13 19:57  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROI.pch
     文件       23668  2014-11-14 13:45  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROI.res
     文件      208184  2014-11-14 15:12  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\MFC_OpencvTest2_ROIDlg.obj
     文件          62  2014-11-14 15:12  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\mt.dep
     文件      466515  2014-11-13 19:57  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\stdafx.obj
     文件     1518592  2014-11-14 15:12  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\vc90.idb
     文件     3313664  2014-11-14 15:12  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\Debug\vc90.pdb
     文件        5552  2014-11-11 16:08  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\dirent.h
     文件         542  2014-11-13 16:30  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\ImageInfo.cpp
     文件         672  2014-11-14 15:19  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\ImageInfo.h
     文件       59400  2014-11-14 13:45  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI.aps
     文件        2253  2014-11-13 16:03  MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI\MFC_OpencvTest2_ROI.cpp
............此处省略14个文件信息

评论

共有 条评论