python(opencv2、PIL)将图片透明背景转换成白色背景的两种方法

方法一:使用OpenCV的函数封装

pip install opencv-python

import cv2
import numpy as np

def convert_transparent_to_white_opencv(input_image_path, output_image_path):
    """
    将透明背景的图片转换为白色背景,使用OpenCV实现。

    参数:
    input_image_path: str,输入图片的路径
    output_image_path: str,输出图片的路径

    返回:
    无
    """
    # 读取带透明背景的图片(假设图片是PNG格式)
    img = cv2.imread(input_image_path, cv2.IMREAD_UNCHANGED)

    # 检查是否读取成功
    if img is None:
        raise ValueError(f"Image at path {input_image_path} could not be read.")

    # 分离RGBA通道
    b, g, r, a = cv2.split(img)

    # 创建一个与Alpha通道大小相同的全白背景
    white_background = np.ones_like(a) * 255

    # 将Alpha通道归一化到0-1范围
    a = a / 255.0

    # 按照Alpha通道的透明度混合原图和白色背景
    r = r * a + white_background * (1 - a)
    g = g * a + white_background * (1 - a)
    b = b * a + white_background * (1 - a)

    # 合并BGR通道
    result = cv2.merge((b, g, r))

    # 保存处理后的图片
    cv2.imwrite(output_image_path, result)

# 示例调用
convert_transparent_to_white_opencv('input_image.png', 'output_image_opencv.png')

方法二:使用PIL的函数封装

pip install pillow

from PIL import Image

def convert_transparent_to_white_pil(input_image_path, output_image_path):
    """
    将透明背景的图片转换为白色背景,使用PIL实现。

    参数:
    input_image_path: str,输入图片的路径
    output_image_path: str,输出图片的路径

    返回:
    无
    """
    # 读取带透明背景的图片(假设图片是PNG格式)
    img = Image.open(input_image_path).convert("RGBA")

    # 创建一个与原图片大小相同的白色背景
    white_background = Image.new("RGB", img.size, (255, 255, 255))

    # 将原图片粘贴到白色背景上,并使用Alpha通道作为掩码
    white_background.paste(img, (0, 0), img)

    # 保存处理后的图片
    white_background.save(output_image_path)

# 示例调用
convert_transparent_to_white_pil('input_image.png', 'output_image_pil.png')

详细解释

OpenCV方法函数封装

  1. 函数定义:定义一个函数convert_transparent_to_white_opencv,接受输入图片路径和输出图片路径作为参数。
  2. 读取图片:在函数内部使用cv2.imread()读取图片,并进行透明通道处理。
  3. 图像处理:按之前的步骤进行通道分离、创建白色背景、图像合成。
  4. 保存图片:将处理后的图片保存到指定路径。

PIL方法函数封装

  1. 函数定义:定义一个函数convert_transparent_to_white_pil,接受输入图片路径和输出图片路径作为参数。
  2. 读取图片:在函数内部使用Image.open()读取图片,并进行透明通道处理。
  3. 图像粘贴:按之前的步骤创建白色背景,将原图粘贴到白色背景上。
  4. 保存图片:将处理后的图片保存到指定路径。

通过上述封装函数,可以更方便地将带透明背景的图片转换为白色背景的图片。


可以将带透明背景的图片转换为任意颜色背景的图片,并在任意颜色背景之间进行转换。以下是使用OpenCV和PIL的方法,并进行了函数封装,允许用户指定任意背景颜色。

1, 使用OpenCV的函数封装

import cv2
import numpy as np

def convert_transparent_to_color_opencv(input_image_path, output_image_path, bg_color=(255, 255, 255)):
    """
    将透明背景的图片转换为任意颜色背景,使用OpenCV实现。

    参数:
    input_image_path: str,输入图片的路径
    output_image_path: str,输出图片的路径
    bg_color: tuple,背景颜色(默认为白色 (255, 255, 255))

    返回:
    无
    """
    # 读取带透明背景的图片(假设图片是PNG格式)
    img = cv2.imread(input_image_path, cv2.IMREAD_UNCHANGED)

    # 检查是否读取成功
    if img is None:
        raise ValueError(f"Image at path {input_image_path} could not be read.")

    # 分离RGBA通道
    b, g, r, a = cv2.split(img)

    # 创建一个与Alpha通道大小相同的指定颜色背景
    background = np.ones_like(a) * np.array(bg_color[::-1], dtype=np.uint8)[:, None, None]

    # 将Alpha通道归一化到0-1范围
    a = a / 255.0

    # 按照Alpha通道的透明度混合原图和背景
    r = r * a + background[0] * (1 - a)
    g = g * a + background[1] * (1 - a)
    b = b * a + background[2] * (1 - a)

    # 合并BGR通道
    result = cv2.merge((b, g, r))

    # 保存处理后的图片
    cv2.imwrite(output_image_path, result)

