首先在你的解决方案资源管理器中的头文件和源文件下分别添加 CvvImage.cpp 如下图:

view类头上加个#include "CvvImage.h"  头文件,应该就可以解决了。

下面是源代码:

CvvImage.h.h

CvvIm
class  CvvImage
{
public:
 CvvImage();
 virtual ~CvvImage();

virtual bool  Create( int width, int height, int bits_per_pixel, int image_origin = 0 );

virtual bool  Load( const char* filename, int desired_color = 1 );

virtual bool  LoadRect( const char* filename,
  int desired_color, CvRect r );

#if defined WIN32 || defined _WIN32
 virtual bool  LoadRect( const char* filename,
  int desired_color, RECT r )
 {
  return LoadRect( filename, desired_color,
   cvRect( r.left, r.top, r.right - r.left, r.bottom - r.top ));
 }
#endif

virtual bool  Save( const char* filename );

virtual void  CopyOf( CvvImage& image, int desired_color = -1 );
 virtual void  CopyOf( IplImage* img, int desired_color = -1 );

IplImage* GetImage() { return m_img; };
 virtual void  Destroy(void);

int Width() { return !m_img ? 0 : !m_img->roi ? m_img->width : m_img->roi->width; };
 int Height() { return !m_img ? 0 : !m_img->roi ? m_img->height : m_img->roi->height;};
 int Bpp() { return m_img ? (m_img->depth & 255)*m_img->nChannels : 0; };

virtual void  Fill( int color );

virtual void  Show( const char* window );

#if defined WIN32 || defined _WIN32
 
 virtual void  Show( HDC dc, int x, int y, int width, int height,
  int from_x = 0, int from_y = 0 );
 
 virtual void  DrawToHDC( HDC hDCDst, RECT* pDstRect );
#endif

IplImage*  m_img;
};

typedef CvvImage CImage;

-----------------------------------------------------------------------------------------------------------------------------------

CvvImage.cpp

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) && \
 ((IplImage*)img)->imageData != 0)

void  CvvImage::CopyOf( IplImage* img, int desired_color )
{
 if( HG_IS_IMAGE(img) )
 {
  int color = desired_color;
  CvSize size = cvGetSize( img );

if( color < 0 )
   color = img->nChannels > 1;

if( Create( size.width, size.height,
   (!color ? 1 : img->nChannels > 1 ? img->nChannels : 3)*8,
   img->origin ))
  {
   cvConvertImage( img, m_img, 0 );
  }
 }
}

bool  CvvImage::Load( const char* filename, int desired_color )
{
 IplImage* img = cvLoadImage( filename, desired_color );
 if( !img )
  return false;

CopyOf( img, desired_color );
 cvReleaseImage( &img );

return true;
}

bool  CvvImage::LoadRect( const char* filename,
       int desired_color, CvRect r )
{
 if( r.width < 0 || r.height < 0 ) return false;

IplImage* img = cvLoadImage( filename, desired_color );
 if( !img )
  return false;

if( r.width == 0 || r.height == 0 )
 {
  r.width = img->width;
  r.height = img->height;
  r.x = r.y = 0;
 }

if( r.x > img->width || r.y > img->height ||
  r.x + r.width < 0 || r.y + r.height < 0 )
 {
  cvReleaseImage( &img );
  return false;
 }

if( r.x < 0 )
 {
  r.width += r.x;
  r.x = 0;
 }
 if( r.y < 0 )
 {
  r.height += r.y;
  r.y = 0;
 }

if( r.x + r.width > img->width )
  r.width = img->width - r.x;

if( r.y + r.height > img->height )
  r.height = img->height - r.y;

cvSetImageROI( img, r );
 CopyOf( img, desired_color );

cvReleaseImage( &img );
 return true;
}

bool  CvvImage::Save( const char* filename )
{
 if( !m_img )
  return false;
 cvSaveImage( filename, m_img );
 return true;
}

void  CvvImage::Show( const char* window )
{
 if( m_img )
  cvShowImage( window, m_img );
}

