题目说明:练习使用感兴趣区域(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