# 示例调用
convert_transparent_to_color_opencv('input_image.png', 'output_image_opencv.png', bg_color=(0, 128, 255))

2, 使用PIL的函数封装

from PIL import Image

def convert_transparent_to_color_pil(input_image_path, output_image_path, bg_color=(255, 255, 255)):
    """
    将透明背景的图片转换为任意颜色背景,使用PIL实现。

    参数:
    input_image_path: str,输入图片的路径
    output_image_path: str,输出图片的路径
    bg_color: tuple,背景颜色(默认为白色 (255, 255, 255))

    返回:
    无
    """
    # 读取带透明背景的图片(假设图片是PNG格式)
    img = Image.open(input_image_path).convert("RGBA")

    # 创建一个与原图片大小相同的指定颜色背景图像
    background = Image.new("RGB", img.size, bg_color)

    # 将原图片粘贴到指定颜色背景上,并使用透明度作为掩码
    background.paste(img, (0, 0), img)

    # 保存处理后的图片
    background.save(output_image_path)

# 示例调用
convert_transparent_to_color_pil('input_image.png', 'output_image_pil.png', bg_color=(0, 128, 255))

详细解释
OpenCV方法函数封装
  1. 函数定义:定义一个函数convert_transparent_to_color_opencv,接受输入图片路径、输出图片路径和背景颜色作为参数。
  2. 读取图片:在函数内部使用cv2.imread()读取带有透明背景的图片,并进行透明通道处理。
  3. 检查是否读取成功:确保图片成功读取,否则抛出异常。
  4. 分离RGBA通道:使用cv2.split()将图片分离为四个通道(RGBA)。
  5. 创建背景:创建一个与Alpha通道大小相同的指定颜色背景,颜色转换为BGR顺序以符合OpenCV的颜色顺序。
  6. 图像合成:将Alpha通道归一化到0-1范围,并按照Alpha通道的透明度混合原图和背景。
  7. 合并通道并保存图片:合并BGR通道,并保存处理后的图片。
PIL方法函数封装
  1. 函数定义:定义一个函数convert_transparent_to_color_pil,接受输入图片路径、输出图片路径和背景颜色作为参数。
  2. 读取图片:在函数内部使用Image.open()读取带有透明背景的图片,并转换为RGBA模式。
  3. 创建背景:创建一个与原图片大小相同的指定颜色背景图像。
  4. 图像粘贴:使用paste()方法将原图粘贴到背景上,并使用透明度作为掩码。
  5. 保存图片:保存处理后的图片。

这两种方法都可以将透明背景转换为任意颜色背景,并支持在任意颜色背景之间进行转换。可以根据具体需求选择合适的工具和方法。


使用OpenCV将图片透明背景添加稍微大一点的白色背景

import cv2
import numpy as np

def add_white_background_with_padding_opencv(input_image_path, output_image_path, padding=10):
    """
    将透明背景的图片转换为带有稍微大一点的白色背景的图片,使用OpenCV实现。

    参数:
    input_image_path: str,输入图片的路径
    output_image_path: str,输出图片的路径
    padding: int,背景的扩展大小(默认为10像素)

    返回:
    无
    """
    # 读取带透明背景的图片(假设图片是PNG格式)
    img = cv2.imread(input_image_path, cv2.IMREAD_UNCHANGED)

    # 检查是否读取成功
    if img is None:
        raise ValueError(f"Image at path {input_image_path} could not be read.")

    # 分离RGBA通道
    b, g, r, a = cv2.split(img)

    # 获取原图片的尺寸
    height, width = a.shape

    # 创建一个稍微大一点的白色背景
    new_height = height + 2 * padding
    new_width = width + 2 * padding
    white_background = np.ones((new_height, new_width, 3), dtype=np.uint8) * 255

    # 将Alpha通道归一化到0-1范围
    a = a / 255.0

    # 创建一个新的RGBA图像并将原图像放到中央
    result = np.zeros((new_height, new_width, 3), dtype=np.uint8)
    for c in range(3):
        result[padding:padding + height, padding:padding + width, c] = img[:, :, c] * a + white_background[padding:padding + height, padding:padding + width, c] * (1 - a)

    # 保存处理后的图片
    cv2.imwrite(output_image_path, result)

# 示例调用
add_white_background_with_padding_opencv('input_image.png', 'output_image_with_padding.png', padding=20)

详细解释
  1. 函数定义:定义一个函数add_white_background_with_padding_opencv,接受输入图片路径、输出图片路径和背景扩展大小作为参数。
  2. 读取图片:使用cv2.imread()读取带有透明背景的图片,并指定cv2.IMREAD_UNCHANGED以确保读取透明通道(Alpha通道)。
  3. 检查是否读取成功:确保图片成功读取,否则抛出异常。
  4. 分离RGBA通道:使用cv2.split()将图片分离为四个通道(RGBA)。
  5. 获取原图片尺寸:获取原图片的高度和宽度。
  6. 创建白色背景:创建一个稍微大一点的白色背景,背景大小为原图片大小加上两倍的扩展大小。
  7. 将Alpha通道归一化:将Alpha通道的值归一化到0-1范围。
  8. 图像合成:创建一个新的图像,并将原图像放到中央,同时根据Alpha通道的透明度混合原图和白色背景。
  9. 保存处理后的图片:将处理后的图片保存到指定路径。

通过这种方法,可以将带透明背景的图片转换为带有稍微大一点白色背景的图片。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/785126.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【沐风老师】3DMAX建筑体块生成插件BuildingBlocks使用方法详解

BuildingBlocks建筑体块生成插件使用方法详解 听说你还在手动建配景楼?有了BuildingBlocks这个插件,一分钟搞定喔! 3DMAX建筑体块生成插件BuildingBlocks,用于快速自定义街道及生成配景楼区块。 【适用版本】 3dMax2019及更高版…

鸿蒙语言基础类库:【@ohos.process (获取进程相关的信息)】

获取进程相关的信息 说明: 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。开发前请熟悉鸿蒙开发指导文档:gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md点击或者复制转到。…

【专项刷题】— 位运算

常见类型介绍: & :有 0 就是 0 | :有 1 就是 1 ^ :相同为 0 ,相异为 1 或者 无进位相加给定一个数确定它的二进制位的第x个数是0还是1:将一个数的二进制的第x位改成1:将一个数的二进制的第x…

无人机在交通管理方面的应用与潜力

随着智能化和数字化技术的发展,无人机已经成为智慧交通管理体系中的重要一环。无人机能够搭载各种专业设备,如超清摄像头、红外热成像摄像头、目标跟踪器等,从而完成多任务的数据采集和快速机动的任务执行。这些数据通过无线传输实时回传&…

RxJava学习记录

