Opencv实现抠图背景图替换功能


Posted in Python onMay 21, 2019

本文实例为大家分享了Opencv实现抠图替换背景图的具体代码,供大家参考,具体内容如下

下面简单图片演示一下:

提取mask:

Opencv实现抠图背景图替换功能===>Opencv实现抠图背景图替换功能

替换背景:

Opencv实现抠图背景图替换功能 + Opencv实现抠图背景图替换功能=Opencv实现抠图背景图替换功能

python的opencv代码如下:

# coding=utf-8
 
import cv2
import numpy as np
 
img=cv2.imread('lp.jpg')
img_back=cv2.imread('back.jpg')
#日常缩放
rows,cols,channels = img_back.shape
img_back=cv2.resize(img_back,None,fx=0.7,fy=0.7)
cv2.imshow('img_back',img_back)
 
rows,cols,channels = img.shape
img=cv2.resize(img,None,fx=0.4,fy=0.4)
cv2.imshow('img',img)
rows,cols,channels = img.shape#rows,cols最后一定要是前景图片的,后面遍历图片需要用到
 
#转换hsv
hsv=cv2.cvtColor(img,cv2.COLOR_BGR2HSV)
#获取mask
lower_blue=np.array([78,43,46])
upper_blue=np.array([110,255,255])
mask = cv2.inRange(hsv, lower_blue, upper_blue)
cv2.imshow('Mask', mask)
 
#腐蚀膨胀
erode=cv2.erode(mask,None,iterations=1)
cv2.imshow('erode',erode)
dilate=cv2.dilate(erode,None,iterations=1)
cv2.imshow('dilate',dilate)
 
#遍历替换
center=[50,50]#在新背景图片中的位置
for i in range(rows):
 for j in range(cols):
 if dilate[i,j]==0:#0代表黑色的点
  img_back[center[0]+i,center[1]+j]=img[i,j]#此处替换颜色,为BGR通道
cv2.imshow('res',img_back)
 
cv2.waitKey(0)
cv2.destroyAllWindows()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
对python中return和print的一些理解
Aug 18 Python
Python xlwt设置excel单元格字体及格式
Apr 18 Python
浅谈pandas中Dataframe的查询方法([], loc, iloc, at, iat, ix)
Apr 10 Python
分析python请求数据
Aug 19 Python
python实现朴素贝叶斯算法
Nov 19 Python
利用Pyhton中的requests包进行网页访问测试的方法
Dec 26 Python
在python中对变量判断是否为None的三种方法总结
Jan 23 Python
python正则-re的用法详解
Jul 28 Python
Python 函数用法简单示例【定义、参数、返回值、函数嵌套】
Sep 20 Python
Python HTMLTestRunner可视化报告实现过程解析
Apr 10 Python
Python实现Excel自动分组合并单元格
Feb 22 Python
Python使用pyecharts控件绘制图表
Jun 05 Python
python多进程读图提取特征存npy
May 21 #Python
Python中使用pypdf2合并、分割、加密pdf文件的代码详解
May 21 #Python
python+selenium实现简历自动刷新的示例代码
May 20 #Python
图文详解python安装Scrapy框架步骤
May 20 #Python
Python配置虚拟环境图文步骤
May 20 #Python
Python检测数据类型的方法总结
May 20 #Python
Python中的引用知识点总结
May 20 #Python
You might like
php中对2个数组相加的函数
2011/06/24 PHP
PHP pthreads v3下worker和pool的使用方法示例
2020/02/21 PHP
浅析Js中的单引号与双引号问题
2013/11/06 Javascript
js实现仿QQ秀换装效果的方法
2015/03/04 Javascript
JavaScript实现在标题栏上显示当前日期的方法
2015/03/19 Javascript
JS根据key值获取URL中的参数值及把URL的参数转换成json对象
2015/08/26 Javascript
AngularJS基础 ng-cloak 指令简单示例
2016/08/01 Javascript
jQuery实现的导航下拉菜单效果示例
2016/09/05 Javascript
JS对象是否拥有某属性如何判断
2017/02/03 Javascript
Vue.2.0.5过渡效果使用技巧
2017/03/16 Javascript
ES6中的箭头函数实例详解
2017/04/06 Javascript
AngularJS使用ocLazyLoad实现js延迟加载
2017/07/05 Javascript
Layui组件Table绑定行点击事件和获取行数据的方法
2018/08/19 Javascript
基于vue的验证码组件的示例代码
2019/01/22 Javascript
Vue.js中的extend绑定节点并显示的方法
2019/06/20 Javascript
vue cli4.0项目引入typescript的方法
2020/07/17 Javascript
微信小程序开发数据缓存基础知识辨析及运用实例详解
2020/11/06 Javascript
python中zip()方法应用实例分析
2016/04/16 Python
python虚拟环境的安装配置图文教程
2017/10/20 Python
python基于物品协同过滤算法实现代码
2018/05/31 Python
用Python PIL实现几个简单的图片特效
2019/01/18 Python
python连接打印机实现打印文档、图片、pdf文件等功能
2020/02/07 Python
Python reversed反转序列并生成可迭代对象
2020/10/22 Python
python3中celery异步框架简单使用+守护进程方式启动
2021/01/20 Python
会计系毕业个人自荐信格式
2013/09/23 职场文书
新闻专业应届生求职信
2013/10/31 职场文书
论文指导教师评语
2014/04/28 职场文书
优秀教师演讲稿
2014/05/06 职场文书
学生会竞选演讲稿怎么写
2014/08/26 职场文书
党员组织生活会发言材料
2014/10/17 职场文书
2014年员工工作总结范文
2014/11/18 职场文书
2015年征兵工作总结
2015/07/23 职场文书
十一月早安语录:把心放轻,人生就是一朵自在的云
2019/11/04 职场文书
在K8s上部署Redis集群的方法步骤
2021/04/27 Redis
Java使用JMeter进行高并发测试
2021/11/23 Java/Android
redis数据结构之压缩列表
2022/03/21 Redis