首页 > Opencv 图像叠加 添加水印

Opencv 图像叠加 添加水印

C++: void Mat::copyTo(OutputArray m) constC++: void Mat::copyTo(OutputArray m, InputArray mask) const这个函数可以复制图像到另一个图像或矩阵上,可选参数是掩码由于叠加的图像大小不一定相等,比如我们这里把一张小照片加到一张大照片上我们可以在大照片上设置一个和小照片一样大的感兴趣区域不使用掩码的时候,我们载入一张png,和一张jpg
#include 

#include



int main(){

cv::Mat image = cv::imread("E:/Image/Fruits.jpg");

cv::Mat logo = cv::imread("E:/logo.png");

cv::Mat imageROI;

imageROI = image(cv::Rect(10,10,logo.cols,logo.rows));

logo.copyTo(imageROI);

cv::namedWindow("result");

cv::imshow("result",image);

cv::waitKey();

return 0;

}

原先在png里面是透明的地方,现在成了黑色,可见原来是透明的地方被认为是值0。我们使用掩码来看看效果,掩码就使用png图片,掩码只能是一个通道的,我们载入灰度图像作为掩码
#include 

#include



int main(){

cv::Mat image = cv::imread("E:/Image/Fruits.jpg");

cv::Mat logo = cv::imread("E:/logo.png");

cv::Mat mask = cv::imread("E:/logo.png",0);

cv::Mat imageROI;

imageROI = image(cv::Rect(10,10,logo.cols,logo.rows));

logo.copyTo(imageROI,mask);

cv::namedWindow("result");

cv::imshow("result",image);

cv::waitKey();

return 0;

}

这样能看出差别了吧。再来看看另一个函数C++: void addWeighted(InputArray src1, double alpha, InputArray src2, double beta, double gamma, OutputArray dst, int dtype=-1)转换成数学表达式就是

#include 

#include



int main(){

cv::Mat image = cv::imread("E:/Image/Fruits.jpg");

cv::Mat logo = cv::imread("E:/logo.png");

cv::Mat imageROI;

imageROI = image(cv::Rect(10,10,logo.cols,logo.rows));

cv::addWeighted(imageROI, 1.0, logo, 0.3, 0, imageROI);

cv::namedWindow("result");

cv::imshow("result",image);

cv::waitKey();

return 0;

}

 

更多相关:

  • 论文阅读模块将分享点云处理,SLAM,三维视觉,高精地图相关的文章。公众号致力于理解三维视觉领域相关内容的干货分享,欢迎各位加入我,我们一起每天一篇文章阅读,开启分享之旅,有兴趣的可联系微信[email protected]。opencv中ArUco模块实践(1)ArUco的生成与检测ArUco与AprilTag简介ChAruco...

  • 在x y的梯度上再求一次导数后相加便是散度。注意不要使用convertScaleAbs int main(int argc, char*argv[]) {cv::Mat IMG = cv::imread("./img.jpg", 1);cv::Mat k = getStructuringElement(cv::MORPH_RECT,...

  • 算法是基于A Fast Parallel Algorithm for Thinning Digital Patterns论文 https://blog.csdn.net/keneyr/article/details/88944563 简单的解释算法: https://blog.csdn.net/xukaiwen_2016...

  • 第一行是提取有效区域后的鱼眼图;第二行就是展开图(第二张和第四张根据需要裁剪了一部分) #include #include "opencv2/highgui/highgui.hpp" #include "opencv2/opencv.hpp" #include

  • cv::Mat inputIMG = cv::imread("./input/src.jpg", 1);cv::Mat graySrc, grad_x, grad_y;cv::Mat abs_grad_x, abs_grad_y;cv::cvtColor(inputIMG, graySrc, cv::COLOR_BGR2GRAY);...

  • 论文阅读模块将分享点云处理,SLAM,三维视觉,高精地图相关的文章。公众号致力于理解三维视觉领域相关内容的干货分享,欢迎各位加入我,我们一起每天一篇文章阅读,开启分享之旅,有兴趣的可联系微信[email protected]。单应矩阵介绍单应性在计算机视觉领域是一个非常重要的概念,它在图像校正、图像拼接、俯视图生成,相机位姿估计、...