void  CvvImage::Show( HDC dc, int x, int y, int w, int h, int from_x, int from_y )
{
 if( m_img && m_img->depth == IPL_DEPTH_8U )
 {
  uchar buffer[sizeof(BITMAPINFOHEADER) + 1024];
  BITMAPINFO* bmi = (BITMAPINFO*)buffer;
  int bmp_w = m_img->width, bmp_h = m_img->height;

FillBitmapInfo( bmi, bmp_w, bmp_h, Bpp(), m_img->origin );

from_x = MIN( MAX( from_x, 0 ), bmp_w - 1 );
  from_y = MIN( MAX( from_y, 0 ), bmp_h - 1 );

int sw = MAX( MIN( bmp_w - from_x, w ), 0 );
  int sh = MAX( MIN( bmp_h - from_y, h ), 0 );

SetDIBitsToDevice(
   dc, x, y, sw, sh, from_x, from_y, from_y, sh,
   m_img->imageData + from_y*m_img->widthStep,
   bmi, DIB_RGB_COLORS );
 }
}

void  CvvImage::DrawToHDC( HDC hDCDst, RECT* pDstRect )
{
 if( pDstRect && m_img && m_img->depth == IPL_DEPTH_8U && m_img->imageData )
 {
  uchar buffer[sizeof(BITMAPINFOHEADER) + 1024];
  BITMAPINFO* bmi = (BITMAPINFO*)buffer;
  int bmp_w = m_img->width, bmp_h = m_img->height;

CvRect roi = cvGetImageROI( m_img );
  CvRect dst = RectToCvRect( *pDstRect );

if( roi.width == dst.width && roi.height == dst.height )
  {
   Show( hDCDst, dst.x, dst.y, dst.width, dst.height, roi.x, roi.y );
   return;
  }

if( roi.width > dst.width )
  {
   SetStretchBltMode(
    hDCDst,           // handle to device context
    HALFTONE );
  }
  else
  {
   SetStretchBltMode(
    hDCDst,           // handle to device context
    COLORONCOLOR );
  }

FillBitmapInfo( bmi, bmp_w, bmp_h, Bpp(), m_img->origin );

::StretchDIBits(
   hDCDst,
   dst.x, dst.y, dst.width, dst.height,
   roi.x, roi.y, roi.width, roi.height,
   m_img->imageData, bmi, DIB_RGB_COLORS, SRCCOPY );
 }
}

void  CvvImage::Fill( int color )
{
 cvSet( m_img, cvScalar(color&255,(color>>8)&255,(color>>16)&255,(color>>24)&255) );
}

代码来自以前的版本.

