《学习OpenCV》课后习题解答6

题目:(P104)
使用cvCmp()创建一个掩码。加载一个真实的图像。使用cvsplit()将图像分割成红,绿,蓝三个单通道图像。
a.找到并显示绿图。
b.克隆这个绿图两次(分别命名为clone1和clone2)。
c.求出这个绿色平面的最大值和最小值。
d.将clone1的所有元素赋值为theash=(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)函数并显示结果。

解答:

#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_maxPixel, &green_minPixel);
    //-------------------d小题-------------------------------
    thresh = (unsigned char)(green_maxPixel - green_minPixel) / 2.0;
    cvSet(clone1, cvScalar(thresh));
    //----------------------e小题-----------------------
    cvZero(clone2);
    cvCmp(gImg, clone1, clone2, CV_CMP_GE);
    //---------------------------f小题-------------------
    cvSubS(gImg, cvScalar(thresh / 2), gImg, clone2);
    cvNamedWindow("GreenImage1");
    cvShowImage("GreenImage1", gImg);
    cvWaitKey(0);
    cvReleaseImage(&srcImg);
    cvReleaseImage(&rImg);
    cvReleaseImage(&gImg);
    cvReleaseImage(&bImg);
    cvDestroyWindow("GreenImage0");
    cvDestroyWindow("GreenImage1");
    return 0;
}

转载于:https://www.cnblogs.com/huahai/p/7271061.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值