zoukankan      html  css  js  c++  java
  • 《学习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...
    ");
            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;
    }
    
  • 相关阅读:
    【z02】选择客栈
    JavaEE(22)
    驱动表问题
    影响子查询展开的情况
    SQL*Net message from client
    等值链接和非等值链接
    ||拼接列关联和直接关联区别
    分页SQL优化
    SQL*Net more data to client
    SQL*Net message to client
  • 原文地址:https://www.cnblogs.com/huahai/p/7271061.html
Copyright © 2011-2022 走看看