IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 证件照人像与背景分离(Python&cv) -> 正文阅读

[人工智能]证件照人像与背景分离(Python&cv)

代码:

import cv2
import numpy as np
#标记特定颜色区域
def Mark_Color(img, flag_color):
    #自定义
    if flag_color ==0:
        lower = np.array([24, 43, 46], dtype="uint8")
        upper = np.array([43, 255, 255], dtype="uint8")
    #黑色
    elif flag_color ==1:
        lower = np.array([0, 0, 0], dtype="uint8")
        upper = np.array([180, 255, 46], dtype="uint8")
    # 灰色
    elif flag_color == 2:
        lower = np.array([0, 0, 46], dtype="uint8")
        upper = np.array([180, 43, 220], dtype="uint8")
    # 白色
    elif flag_color == 3:
        lower = np.array([0, 0, 221], dtype="uint8")
        upper = np.array([180, 30, 255], dtype="uint8")
    # 红色
    elif flag_color == 4:
        lower = np.array([156, 43, 46], dtype="uint8")
        upper = np.array([180, 255, 255], dtype="uint8")
    # 红色2
    elif flag_color == 5:
        lower = np.array([0, 43, 46], dtype="uint8")
        upper = np.array([10, 255, 255], dtype="uint8")
    # 橙色
    elif flag_color == 6:
        lower = np.array([11, 43, 46], dtype="uint8")
        upper = np.array([25, 255, 255], dtype="uint8")
    # 黄色
    elif flag_color == 7:
        lower = np.array([26, 43, 46], dtype="uint8")
        upper = np.array([34, 255, 255], dtype="uint8")
    # 绿色
    elif flag_color == 8:
        lower = np.array([35, 43, 46], dtype="uint8")
        upper = np.array([77, 255, 255], dtype="uint8")
    # 青色
    elif flag_color == 9:
        lower = np.array([78, 43, 46], dtype="uint8")
        upper = np.array([99, 255, 255], dtype="uint8")
    # 蓝色
    elif flag_color == 10:
        lower = np.array([100, 43, 46], dtype="uint8")
        upper = np.array([124, 255, 255], dtype="uint8")
    # 紫色
    else:
        lower = np.array([125, 43, 46], dtype="uint8")
        upper = np.array([155, 255, 255], dtype="uint8")

    converted = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)
    markingMask = cv2.inRange(converted, lower, upper)

    return markingMask
    # markingMask = cv2.GaussianBlur(markingMask, (5, 5), 0)
    # marked_img = cv2.bitwise_and(img, img, mask=markingMask)
    # return marked_img
# Read image
# im_in = cv2.imread("2inch_blue_1.jpg", cv2.IMREAD_GRAYSCALE);
img_path = '2inch_blue_1.jpg'

img = cv2.imread(img_path)

# 分离背景(背景为白色,人物为黑色)
im_in = Mark_Color(img, 10)


# Threshold.
# Set values equal to or above 220 to 0.
# Set values below 220 to 255.
th, im_th = cv2.threshold(im_in, 220, 255, cv2.THRESH_BINARY_INV);

# Copy the thresholded image.
im_floodfill = im_th.copy()

# Mask used to flood filling.
# Notice the size needs to be 2 pixels than the image.
h, w = im_th.shape[:2]
mask = np.zeros((h + 2, w + 2), np.uint8)

# Floodfill from point (0, 0)
cv2.floodFill(im_floodfill, mask, (0, 0), 255);

# Invert floodfilled image
im_floodfill_inv = cv2.bitwise_not(im_floodfill)

# Combine the two images to get the foreground.
im_out = im_th | im_floodfill_inv

# Display images.
cv2.imshow("Thresholded Image", im_th)
cv2.imshow("Floodfilled Image", im_floodfill)
cv2.imshow("Inverted Floodfilled Image", im_floodfill_inv)
cv2.imshow("Foreground", im_out)
cv2.waitKey(0)

效果:
按照Display依次为:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
然后,可以继续设计有趣的应用。

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-06 13:02:47  更:2022-03-06 13:05:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 2:08:45-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码