cvCopy使用的时候,大家可能不想考虑第三个参数.实际上第三个参数就是根据mask相应的位置,如果是1,就拷贝图象这个位置的象素,否则就不拷贝.所以mask二维数组的大小和src的大小应该相等.在cvCopy的原程序也验证了.
if( !CV_ARE_SIZES_EQ( src, mask ))
CV_ERROR( CV_StsUnmatchedSizes, "" );
mask也可以是IplImage格式.
IplImage *mask=cvCreateImage(cvSize(width,height),8,1);
cvZero(mask);
cvCopy(src,dst,mask);
需要注意src,dst和mask必须是一样的大小,否则出错
下面写了一个简单的小例子程序.将融合图象的白色就不要进行象素拷贝
void cvMaskCopy(char *srcImgPath,char *rhImgPath,CvRect rect)
{
int i,j,m,n;
CvScalar bl1;
IplImage *rhImg=cvLoadImage(rhImgPath,1);//luhui 2009-10-29
m=rhImg->width;
n=rhImg->height;
CvMat *mask=cvCreateMat(n,m,CV_8UC1);
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
bl1=cvGet2D(rhImg,j,i);
if(bl1.val[2]==255
&& bl1.val[1]==255
&& bl1.val[0]==255)
{
cvSetReal2D(mask,j,i,0);
}
else
{
cvSetReal2D(mask,j,i,1);
}
}
}
IplImage *oldImage=cvLoadImage(srcImgPath,1);//luhui 2009-10-29
CvRect cvRectTmp=rect;
cvSetImageROI(oldImage,cvRectTmp);
cvCopy(rhImg,oldImage,mask);
cvResetImageROI(oldImage);
cvReleaseImage(&oldImage);
cvReleaseImage(&rhImg);
}