《学习OpenCV》第三章课后题5

题目说明:练习使用感兴趣区域(ROI)。创建一个210*210的单通道图像并将其归0。在图像中使用ROI和cvSet()建立一个增长如金字塔状的数组。也就是:外部边界为0,下一个内部边界应该为20,再下一个内部边界为40依次类推,直到最后内部值为200;所有的边界应该为10个像素的宽度,最后显示这个图形。

#include <highgui.h>
#include <cv.h>
#include <stdio.h>


// 图像高宽
#define IMG_SIZE   210

// 边界宽度
#define BORDER_WIDTH 10

int main()
{
    // 创建8位单通道图像
    IplImage * image = cvCreateImage(cvSize(IMG_SIZE, IMG_SIZE), 8, 1);

    // 初始化置零
    cvZero(image);

    // 灰度值
    int value = 0;

    // ROI区域大小
    int rect_size = IMG_SIZE;

    for(int length = IMG_SIZE; length >= 0 && 0 <= rect_size && value <= 200; length -= BORDER_WIDTH, value += 10)
    {
        cvSetImageROI(image, cvRect(IMG_SIZE - length, IMG_SIZE- length, rect_size, rect_size));
        rect_size -= 2*BORDER_WIDTH;
        cvSet(image, cvScalarAll(value));
        cvResetImageROI(image);
    }

    cvNamedWindow("img", 1);
    cvShowImage("img", image);

    cvWaitKey(0);
    cvReleaseImage(&image);
    cvDestroyAllWindows();

    return 0;
}

解释说明:此算法首先将整个区域设为ROI,然后进行赋值,然后逐渐缩小ROI,然后增加亮度进行赋值,直到最后到金字塔的顶端为止,亮度最大。


wind向qdsclove学习

引用:qdsclove的专栏
http://m.blog.csdn.net/blog/Stk_OverFlow/8744679

发布了19 篇原创文章 · 获赞 13 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/windxf/article/details/46534973