首页 > 代码库 > 对OpenCV中seamlessClone的初步实验
对OpenCV中seamlessClone的初步实验
seamlessClone是OpenCV中新出现的函数,应该说如果能够基于较为准确的图像分割,能够得到很好的结果。
原始的前景,背景
三种flag下的融合结果
//注意头文件中添加 #include <opencv2/photo.hpp>
int main( int argc, const char** argv )
{
Mat src = imread("iloveyoupapa.png");
Mat dst = imread("wood.png");
// Create an all white mask
Mat src_mask = 255 * Mat::ones(src.rows, src.cols, src.depth());
// The location of the center of the src in the dst
Point center(dst.cols/2,dst.rows/2);
// Seamlessly clone src into dst and put the results in output
Mat normal_clone;
Mat mixed_clone;
Mat monochrome_clone;
seamlessClone(src, dst, src_mask, center, normal_clone, NORMAL_CLONE);
seamlessClone(src, dst, src_mask, center, mixed_clone, MIXED_CLONE);
seamlessClone(src, dst, src_mask, center, monochrome_clone, MONOCHROME_TRANSFER);
imshow("normal_clone",normal_clone);
imshow("minxed_clone",mixed_clone);
imshow("monochrome_clone",monochrome_clone);
imshow("wood",dst);
imshow("lovepapa",src);
waitKey();
return 0;
}
{
Mat src = imread("iloveyoupapa.png");
Mat dst = imread("wood.png");
// Create an all white mask
Mat src_mask = 255 * Mat::ones(src.rows, src.cols, src.depth());
// The location of the center of the src in the dst
Point center(dst.cols/2,dst.rows/2);
// Seamlessly clone src into dst and put the results in output
Mat normal_clone;
Mat mixed_clone;
Mat monochrome_clone;
seamlessClone(src, dst, src_mask, center, normal_clone, NORMAL_CLONE);
seamlessClone(src, dst, src_mask, center, mixed_clone, MIXED_CLONE);
seamlessClone(src, dst, src_mask, center, monochrome_clone, MONOCHROME_TRANSFER);
imshow("normal_clone",normal_clone);
imshow("minxed_clone",mixed_clone);
imshow("monochrome_clone",monochrome_clone);
imshow("wood",dst);
imshow("lovepapa",src);
waitKey();
return 0;
}
当然选择这个例子有些讨巧的存在,因为前景为白底红色的文字,这个时候还是比较好进行区分的。同时我还做了一些其他图片的实验。
使用蝴蝶和星空来进行融合
对OpenCV中seamlessClone的初步实验
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。