Opencv python: seamlessClone泊松融合 (我把Lena变成了彼岸花怪/(ㄒoㄒ)/~~)

2023-10-14 17:20

本文主要是介绍Opencv python: seamlessClone泊松融合 (我把Lena变成了彼岸花怪/(ㄒoㄒ)/~~),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为什么要进行融合呢?原因是LZ在进行贴图操作的时候,经常会出现很明显的边界效应,在各种查找资料的情况下,找到了一种比较适合图像融合的方法,并且OpenCV有对应的接口,所以就网上下了图片,做了一些尝试,当然最后并没有使用这个函数是因为贴图效果太不明显了,LZ甚至以为是自己代码写错了,所以这个函数因人而异。

首先这个函数的用法:

def seamlessClone(src, dst, mask, p, flags, blend=None): # real signature unknown; restored from __doc__"""seamlessClone(src, dst, mask, p, flags[, blend]) -> blend.   @brief Image editing tasks concern either global changes (color/intensity corrections, filters,.   deformations) or local changes concerned to a selection. Here we are interested in achieving local.   changes, ones that are restricted to a region manually selected (ROI), in a seamless and effortless.   manner. The extent of the changes ranges from slight distortions to complete replacement by novel.   content @cite PM03 ..   .   @param src Input 8-bit 3-channel image..   @param dst Input 8-bit 3-channel image..   @param mask Input 8-bit 1 or 3-channel image..   @param p Point in dst image where object is placed..   @param blend Output image with the same size and type as dst..   @param flags Cloning method that could be cv::NORMAL_CLONE, cv::MIXED_CLONE or cv::MONOCHROME_TRANSFER"""pass

NORMAL_CLONE
Python: cv.NORMAL_CLONE
The power of the method is fully expressed when inserting objects with complex outlines into a new background
将具有复杂轮廓的对象插入新背景,也就是说不保留dst 图像的texture细节,目标区域的梯度只由源图像决定。

MIXED_CLONE
Python: cv.MIXED_CLONE

The classic method, color-based selection and alpha masking might be time consuming and often leaves an undesirable halo. Seamless cloning, even averaged with the original image, is not effective. Mixed seamless cloning based on a loose selection proves effective.
基于宽松选择的混合无缝克隆,保留des图像的texture 细节。目标区域的梯度是由原图像和目的图像的组合计算出来(计算dominat gradient)。

MONOCHROME_TRANSFER
Python: cv.MONOCHROME_TRANSFER
Monochrome transfer allows the user to easily replace certain features of one object by alternative features.
不保留src图像的颜色细节,只有src图像的质地,颜色和目标图像一样,可以用来进行皮肤质地填充(美颜是不是可以用呢?)

import cv2 
import numpy as np# read our test imges
img1 = cv2.imread("../test_imgs/lena_standard.jpg")
img2 = cv2.imread("../test_imgs/beiji.jpeg")
cv2.imshow("img1", img1)
cv2.imshow("img2", img2)
cv2.waitKey()
cv2.destroyAllWindows()

在这里插入图片描述
在这里插入图片描述

# create an white mask
mask = 255*np.ones(img1.shape, img1.dtype)
# the location of the src in the dst
width, height, channel = img2.shape
center = (int(height/2), int(width/2))
normal_clone = cv2.seamlessClone(img1, img2, mask, center, cv2.NORMAL_CLONE)
cv2.imshow("normal_clone", normal_clone)
cv2.waitKey()

在这里插入图片描述

mixed_clone = cv2.seamlessClone(img1, img2, mask, center, cv2.MIXED_CLONE)
cv2.imshow("mixed_clone", mixed_clone)
cv2.waitKey()
# cv2.destroyAllWindows()

在这里插入图片描述

mono_clone = cv2.seamlessClone(img1, img2, mask, center, cv2.MONOCHROME_TRANSFER)
cv2.imshow("mono_clone", mono_clone)
cv2.waitKey()
cv2.destroyAllWindows()

在这里插入图片描述
额,测试图片感觉没选好,融合起来感觉哪里怪怪的/(ㄒoㄒ)/~~

#这段代码写的可随意了,就是生成一个mask,做一个融合
img1_gray = cv2.cvtColor(img1, cv2.COLOR_BGR2GRAY)    
ret, binary = cv2.threshold(img1_gray, 100, 255, cv2.THRESH_BINARY | cv2.THRESH_TRIANGLE)contours, _ = cv2.findContours(binary,cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
# print("contour: ", contour)
src_mask = np.zeros(img1.shape, img1.dtype)area = []
want_area = []
for i in range(len(contours)):area.append(cv2.contourArea(contours[i]))
area.sort()
for i in range(len(contours)):if (cv2.contourArea(contours[i]) < area[-1]):cv2.fillConvexPoly(src_mask, contours[i], 0)else:cv2.fillConvexPoly(src_mask, contours[i], (255,255, 255))
test_mask = src_mask[:,:,1]# print("mask_shape: ", mask_new.shape)
normal_clone_bin = cv2.seamlessClone(img1, img2, test_mask, center, cv2.NORMAL_CLONE)cv2.imshow("normal_clone_bin", normal_clone_bin)
cv2.waitKey()
cv2.destroyAllWindows()

在这里插入图片描述

参考地址:

  1. https://www.jianshu.com/p/49adfbe4b804
  2. https://docs.opencv.org/3.4/df/da0/group__photo__clone.html

这篇关于Opencv python: seamlessClone泊松融合 (我把Lena变成了彼岸花怪/(ㄒoㄒ)/~~)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/211972

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

韦季李输入法_输入法和鼠标的深度融合

在数字化输入的新纪元,传统键盘输入方式正悄然进化。以往,面对实体键盘,我们常需目光游离于屏幕与键盘之间,以确认指尖下的精准位置。而屏幕键盘虽直观可见,却常因占据屏幕空间,迫使我们在操作与视野间做出妥协,频繁调整布局以兼顾输入与界面浏览。 幸而,韦季李输入法的横空出世,彻底颠覆了这一现状。它不仅对输入界面进行了革命性的重构,更巧妙地将鼠标这一传统外设融入其中,开创了一种前所未有的交互体验。 想象

opencv 滚动条

参数介绍:createTrackbar( trackbarname , "hello" , &alpha_slider ,alpha_max ,  on_trackbar )  ;在标签中显示的文字(提示滑动条的用途) TrackbarName创建的滑动条要放置窗体的名字 “hello”滑动条的取值范围从 0 到 alpha_max (最小值只能为 zero).滑动后的值存放在

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip