不玩PS抠图了,改玩Python抠图

网上找了两个苏轼的印章图片:

把这两个印章抠出来的话,对于不少PS高手来说是相当容易,但是要去掉其中的水印,可能要用仿制图章慢慢描绘,图章的边缘也要慢慢勾画或者用通道抠图之类来处理,而且印章的红色也不是很鲜亮,调整颜色也有点麻烦。弄个下面的Python程序,那就秒杀。

python 复制代码
import random

import cv2

def remove_background(image_path, red_threshold):
    """
    将图片中红色分量低于指定值的点全部变成透明

    :param image_path: 图片的路径
    :param red_threshold: 红色分量的阈值
    :return: 处理后的透明背景红色增强图片(numpy.ndarray类型)
    """
    # 读取图片
    image = cv2.imread(image_path)
    image_rgba = cv2.cvtColor(image, cv2.COLOR_BGR2RGBA)

    # 获取图片的高度、宽度和通道数
    height, width, channels = image.shape

    # 遍历图片中的每个像素点
    for i in range(height):
        for j in range(width):
            # 获取当前像素点的红色分量值
            red_value = image[i][j][2]

            # 如果红色分量值低于阈值,将该像素点变为透明
            if red_value < red_threshold:
                image_rgba[i][j] = [0, 0, 0, 0]
            else:
                # 考虑到现实中的红色未必都是纯红,生成一种随机的比较鲜艳的红色填充红色区域。这样水印自然消掉了
                red_value = random.randint(248, 255)
                green_value = random.randint(0, 8)
                blue_value = random.randint(0, 5)
                image_rgba[i][j] = [blue_value, green_value, red_value, 255]

    return image_rgba

if __name__ == '__main__':
    file_path = 'meiyang.jpg'
    image = remove_background(file_path, red_threshold=127)
    cv2.imwrite('meiyang.png', image)
    cv2.imshow('image', image)

    cv2.waitKey(0)
    cv2.destroyAllWindows()

抠图效果展示(右下角CSDN添加的水印别怪我,看不出透明背景别怪我):

其实只要前景色中没有混杂背景色,如果前景色和背景色差异较大或者转换为灰度图片后前景色与背景色灰度值相差明显,就可以稍微修改一下上面的代码将背景改成透明的,从而完成抠图。背景色不是纯黑纯白时可传入红绿蓝三个分量的阈值,转换为灰度图片后前景色与背景色灰度值相差明显时可先转换成灰度图片后二值化作为掩码图片,利用掩码图片消除原始图片上的背景。

话说苏东坡是白字先生,"士"字多刻了两笔🐶。

相关推荐
lucky九年2 分钟前
GO语言模拟C++封装,继承,多态
开发语言·c++·golang
温天仁6 分钟前
西门子PLC编程实践教程:工控工程案例学习
开发语言·学习·自动化·php
小陈工8 分钟前
Python Web开发入门(十):数据库迁移与版本管理——让数据库变更可控可回滚
前端·数据库·人工智能·python·sql·云原生·架构
lsx2024069 分钟前
Java 数组
开发语言
JosieBook12 分钟前
【C#】VS中的 跨线程调试异常:CrossThreadMessagingException
开发语言·c#
爱滑雪的码农14 分钟前
Java八:Character 类与string类
java·开发语言
csbysj202015 分钟前
《C 标准库 - 参考手册》
开发语言
JoshRen18 分钟前
Python中的简单爬虫
爬虫·python·信息可视化
永远的超音速21 分钟前
PyCharm性能调优避坑录大纲
python·pycharm
AnchorYYC29 分钟前
TEI Inference Toolkit - 工业级Embedding/NLI /Reranking服务调用最佳实践
人工智能·python·持续部署·#大模型应用