Opencv C++ 圖像混合(貼圖)

原始圖片下載地址:
鏈接:https://pan.baidu.com/s/1fmTNu324_K1D2rGLCmR_RQ
提取碼:jap1

#include <opencv2/core.hpp>
#include <opencv2/highgui.hpp>
#include <opencv2/imgproc.hpp>
#include <iostream>

using namespace cv;
using namespace std;


//圖片混合
bool MixImage(Mat& srcImage, Mat mixImage, Point startPoint)
{
	//檢查圖片數據
	if (!srcImage.data || !mixImage.data)
	{
		cout << "輸入圖片 數據錯誤!" << endl ;
		return false;
	}
	//檢查行列是否越界
	int addCols = startPoint.x + mixImage.cols > srcImage.cols ? 0 : mixImage.cols;
	int addRows = startPoint.y + mixImage.rows > srcImage.rows ? 0 : mixImage.rows;
	if (addCols ==0 || addRows ==0)
	{
		cout << "添加圖片超出" << endl;
		return false;
	}

	//ROI 混合區域
	Mat roiImage = srcImage(Rect(startPoint.x, startPoint.y, addCols, addRows));

	//圖片類型一致
	if (srcImage.type() == mixImage.type())
	{
		mixImage.copyTo(roiImage, mixImage);
		return true;
	}

	Mat maskImage;
	//原始圖片:灰度  貼圖:彩色
	if (srcImage.type() == CV_8U && mixImage.type() == CV_8UC3)
	{
		cvtColor(mixImage, maskImage, COLOR_BGR2GRAY);
		maskImage.copyTo(roiImage, maskImage);
		return true;
	}

	//原始圖片:彩色  貼圖:灰色
	if (srcImage.type() == CV_8UC3 && mixImage.type() == CV_8U)
	{
		cvtColor(mixImage, maskImage, COLOR_GRAY2BGR);
		maskImage.copyTo(roiImage, maskImage);
		return true;
	}

	return false;
}

int main()
{ 
	//1、讀取圖片;
	Mat srcImage = imread("../Data/dota_pa.jpg");
	Mat logoImage = imread("../Data/dota_logo.jpg");

	cout << "原圖 通道數: " << srcImage.channels() << "  類型:"<< srcImage.type() << endl;
	cout << "logo 通道數: " << logoImage.channels() << "  類型:" << logoImage.type() << endl;

	//2、實現貼圖
	MixImage(srcImage, logoImage, Point(200, 250));

	//3、顯示圖片
	imshow("srcImage", srcImage);
	waitKey(0);
	destroyAllWindows();

	return 1;
}

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章