栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

Alpha融合 Python-OpenCV

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Alpha融合 Python-OpenCV

import numpy as np
import cv2

def paste_ROI_to_image(img1, img2, area):
    image1 = img1.copy()

    #改变尺寸
    # y1, x1, y2, x2 = area
    # img2 = cv2.resize(img2, (x2 - x1 + 1, y2 - y1 + 1))  # cv.resize(src, dsize=(width, height))

    image1 = image1.astype(np.float)  # 类型转换为np.float
    img2 = img2.astype(np.float)
    # alpha通道
    # alpha_image1 = image1[y1:y2 + 1, x1:x2 + 1, 3] / 255.0 #特定区域
    alpha_image1 = image1[:, :, 3] / 255.0 #整景影像
    alpha_img2 = img2[:, :, 3] / 255.0
    alpha = 1 - (1 - alpha_image1) * (1 - alpha_img2)
    # BGR通道
    for i in range(3):
        # image1[y1:y2 + 1, x1:x2 + 1, i] = (image1[y1:y2 + 1, x1:x2 + 1, i] * alpha_image1 * (1 - alpha_img2) + img2[:, :, i] * alpha_img2) / alpha     #放到特定位置                                                                                             
        image1[:, :, i] = (image1[:, :, i] * alpha_image1 * (1 - alpha_img2) + img2[:, :, i] * alpha_img2) / alpha
    image1[:, :, 3] = alpha * 255
    image = image1.astype(np.uint8)
    return image


if __name__ == "__main__":
    image1 = cv2.imread("cut\1.png", cv2.IMREAD_UNCHANGED)
    image2 = cv2.imread("cut\2.png", cv2.IMREAD_UNCHANGED)
    image = paste_ROI_to_image(image1, image2, [0, 0, 255, 255])
    cv2.imwrite("cut\3.png", image)

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/357597.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号