文章目录 1. 总览1.1 基本原理1.2 导入包和依赖 2. 操作符2.1 创建操作符2.2 转换操作符2.3 组合操作符2.4 功能操作符 1. 总览 1.1 基本原理 参考文献 构建流:每一步操作都会生成一个新的Observable节点(没错,包括ObserveOn和SubscribeOn线程变换操作…

YOLOv10改进 | 主干篇 | 低照度增强网络PE-YOLO改进主干(改进暗光条件下的物体检测模型)

一、本文介绍 本文给大家带来的改进机制是低照度图像增强网络PE-YOLO中的PENet,PENet通过拉普拉斯金字塔将图像分解成多个分辨率的组件,增强图像细节和低频信息。它包括一个细节处理模块(DPM),用于通过上下文分支和边…

【安全设备】日志审计

一、什么是日志审计 日志审计是一站式的日志数据管理平台,主要致力于提供事前预警、事后审计的安全能力, 通过对日志数据的全面采集、解析和深度的关联分析,及时发现各种安全威胁和异常行为事件。日志审计是指通过集中采集信息系统中的各类信…

Chain-of-Verification Reduces Hallucination in Lagrge Language Models阅读笔记

来来来,继续读文章了,今天这个是meta的研究员们做的一个关于如何减少LLM得出幻觉信息的工作,23年底发表。文章链接:https://arxiv.org/abs/2309.11495 首先,这个工作所面向的LLM的问答任务,是list-based q…

怎样优化 PostgreSQL 中对日期时间范围的模糊查询?

文章目录 一、问题分析(一)索引未有效利用(二)日期时间格式不统一(三)复杂的查询条件 二、优化策略(一)使用合适的索引(二)规范日期时间格式(三&a…

前沿重器[53] | 聊聊搜索系统6:精排

前沿重器 栏目主要给大家分享各种大厂、顶会的论文和分享,从中抽取关键精华的部分和大家分享,和大家一起把握前沿技术。具体介绍:仓颉专项:飞机大炮我都会,利器心法我还有。(算起来,专项启动已经…

IDEA启动tomcat之后控制台出现中文乱码问题

方法1: 第一步:file--setting--Editor--File Encodings 注意页面中全部改为UTF-8,然后apply再ok 第二步:Run--Edit Configuration,将VM options输入以下值: -Dfile.encodingUTF-8 还是一样先apply再ok …

视频图文理解关联技术与创业团队(二)

上一篇:google gemini1.5 flash视频图文理解能力初探(一)提到了gemini 1.5 flash 可以对视频进行理解以及分析,但是整体在检索任务上效果不佳。 这几天参加了人工智能大会 网上收集,看一看有相似能力的一些技术点、创…

生物素化果胶粒子包裹药物阿霉素;DOX/Bio-PEC

生物素化果胶粒子包裹药物阿霉素(DOX/Bio-PEC)是一种新型的药物载体系统,结合了生物素和果胶多糖的优势,旨在提高药物的靶向性和控释性能。以下是对该系统的详细解析: 一、生物素化果胶粒子的制备 原理与步骤&#xff…

独立开发者系列(22)——API调试工具apifox的使用

接口的逻辑已经实现,需要对外发布接口,而发布接口的时候,我们需要能自己简单调试接口。当然,其实自己也可以写简单的代码调试自己的接口,因为其实就是简单的request请求或者curl库读取,调整请求方式get或者…

甄选范文“论区块链技术及应用”,软考高级论文,系统架构设计师论文

论文真题 区块链作为一种分布式记账技术,目前已经被应用到了资产管理、物联网、医疗管理、政务监管等多个领域。从网络层面来讲,区块链是一个对等网络(Peer to Peer, P2P),网络中的节点地位对等,每个节点都保存完整的账本数据,系统的运行不依赖中心化节点,因此避免了中…

MATLAB基础应用精讲-【数模应用】分层聚类(附python代码实现)

目录 前言 知识储备 层次聚类 1. 算法解读: 2. 步骤和细节: 3. 举例: 4. 算法评价: 5. 算法的变体: 算法原理 基本思想 分层聚类网络的原理 分层聚类网络的优势 分层聚类网络的应用领域 SPSSAU 分层聚类案例 1、背景 2、理论 3、操作 4、SPSSAU输出结果…

Johnson Counter

目录 描述 输入描述: 输出描述: 参考代码 描述 请用Verilog实现4位约翰逊计数器(扭环形计数器),计数器的循环状态如下。 电路的接口如下图所示。 输入描述: input clk , input …

[氮化镓]Kevin J. Chen组新作—肖特基p-GaN HEMTs正栅ESD机理研究

这篇文章是发表在《IEEE Electron Device Letters》上的一篇关于Schottky型p-GaN栅极高电子迁移率晶体管(HEMTs)的正向栅极静电放电(ESD)机理研究的论文。文章由Jiahui Sun等人撰写,使用了基于碳化硅(SiC&a…

设计模式探索:观察者模式

1. 观察者模式 1.1 什么是观察者模式 观察者模式用于建立一种对象与对象之间的依赖关系,当一个对象发生改变时将自动通知其他对象,其他对象会相应地作出反应。 在观察者模式中有如下角色: Subject(抽象主题/被观察者&#xf…

第11章 规划过程组(二)(11.10制订进度计划)

第11章 规划过程组(二)11.10制订进度计划,在第三版教材第395~397页;文字图片音频方式 第一个知识点:定义及作用 分析活动顺序、持续时间、资源需求和进度制约因素,创建项目进度模型,从而落实项目…