OpenCV笔记之 图像有效区域复制 image.copyTo()

                     **openCV  image.copyTo()**

1,实现目的
为了实现图像进行等比例的扩张,其中牵涉到一些前提环节。一下对牵涉到的几个关键点一一进行记录。

1,OpenCV中Mat类的图像如何设置ROI区域

(1)使用拷贝构造函数Mat(constMat& m, const Rect& roi ),矩形roi指定了兴趣区

例如:// rows 代表行——Y ;cols 代表列——X
Mat src = imread(“xx.jpg”);
Mat srcROI( src, Rect(0,0,src.cols/2,src.rows/2));

  • 尤其要特别注意:srcROI的数据与源图像src共享存储区,所以此后在srcROI上的操作也会作用在源图像src上。

(2)使用操作符"()",即Mat operator () ( const Rect&roi ) const,矩形roi指定了兴趣区

例如:
Mat src = imread(“xx.jpg”);
Mat srcROI = src(Rect(0,0,src.cols/2,src.rows/2));
srcROI的数据与源图像src共享存储区,所以此后在srcROI上的操作也会作用在源图像src上。

-----------------------------------------------------------建刚分割线----------------------------------------------------------------------------------------------------------------------
2,OPenCv 中image.copyTo()有两种用法
1、image.copyTo(imageROI),作用是把image的内容粘贴到imageROI;

2、image.copyTo(imageROI,mask),作用是把mask和image重叠以后把mask中像素值为0(black)的点对应的image中的点变为透明,而保留其他点。

mask:即掩模。掩模是由0和1组成的一个二进制图像。当在某一功能中应用掩模时,1值区域被处理,被屏蔽的0值区域不被包括在计算中。通过指定的数据值、数据范围、有限或无限值、感兴趣区和注释文件来定义图像掩模,也可以应用上述选项的任意组合作为输入来建立掩模。

例子代码:

#include<opencv2/core/core.hpp>
#include<opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include
using namespace cv;

bool ROI_AddImage()
{
Mat srcImage1 = imread(“102.jpg”); //source的意思
Mat logoImage = imread(“10.png”);

if (!srcImage1.data)
{
	std::cout << "读入图片失败" << std::endl;
	return false;
}
if (!logoImage.data)
{
	std::cout << "读入图片失败" << std::endl;
	return false;
}
Mat imageROI = srcImage1(Rect(0, 0, logoImage.cols, logoImage.rows));
Mat mask = imread("10.png",0);

//logoImage.copyTo(imageROI, mask);   // 第一张效果图,加入了mask,  因为公用了roi 所以 会logoImage 写入ROI 导致了 srcImage 直接发生变化
logoImage.copyTo(imageROI);                //第二张效果图

namedWindow("效果图");
imshow("效果图", srcImage1);

}
void main()
{
ROI_AddImage();
waitKey();
}

第一张效果图:
在这里插入图片描述
第二张效果图:
在这里插入图片描述

3,实现将图像变成固定比例,多余的部分填充为黑色

此功能针对油画家系统是一个核心功能模块之一。需要进行详细说明。

例子代码:

核心段:

using namespace std;
using namespace cv;

Mat getROIimage(Mat srcimg,string file);
string Dir_path = “C:\Users\lcg\Desktop\cut\JPEGImages\”;

int main(int argc, char argv[])
{
Directory dir;
string newfilename;
vector fileNames = dir.GetListFiles(Dir_path, "
.jpg", false);
for (int i = 0; i < fileNames.size(); i++)
{
string fileName = fileNames[i];
string filefullname;
string xmlname;
newfilename = Dir_path + “size\”+“5-3-” + fileName;
filefullname = Dir_path + fileName;
Mat srcImg = imread(filefullname);
Mat desimg = getROIimage(srcImg,filefullname);
imwrite(newfilename, desimg);
//waitKey(0);
}

}

--------------------------------------------------建刚分割线,下面是核心代码------------------------------------------------------------------------------
Mat getROIimage(Mat srcimg,string file)
{
int width=0;
int height=0;
if (3 * srcimg.rows <= 5 * srcimg.cols) // 此情况表明: X长度足够,需要对Y进行补充
{
width = srcimg.cols;
height = 5 * srcimg.cols / 3;
}
else // 此情况表明: Y长度足够,需要对X进行补充
{
height = srcimg.rows;
width = 3 * srcimg.rows / 5;
}

Mat desImg(height, width, CV_8UC3, Scalar(0,0,0));                      //创建一个全黑的图片,长宽按照3:5 的全黑的图片
Mat imageROI;
imageROI = desImg(Rect(0, 0, srcimg.cols, srcimg.rows));               //图1 最外围的轮廓效果
Mat mask = imread(file, 0);                                                                 //第二个参数,表明读取的是灰度图。但是我们自己要分清楚,我们此处需要加入是原图,不需要过滤。针对自己的项目,第二个参数设置为1即可。
srcimg.copyTo(imageROI, mask);
return desImg;

}
在 图1:   填充效果图通过此图进行演示效果 这里插入图片描述

4,图像的缩放

resize(image, image, Size(image.cols * 0.99, image.rows *0.99), 0, 0, INTER_LINEAR);

以上0.99 是倍数,后续需要进行人为设置修改iain
其中src和dst我这边使用Mat类型的图像,0.99是系数,fx和 fy都为0,用默认的线性插值。

  • 1
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值