opencv把⼀个图像的⼀⼩块区域拷贝到另⼀个图像的指定区域opencv把⼀个图像的⼀⼩块区域拷贝到另⼀个图像的指定区域:
// vv.cpp : 定义控制台应⽤程序的⼊⼝点。
//opencv把⼀个图像的⼀⼩块区域拷贝到另⼀个图像的指定区域
#include "stdafx.h"
#include "cv.h"
#include "highgui.h"
int main()
{
IplImage* img = cvLoadImage("c:\\lh.jpg",0);
CvRect roi =cvRect(6, 6, 48, 48);
cvNamedWindow("img");
cvShowImage("img", img);
IplImage* img1 = cvLoadImage("c:\\leehom.jpg",0);
CvRect roi1 = cvRect(6, 6, 48, 48);
cvNamedWindow("img1");
cvShowImage("img1", img1);
杨洋的女朋友cvSetImageROI(img, roi);
cvSetImageROI(img1, roi1);
cvCopy(img1, img);
cvResetImageROI(img);
cvResetImageROI(img1);
cvNamedWindow("result");
cvShowImage("result", img);
cvWaitKey(-1);
胡定欣电视剧cvReleaseImage(&img);
cvReleaseImage(&img1);
cvDestroyAllWindows();
return 0;
}
结果图:
要注意
对于三通道图像:【拷贝的两幅图像的depth 和 nchanels 应该是⼀样的才可以哦】
额 其实代码⼀样的呃。 只是第⼀次随意指定的Rect区域,三通道图像不⾏,还看了下 cvSetImageROI的源码。
后来发现,额,三通道耶,rect区域的指定肯定是 3 的倍数撒!
特意设定相同的rect区域试了下,发现拷贝过去的图⽚是⼀样的耶。
好菜额···
不太懂,灰度图中是从第六个像素点开始的, 3通道图应该也是从第六个像素开始的啊,因为拷贝过去的图像是⼀样的啊。如果3通道图中 的 6 也是指第六个像素的话,那,roi1 为嘛⾮要是3的倍数呢?
如果这个6指的是第3个像素的第⼀个通道位置的话,那么 为嘛拷贝过去的图像⼀样呢
额。。。暂时还没想通。。。。
// vv.cpp : 定义控制台应⽤程序的⼊⼝点。
//opencv把⼀个图像的⼀⼩块区域拷贝到另⼀个图像的指定区域
#include "stdafx.h"
#include "cv.h"
#include "highgui.h"
int main()
{
IplImage* img = cvLoadImage("c:\\lh.jpg",1);
CvRect roi =cvRect(6, 6, 48, 48);
cvNamedWindow("img");
cvShowImage("img", img);
IplImage* img1 = cvLoadImage("c:\\leehom.jpg",1);
CvRect roi1 = cvRect(6, 6, 48, 48);
cvNamedWindow("img1");
cvShowImage("img1", img1);
cvSetImageROI(img, roi);
五一为啥连休5天
仙剑奇侠传三攻略cvSetImageROI(img1, roi1);
cvCopy(img1, img);
cvResetImageROI(img);
cvResetImageROI(img1);
cvNamedWindow("result");
cvShowImage("result", img);
cvWaitKey(-1);
cvReleaseImage(&img);
cvReleaseImage(&img1);
cvDestroyAllWindows();
return 0;
}
opencv中cvSetImageROI在 cvcore.h中,具体在 cxarray.cpp 中:
CV_IMPL void
cvSetImageROI( IplImage* image, CvRect rect )计算机网络技术主要学什么
{
if( !image )
CV_Error( CV_HeaderIsNull, "" );
// allow zero ROI width or height
CV_Assert( rect.width >= 0 && rect.height >= 0 &&
rect.x < image->width && rect.y < image->height &&
rect.x + rect.width >= (int)(rect.width > 0) &&
rect.y + rect.height >= (int)(rect.height > 0) );
rect.width += rect.x;
rect.height += rect.y;
rect.x = std::max(rect.x, 0);
rect.y = std::max(rect.y, 0);
rect.width = std::min(rect.width, image->width);汪雨 李钰
rect.height = std::min(rect.height, image->height);
rect.width -= rect.x;
rect.height -= rect.y;
if( image->roi )
{
image->roi->xOffset = rect.x;
image->roi->yOffset = rect.y;
image->roi->width = rect.width;
image->roi->height = rect.height;
}
else
image->roi = icvCreateROI( 0, rect.x, rect.y, rect.width, rect.height );
}
=================
后⾯我使⽤的时候,发现⼀个很奇怪的现象,不知道是不是我使⽤的  opencv2.3.1 版本的问题
ex:
/
/⼈脸区域
CvRect roi = cvRect(r_ret->x * scale, r_ret->y * scale, r_ret->width * scale, r_ret->height * scale );
cvRectangle(img, cvPoint(roi.x , roi.y ), cvPoint( roi.x + roi.width , roi.y + roi.height), CV_RGB(0, 255, 0), 3, 8, 0);  cvSetImageROI(img, roi);
//裁剪出⼈脸图像,灰度图
IplImage* face = cvCreateImage( cvSize(roi.width, roi.height), 8, 1);
cvCopy(img, face);
cvResetImageROI(img);
这样是没问题的、但是下⾯这样,就有问题了:
//⼈脸区域
CvRect roi = cvRect(r_ret->x * scale, r_ret->y * scale, r_ret->width * scale, r_ret->height * scale );
cvRectangle(img, cvPoint(roi.x , roi.y ), cvPoint( roi.x + roi.width , roi.y + roi.height), CV_RGB(0, 255, 0), 3, 8, 0);  //裁剪出⼈脸图像,灰度图
IplImage* face = cvCreateImage( cvSize(roi.width, roi.height), 8, 1);
cvSetImageROI(img, roi);
cvCopy(img, face);
cvResetImageROI(img);
真是奇了怪了, roi区域 ⼜不会改变。。。。。。。。。。