OpenCV中的ROI问题

修改ROI像素值

#include<iostream>
#include<opencv2/opencv.hpp>


int main()
{
    
    
	cv::Mat img = cv::Mat::zeros(cv::Size(640, 480), CV_8U);
	cv::Mat roi = img(cv::Rect(100, 100, 100, 100));
	for (size_t i = 0; i < roi.rows; i++)
	{
    
    
		for (size_t j = 0; j < roi.cols; j++)
		{
    
    
			roi.at<uchar>(i, j) = 255;
		}
	}

	cv::imwrite("img.png", img);
	cv::imwrite("roi.png", roi);
	return 0;
}

运行结果:(修改原图像素值)在这里插入图片描述

#include<iostream>
#include<opencv2/opencv.hpp>


int main()
{
    
    
	cv::Mat img = cv::Mat::zeros(cv::Size(640, 480), CV_8U);
	cv::Mat roi = img(cv::Rect(100, 100, 100, 100)).clone();
	for (size_t i = 0; i < roi.rows; i++)
	{
    
    
		for (size_t j = 0; j < roi.cols; j++)
		{
    
    
			roi.at<uchar>(i, j) = 255;
		}
	}

	cv::imwrite("img.png", img);
	cv::imwrite("roi.png", roi);
	return 0;
}

运行结果:(不修改原图像素值)在这里插入图片描述

替换ROI内容

#include<iostream>
#include<opencv2/opencv.hpp>


int main()
{
    
    
	cv::Mat img = cv::Mat::zeros(cv::Size(640, 480), CV_8U);
	cv::Mat roi = img(cv::Rect(100, 100, 100, 100));
	cv::Mat fill = cv::Mat(cv::Size(100, 100), CV_8U, cv::Scalar::all(255));
	fill.copyTo(roi);

	cv::imwrite("img.png", img);
	cv::imwrite("roi.png", roi);
	return 0;
}

运行结果:(修改原图像素值)在这里插入图片描述

#include<iostream>
#include<opencv2/opencv.hpp>


int main()
{
    
    
	cv::Mat img = cv::Mat::zeros(cv::Size(640, 480), CV_8U);
	cv::Mat roi = img(cv::Rect(100, 100, 100, 100)).clone();
	cv::Mat fill = cv::Mat(cv::Size(100, 100), CV_8U, cv::Scalar::all(255));
	fill.copyTo(roi);

	cv::imwrite("img.png", img);
	cv::imwrite("roi.png", roi);
	return 0;
}

运行结果:(不修改原图像素值)在这里插入图片描述
总结:

cv::Mat img1;
cv::Mat img2 = img1;

赋值运算符,只是将img2 指向img1(修改img2 的时候会同时改变img1)。

cv::Mat img1;
cv::Mat img2 = img1.clone();

img2 会重新分配内存,内容为img1(修改img2 的时候不改变img1)。

cv::Mat img1, img2;
img1.copyTo(img2);

当img1和img2具有相同的类型和大小时,只拷贝数据,内存地址不变。

猜你喜欢

转载自blog.csdn.net/taifyang/article/details/129774792
今日推荐