在OpenCV2.2后的版本中没有CvvImage类的解决方法(及出现错误:IntelliSense: 未定义标识符 "CvvImage" )的更多相关文章

  1. 【转】 VC++ 关闭程序后任务管理器进程中进程仍然存在的解决方法

    转载出处:http://blog.csdn.net/zac_sian/article/details/50809084 可以从以下两个方面进行查找! 1.程序开启了进程,进程中使用了while(1), ...

  2. Devexpress xaf针对某个用户登录后在面板中设置导航无效的解决方法

    Devexpress xaf框架生成的项目默认情况下导航栏是显示在左侧,有时候我们用某个账户登录后,发现导航栏无法显示在左侧,操作十分不方便.我们可以去数据库删除当前登录用户的自定义布局 解决方法如下 ...

  3. WebService中使用自定义类的解决方法(5种)

    转自:http://www.cnblogs.com/lxinxuan/archive/2007/05/24/758317.html Demo下载:http://files.cnblogs.com/lx ...

  4. @Data注解使用后在eclipse中get/set报错解决方法

    Maven项目中已经导入相关的lombok.jar包但是使用后仍提示无set/get方法 安装完成之后,请确认eclipse安装路径下是否多了一个lombok.jar包,并且其 配置文件eclipse ...

  5. 国内不fq安装K8S四: 安装过程中遇到的问题和解决方法

    目录 4 安装过程中遇到的问题和解决方法 4.1 常见问题 4.2 常用的操作命令 4.3 比较好的博客 国内不fq安装K8S一: 安装docker 国内不fq安装K8S二: 安装kubernet 国 ...

  6. 将html代码部署到阿里云服务器,并进行域名解析,以及在部署过程中遇到的问题和解决方法

    本博客主要是说一下,,如何将html代码部署到阿里云服务器,并进行域名解析,以及在部署过程中遇到的问题和解决方法. 1.先在阿里云上购买一台阿里云服务器(ECS云服务器): 2.远程连接上该服务器,在 ...

  7. VS2012中丢失ArcGIS模板的解决方法

    VS2012中丢失ArcGIS模板的解决方法 由于ArcGIS10.0(for .NET)默认是用VS2010作为开发工具的,所以在先安装VS2012后装ArcGIS10.0 桌面版及ArcObjec ...

  8. Java Native Interfce三在JNI中使用Java类的普通方法与变量

    本文是<The Java Native Interface Programmer's Guide and Specification>读书笔记 前面我们学习了如何在JNI中通过参数来使用J ...

  9. java开发中遇到的问题及解决方法(持续更新)

    摘自 http://blog.csdn.net/pony12/article/details/38456261 java开发中遇到的问题及解决方法(持续更新) 工作中,以C/C++开发为主,难免与其他 ...

随机推荐

  1. 【读书笔记】Java核心技术-基础知识-反射

    在网页中运行Java程序称为applet. 反射 这项功能被大量地应用于JavaBeans中,它是Java组件的体系结构. 能够分析类能力的程序称为反射(reflective).反射机制的功能及其强大 ...

  2. python中的逻辑操作符

    python中主要有三个逻辑操作符,分别是:and.or.not. and:且,所有人为真才为真. or:或,一个为正就是真. not:非,取反. >>> print(3>2 ...

  3. iOS 11 Xcode9开发 新特性学习 (警告篇)

    最新版本SDK优化了开发体验,编译过程会提供更多提示警告,建议你修改.这些功能也可以自主选择用或者不用,当然,苹果喜欢你用他推荐的东西... 1 . @avalibale 语法,同步判断当前iOS系统 ...

  4. 40个你可能不知道的Python的特点和技巧

    1.拆箱 >>> a, b, c = 1, 2, 3 >>> a, b, c (1, 2, 3) >>> a, b, c = [1, 2, 3] ...

  5. 记录python面试题

    闲来无事,记录一下曾经以及深刻的面试题 记录一下我记忆比较深的面试题,以后若用到python相关还能细细把玩 搜狐面试题: 一.写一个缓存优化策略 解答:这个题主要考察对lru_cache的理解,所以 ...

  6. JavaWeb Request和Response

    1. Request与Response 1.1. Web应用运行机制 到目前为止,我们已经掌握了Web应用程序的运行机制,现在学习的就是Web应用程序运行机制中很重要的内容 —— Request与Re ...

  7. Android系统--灯光系统驱动编写

    Android系统开发--Android灯光系统tiny4412_led_class驱动编写 框架分析 led_classdev_4412结构体 创建led_classdev_4412结构体 分配结构 ...

  8. Android LCD(二):常用接口原理篇【转】

    本文转载自:http://blog.csdn.net/xubin341719/article/details/9125799 关键词:Android LCD TFT TTL(RGB)  LVDS  E ...

  9. 单文件夹下的C程序如何编写Makefile文件

    通过学习已经学会了GCC的一些基础的命令,以及如何将C语言源代码编译成可执行文件. 我们已经知道在linux环境下编译源码时,常会有以下三个步骤: ./configure make make clea ...

  10. CentOS 7 安装 maven

    下载地址 http://maven.apache.org/download.cgi 版本 apache-maven-3.3.9 -bin.tar.gz tar -xvf apache-maven-3. ...