gan通过python实现_python大展身手带你通过罩层对彩图进行二值化操作,实现抠图与图像拼接...

概要

通过python带大家通过罩层对彩图进行二值化操作,最终实现抠图与图像拼接的功能。

关键字:罩层 MASK 二值化 抠图

最终抠图效果:

f99ba82765a8061f9606763e1fa8d820.png

通过罩层对彩图进行二值化操作,实现抠图与图像拼接

  • 概要
  • 图像二值化
  • 数学形态学处理
  • 筛选连通域
  • 抠图-带罩层的二值化与操作
  • 换背景颜色
  • 图片合并 cv2.add
  • 高斯模糊

图像二值化

import cv2

# 载入原图
img = cv2.imread('cat.jpeg')

from matplotlib import pyplot as plt

# 展示图像
plt.imshow(img[:, :, ::-1])

9a6c868d0a5791f842864020be2149e4.png
# 图像二值化
img_bin = cv2.inRange(img, lowerb=(9, 16, 84), upperb=(255, 251, 255))

plt.imshow(img_bin, cmap='gray')

bb08ef0f3e776e631e5a95a41d13e9fb.png

数学形态学处理

# 数学形态学预处理
import numpy as np
kernel = np.ones((5,5), np.uint8)
img_bin = cv2.erode(img_bin, kernel, iterations=1)
img_bin = cv2.dilate(img_bin, kernel, iterations=2)
plt.imshow(img_bin, cmap='gray')

c89d53b792e218b5b17821efaa3b82ea.png

筛选连通域

# 过滤掉小的contours
# 获取边缘信息
_, contours, hierarchy = cv2.findContours(image=img_bin,mode=cv2.RETR_EXTERNAL, method=cv2.CHAIN_APPROX_SIMPLE)


def contours_area(cnt):
    # 计算countour的面积
    (x, y, w, h) = cv2.boundingRect(cnt)
    return w * h

# 获取面积最大的contour
max_cnt = max(contours, key=lambda cnt: contours_area(cnt))
# 创建空白画布
mask = np.zeros_like(img_bin)
# 获取面积最大的 contours
mask = cv2.drawContours(mask,[max_cnt],0,255,-1)
# 打印罩层
plt.imshow(mask, cmap='gray')

99b2f60c190eeb25b861a046b169b231.png

抠图-带罩层的二值化与操作

img跟它本身进行或/与操作(其实他们的结果是一样的) 在罩层区域(MASK)内进行。罩层区域为0, 黑色

二值化操作就是 如果两个img的该点的像素点都不为零则保留原来的取值,否则就是黑色

# 使用罩层对原来的图像进行抠图
sub_img = cv2.bitwise_or(img,img,mask=mask)
# sub_img = cv2.bitwise_and(img,img,mask=mask)

plt.imshow(sub_img[:,:,::-1])

86e00fefce3d935be2babd2fcfd91dd9.png

哇, 大白猫就抠出来了,是不是很惊艳!!!!!

换背景颜色

# 给大白猫换个背景
background = np.zeros_like(img)
background[:,:,:]  = (150, 198, 12)
plt.imshow(background[:,:,::-1])

3a21a12288d7db476a90b4988ef50686.png
# 获取新的背景
new_background = cv2.bitwise_or(background, background, mask=cv2.bitwise_not(mask))
plt.imshow(new_background[:,:,::-1])

afec1b53151060015d73889914bca709.png

图片合并 cv2.add

new_img = cv2.add(new_background, sub_img)
plt.imshow(new_img[:,:,::-1])

690c25f6a4e14499d8771f39dd30fbf9.png

高斯模糊

拼接感太强,做一下高斯模糊

# 用5*5的kernel进行高斯模糊
new_img_blur = cv2.GaussianBlur(new_img, (9,9), 5)
plt.imshow(new_img_blur[:,:,::-1])

faf781d24faca7f4d1a0844c3e038e53.png

a6e0ae988e826fe4f6827383fcc1d15e.png

原文链接:

python大展身手带你通过罩层对彩图进行二值化操作,实现抠图与图像拼接_ywsydwsbn的博客-CSDN博客_python 以二值化区域抠图​blog.csdn.net
2a636e0cddd0b2d43c657c9f5fcf3cc7.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值