PNG透明图片叠加(Opencv实现,包括旋转缩放以及边界处理)

叠加效果

PNG透明图片叠加(Opencv实现,包括旋转缩放以及边界处理)_第1张图片

原图

PNG透明图片叠加(Opencv实现,包括旋转缩放以及边界处理)_第2张图片

叠加图片

PNG透明图片叠加(Opencv实现,包括旋转缩放以及边界处理)_第3张图片


大致实现了一个四通道的PNG矢量图叠加到一个三通道的图片上,函数如下:

bool 叠加(cv::Mat &dst, cv::Mat &src,
double scale = 1.0, //整体透明度
double size = 1.0,//图片缩放比例
double angle = 0,//图片旋转角度
cv::Point location = cv::Point(0, 0)//图片位置
)



使用示例

#include   
#include "叠加.h" 
using namespace cv;
int main()
{
	Mat img1 = imread("timg.jpg"), img2 = imread("img.png", -1);
	imshow("原图", img1);
	叠加(img1, img2,1,0.4,45,Point(160,220));
	imshow("叠加元素", img2);
	imshow("组合图", img1);
	waitKey(0);
	return 0;
}




头文件

叠加.h

#pragma once
#include   
#include   
//#include

bool 叠加(cv::Mat &dst, cv::Mat &src,
	double scale = 1.0, //整体透明度
	double size = 1.0,//图片缩放比例
	double angle = 0,//图片旋转角度
	cv::Point location = cv::Point(0, 0)//图片位置

)
{
	if (dst.channels() != 3 || src.channels() != 4 || location.x>dst.cols || location.y>dst.cols)
	{
		return false;
	}


	cv::Mat small_size = src.clone();

	if (size != 1 || angle != 0) {
		int width = src.cols>(dst.cols - location.x) ? (dst.cols - location.x) : src.cols;
		int length = src.rows>(dst.rows - location.y) ? (dst.rows - location.y) : src.rows;
		cv::Mat rotation = cv::getRotationMatrix2D(cv::Point2f(length / 2, width / 2), angle, size);
		cv::warpAffine(small_size, small_size, rotation, cv::Size(width, length));
	}
	//imshow("test", small_size);
	//std::cout << small_size.cols << " " << small_size.rows << std::endl;
	cv::Mat dst_part(dst, cv::Rect(location.x, location.y, small_size.cols, small_size.rows));

	std::vectorsrc_channels;
	std::vectordst_channels;
	split(small_size, src_channels);
	split(dst_part, dst_channels);
	//	CV_Assert(src_channels.size() == 4 && dst_channels.size() == 3);

	if (scale < 1)
	{
		src_channels[3] *= scale;
		scale = 1;
	}
	for (int i = 0; i < 3; i++)
	{
		dst_channels[i] = dst_channels[i].mul(255.0 / scale - src_channels[3], scale / 255.0);
		dst_channels[i] += src_channels[i].mul(src_channels[3], scale / 255.0);
	}
	merge(dst_channels, dst_part);
	return true;
}


整体打包见地址

提前狗年祝元宵节快乐,233




你可能感兴趣的:(opencv)