练习3-7 使用cvCmp()创建一个掩码。加载一个真实的图像。使用cvSplit()将图像分割成红,绿,蓝三个单通道图像。

7. 使用cvCmp()创建一个掩码。加载一个真实的图像。使用cvSplit()将图像分割成红,绿,蓝三个单通道图像。

a. 找到并显示绿图。

b. 克隆这个绿图两次(分别命名为clone1和clone2)。

c. 求出这个绿色平面的最大值和最小值。

d. 将clone1的所有元素赋值为thresh=(unsigned char)((最大值-最小值)/2.0)。

e. 将clone2所有元素赋值为0,然后调用函数cvCmp (green_image, clone1, clone2, CV_CMP_GE)。现在clone2将是一个标识绿图中值超过thresh的掩码图像。

f. 最后,使用cvSubS(green_image,thresh/2, green_image, clone2)函数并显示结果。

// 作业3-7(104).cpp : 定义控制台应用程序的入口点。
//


#include "stdafx.h"
#include <cv.h>
#include <highgui.h>


int main(int argc, const char** argv)
{
IplImage* srcImg = cvLoadImage(argv[1]);    //load the image


if (!srcImg)
{
printf("cannot open the file...\n");
return -1;
}
IplImage* rImg = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1);
IplImage* gImg = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1);
IplImage* bImg = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1);    //创建单通道r,g,b图像
IplImage* clone1 = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1);
IplImage* clone2 = cvCreateImage(cvGetSize(srcImg), srcImg->depth, 1);
double green_maxPixel = 0;
double green_minPixel = 0;  //绿色平面最大最小值
double thresh;  //阈值thresh
cvSplit(srcImg, rImg, gImg, bImg, 0);   //拆分3通道
//-------------------a小题 ------------------
cvNamedWindow("GreenImage0");
cvShowImage("GreenImage0", gImg);
//-------------------b小题---------------------
cvCopy(gImg, clone1);
cvCopy(gImg, clone2);   //copy the gImg to clone1 and  clone2
//-----------------c小题求绿色平面最大最小值-----------------
cvMinMaxLoc(gImg, &green_minPixel, &green_maxPixel);
//-------------------d小题-------------------------------
thresh = (unsigned char)(green_maxPixel - green_minPixel) / 2.0;
cvSet(clone1, cvScalar(thresh));
//----------------------e小题-----------------------
cvZero(clone2);
cvCmp(gImg, clone1, clone2, CV_CMP_GE);
cvNamedWindow("GreenImage1");
cvShowImage("GreenImage1", clone2);
//---------------------------f小题-------------------
cvSubS(gImg, cvScalar(thresh/2 ), gImg, clone2);
cvNamedWindow("GreenImage2");
cvShowImage("GreenImage2", gImg);
cvWaitKey(0);
cvReleaseImage(&srcImg);
cvReleaseImage(&rImg);
cvReleaseImage(&gImg);
cvReleaseImage(&bImg);
cvDestroyWindow("GreenImage0");
cvDestroyWindow("GreenImage1");
cvDestroyWindow("GreenImage2");
return 0;

}

练习3-7 使用cvCmp()创建一个掩码。加载一个真实的图像。使用cvSplit()将图像分割成红,绿,蓝三个单通道图像。