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 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 图像分割为黑白,做图像修复的mask使用 -> 正文阅读

[人工智能]图像分割为黑白,做图像修复的mask使用

今天在做视频修复的时候遇到了一个问题:我应该如何将左边的照片转为右边这种形式的呢(也可以自定义mask,做静态mask...)?

第一步:

我先用PS将图像抠出来(这里推荐使用套索工具,感觉很好用)

?然后我右键这个区域,选择填充为白色,

然后再右键该区域,选择反向,填充为黑色:

这样你选择的地方就变成白色,其他地方就变成黑色了

?

保存为PNG格式到桌面

第2步:

但是这样不够,因为你会发现这个照片是24位深,并且黑白交互地方有羽化的痕迹

通过以下代码生成8位深的纯黑白照片


import glob
import os

import cv2
import numpy as np

# Get all png files under the input folder
input_img_path = glob.glob("images/*.png")
save_path = "blur13x13/"


def mkdir(path):
    folder = os.path.exists(path)
    if not folder:  # 判断是否存在文件夹如果不存在则创建为文件夹
        os.makedirs(path)  # makedirs 创建文件时如果路径不存在会创建这个路径
        print("--- create new folder...  ---")
    else:
        print("---  There is this folder!  ---")

def erode_demo(gray):
    ret, binary = cv2.threshold(gray, 0, 255, cv2.THRESH_BINARY_INV)
    kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5))
    dst = cv2.erode(binary, kernel)
    return dst


def dilate_demo(gray):
    ret, binary = cv2.threshold(gray, 0, 255, cv2.THRESH_BINARY_INV)
    kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5))
    dst = cv2.dilate(binary, kernel)
    return dst


mkdir(save_path)  # 调用函数

i = 0
for file in input_img_path:
    # get the file_name of image
    file_name = file.split('\\')[-1]

    print(file_name)

    img1 = cv2.imread(file, cv2.IMREAD_GRAYSCALE)


    ### 下面为处理图片的过程

    binary_path, th = cv2.threshold(img1, 180, 255, cv2.THRESH_BINARY)
    binary_inv_path, th1 = cv2.threshold(img1, 180, 255, cv2.THRESH_BINARY_INV)
    trunc_path, th2 = cv2.threshold(img1, 180, 255, cv2.THRESH_TRUNC)
    tozero_path, th3 = cv2.threshold(img1, 180, 255, cv2.THRESH_TOZERO)
    tozero_inv_path, th4 = cv2.threshold(img1, 180, 255, cv2.THRESH_TOZERO_INV)

    result = erode_demo(th3)
    result3 = dilate_demo(result)

    cv2.waitKey(0)
    cv2.destroyAllWindows()

    img_color = cv2.applyColorMap(th3, cv2.COLORMAP_HOT)
    img_color1 = cv2.applyColorMap(th4, cv2.COLORMAP_DEEPGREEN)

    Image = cv2.addWeighted(img_color, 0.3, img_color1, 0.7, 0)

    out_img1 = np.hstack((img1, th, th1))
    out_img2 = np.hstack((th2, th3, th4))
    out_img = np.vstack((out_img1, out_img2))

    ###

    # cv2.imwrite(save_path + file_name, out_img)
    # cv2.imwrite(save_path + file_name, img_color)
    # cv2.imwrite(save_path + file_name, img_color1)
    # cv2.imwrite(save_path + file_name, Image)
    #
    # cv2.imwrite(save_path + file_name, img1)
    # cv2.imwrite(save_path + file_name, th)
    cv2.imwrite(save_path + file_name, th1)
    # cv2.imwrite(save_path + file_name, th2)
    # cv2.imwrite(save_path + file_name, th3)
    # cv2.imwrite(save_path + file_name, th4)

    i = i + 1
    print("The", i, "picture is currently being processed")





?在文件夹下:C:\Users\PycharmProjects\color_flower这个就是你想要的照片了

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:22:47  更:2022-04-01 23:26:40 
 
开发: 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/9 0:22:34-

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