【OpenCV图像处理】IplImage转换灰度图像及Cvmat与IplImage格式之间的相互转换

#define ImgPath "D:\\...\\*.JPG"

//读取图像
IplImage* Img = cvLoadImage(ImgPath);
if (!Img)
{
	fprintf(stderr, "Can not load image %s\n", ImgPath);
}

//转换为灰度图像
IplImage* ImgGray = cvCreateImage(cvGetSize(Img), IPL_DEPTH_8U, 1);
cvCvtColor(Img, ImgGray, CV_BGR2GRAY);//cvCvtColor(src,des,CV_BGR2GRAY)
cvSaveImage(ImgGrayPath, ImgGray);//保存灰度图像

//转换为矩阵
CvMat* ImgMat = cvCreateMat(ImgGray->height, ImgGray->width, CV_64FC1);//定义一个指向CvMat对象的指针
ImgMat = cvCreateMatHeader(ImgGray->height, ImgGray->width, CV_64FC1);//创建矩阵头,和图像头,数据共享(必要)
cvGetMat(ImgGray, ImgMat);//从img到mat

//二次转换为图像
IplImage* ReImg = cvCreateImage(cvGetSize(ImgMat), IPL_DEPTH_8U, 1);
cvGetImage(ImgMat, ReImg);//从mat到img

//显示调试
cvNamedWindow("image", CV_WINDOW_AUTOSIZE);//创建显示目标的窗口
cvShowImage("image", ReImg);//显示灰度图像
cvWaitKey(0);

//释放内存,关闭窗口
cvReleaseMat(&ImgMat);

cvReleaseImage(&Img);
cvReleaseImage(&ImgGray);
cvReleaseImage(&ReImg);

cvDestroyAllWindows();
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值