iplimage bitmap

场景:opencv 中 怎么实现 IplImage格式与 Bitmap 格式的相互转换? 万分感谢

opencv 中 如何实现 IplImage格式与 Bitmap 格式的相互转换? 万分感谢
如图 , 最近在搞图形处理, 想实现 IplImage 与 Bitmap 的相互转换 ? 请高手指点?

  另外 ,请大家推荐几本关于opencv 人脸特征定位的书(比如眼睛 、鼻子),或者网站、资料。分不算多,万分感谢!

------解决方案--------------------
C/C++ code

#ifndef HANNOSOGNO_FUNCTION
#define HANNOSOGNO_FUNCTION


#include "cv.h"
#include "highgui.h"


namespace Hannosogno
{


System::Drawing::Bitmap^ IplImage2Bitmap(IplImage *src)
{
System::Drawing::Bitmap^ bm = gcnew System::Drawing::Bitmap(src->width, src->height);


for(int i=0; i<src->height; ++i)
{
for(int j=0; j<src->width; ++j)
{
CvScalar s = cvGet2D(src, i, j); 
int b = s.val[0];
int g = s.val[1];
int r = s.val[2];
System::Drawing::Color c = System::Drawing::Color::FromArgb(r, g, b);
bm->SetPixel(j, i, c);
}
}


return bm;
}
}


#endif

------解决方案--------------------
由于OpenCV主要针对的是计算机视觉方面的处理,因此在函数库中,最重要的结构体是IplImage结构。IplImage结构来源于Intel的另外一个函数库Intel Image Processing Library (IPL),该函数库主要是针对图像处理。IplImage结构具体定义如下:

typedef struct _IplImage

{

int nSize; /* IplImage大小 */

int ID; /* 版本 (=0)*/

int nChannels; /* 大多数OPENCV函数支持1,2,3 或 4 个通道 */

int alphaChannel; /* 被OpenCV忽略 */

int depth; /* 像素的位深度,主要有以下支持格式: IPL_DEPTH_8U, IPL_DEPTH_8S, IPL_DEPTH_16U,IPL_DEPTH_16S, IPL_DEPTH_32S,

IPL_DEPTH_32F 和IPL_DEPTH_64F */

char colorModel[4]; /* 被OpenCV忽略 */

char channelSeq[4]; /* 同上 */

int dataOrder; /* 0 - 交叉存取颜色通道, 1 - 分开的颜色通道.

只有cvCreateImage可以创建交叉存取图像 */

int origin; /*图像原点位置: 0表示顶-左结构,1表示底-左结构 */

int align; /* 图像行排列方式 (4 or 8),在 OpenCV 被忽略,使用 widthStep 代替 */

int width; /* 图像宽像素数 */

int height; /* 图像高像素数*/

struct _IplROI *roi; /* 图像感兴趣区域,当该值非空时,

只对该区域进行处理 */

struct _IplImage *maskROI; /* 在 OpenCV中必须为NULL */

void *imageId; /* 同上*/

struct _IplTileInfo *tileInfo; /*同上*/

int imageSize; /* 图像数据大小(在交叉存取格式下ImageSize=image->height*image->widthStep),单位字节*/

char *imageData; /* 指向排列的图像数据 */

int widthStep; /* 排列的图像行大小,以字节为单位 */

int BorderMode[4]; /* 边际结束模式, 在 OpenCV 被忽略*/

int BorderConst[4]; /* 同上 */

char *imageDataOrigin; /* 指针指向一个不同的图像数据结构(不是必须排列的),是为了纠正图像内存分配准备的 */

} IplImage;

IplImage结构体是整个OpenCV函数库的基础,在定义该结构变量时需要用到函数cvCreatImage,变量定义方法如下: 

IplImage* src="/cvCreateImage"(cvSize(400,300), IPL_DEPTH_8U,3); 

上句定义了一个IplImage指针变量src,图像的大小是400×300,图像颜色深度8位,3通道图像。


------解决方案--------------------
以发送到你的邮箱
请查收
3x