已知alpha通道对原图进行抠图和新背景的合成,基于python

本人自己设计过不少已知alpha通道进行原图抠图的方法,但是都不如人意,今天偶遇一篇文章描述这种问题的解决方法,以此记录下来,非常感谢该作者,文章链接为:https://blog.csdn.net/qianbin3200896/article/details/87934119

我记录该代码本意是给自己的学习做个笔记,侵删

import cv2
import numpy as np

img = cv2.imread("1.jpg")
mask = cv2.imread("2.jpg", 0)  # 读取灰度图像

height, width, channel = img.shape

b, g, r = cv2.split(img)

# -----------------1.获取透明的前景图像-----------
dstt = np.zeros((4, height, width), dtype=img.dtype)

dstt[0][0:height, 0:width] = b
dstt[1][0:height, 0:width] = g
dstt[2][0:height, 0:width] = r
dstt[3][0:height, 0:width] = mask
cv2.imwrite("fore.png", cv2.merge(dstt))

# -----------------2.与新背景图像合成-----------
bg = np.zeros((3, height, width), dtype=img.dtype)  # 生成背景图像
bg[2][0:height, 0:width] = 255  # 背景图像采用红色

dstt = np.zeros((3, height, width), dtype=img.dtype)

for i in range(3):
    dstt[i][:, :] = bg[i][:, :] * (255.0 - mask) / 255
    dstt[i][:, :] += np.array(img[:, :, i] * (mask / 255), dtype=np.uint8)
cv2.imwrite("merge.png", cv2.merge(dstt))

1.jpg
2.jpg

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很好,我理解您的问题。为了完成这个任务,您可以使用OpenCV和Pillow这两个库来完成图片的抠图、修改背景颜色和图片大小的操作。以下是一个简单的Python代码示例,供您参考: ``` import cv2 from PIL import Image # 读取图片 img = cv2.imread("photo.jpg") # 将图片转成灰度图并进行二值化处理 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) _, thresh = cv2.threshold(gray, 0, 255, cv2.THRESH_BINARY_INV + cv2.THRESH_OTSU) # 进行腐蚀和膨胀操作,消除噪点 kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (3, 3)) erosion = cv2.erode(thresh, kernel, iterations=1) dilation = cv2.dilate(erosion, kernel, iterations=1) # 进行轮廓检测 contours, hierarchy = cv2.findContours(dilation, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) # 找到最大轮廓 max_contour = max(contours, key=cv2.contourArea) # 生成掩模图像 mask = cv2.drawContours(np.zeros_like(img), [max_contour], 0, (255, 255, 255), -1) # 抠出图片并保存 result = cv2.bitwise_and(img, mask) cv2.imwrite("foreground.jpg", result) # 修改背景颜色 im = Image.open("foreground.jpg") im = im.convert("RGBA") datas = im.getdata() new_data = [] for item in datas: if item[3] == 0: new_data.append((255, 255, 255, 0)) else: new_data.append((255, 0, 0, item[3])) im.putdata(new_data) im.save("background.jpg") # 修改图片大小 img = cv2.imread("background.jpg") resized_img = cv2.resize(img, (256, 256)) cv2.imwrite("resized.jpg", resized_img) ``` 这个代码示例仅仅是抛砖引玉,您可以根据自己的需求进行更加具体的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值