《数字图像处理-OpenCV/Python》连载(33)使用掩模图像控制处理区域

**本书京东优惠购书链接:https://item.jd.com/14098452.html**
**本书CSDN独家连载专栏:https://blog.csdn.net/youcans/category_12418787.html**


 
第 5 章  图像的算术运算

在OpenCV中,图像是以Numpy数组格式存储的,图像的算术运算可以使用OpenCV函数实现,也可以直接使用Numpy矩阵实现。但是,OpenCV函数对结果进行了饱和处理,可以避免数据溢出,而且使用OpenCV函数运算速度更快。

<br>

本章内容概要

  • 学习并比较使用OpenCV与Numpy矩阵的加法、减法、乘法和除法。
  • 学习图像的按位操作。
  • 介绍掩模图像,理解掩模图像在图像处理中的作用。
  • 介绍积分图像,理解积分图像的原理,实现快速模糊处理。


5.2 使用掩模图像控制处理区域

图像掩模,也称“掩膜”,是指用特定的掩模图像或掩模函数对目标图像进行覆盖或遮挡,以控制图像处理区域或处理过程,常用于结构特征区域的处理。

用来遮蔽的图像或函数,称为掩模、掩像、模板或遮罩。掩模图像是单通道二值图像,显示为黑白两种颜色。黑色遮蔽区域的值为0,白色非遮蔽区域的值为1或255,也被称为窗口、开窗区域。

在OpenCV中,很多处理函数都允许使用掩模图像控制处理区域,即只对掩模图像中数值为1(或255)的窗口区域进行处理,而对数值为0的遮蔽区域不做处理。

例如,使用函数cv.add进行加法运算,可以使用掩模图像实现掩模加法,只对掩模图像中像素值为255的白色窗口区域进行处理,输出为加法运算的值;对掩模图像中像素值为0的黑色遮蔽区域不做处理,输出图像的对应位置的值为0(黑色)。

注意问题

(1) 掩模图像是单通道二值图像,遮蔽区域为0(黑色),窗口区域为255(白色)。

(2) 需要特别注意的是:如果以非二值的单通道图像作为掩模图像,程序一般不会报错,但处理结果可能发生错误,通常会将非0值都视为1。

(3) 掩模图像必须与加法运算的输入图像src1的尺寸相同。

【例程0502】掩模图像的生成和图像的掩模加法

本例程包括掩模图像的生成和图像的掩模加法。

python"># 【0502】掩模图像的生成和图像的掩模加法
import cv2 as cv
import numpy as np
from matplotlib import pyplot as plt

if __name__ == '__main__':
    img1 = cv.imread("../images/Lena.tif")  # 读取彩色图像(BGR)
    img2 = cv.imread("../images/Fig0301.png")  # 读取彩色图像(BGR)
    h, w = img1.shape[:2]
    img3 = cv.resize(img2, (w,h))  # 调整图像大小与 img1 相同
    print(img1.shape, img2.shape, img3.shape)
    imgAddCV = cv.add(img1, img3)  # 图像加法 (饱和运算)

    # 掩模加法,矩形掩模图像
    maskRec = np.zeros(img1.shape[:2], np.uint8)  # 生成黑色模板
    xmin, ymin, w, h = 170, 190, 200, 200  # 矩形 ROI 参数(ymin:ymin+h, xmin:xmin+w)
    maskRec[ymin:ymin+h, xmin:xmin+w] = 255  # 生成矩形掩模图像,ROI 为白色
    imgAddRec = cv.add(img1, img3, mask=maskRec)  # 掩模加法

    # 掩模加法,圆形掩模图像
    maskCir = np.zeros(img1.shape[:2], np.uint8)  # 生成黑色模板
    cv.circle(maskCir, (280,280), 120, 255, -1)  # 生成圆形掩模图像
    imgAddCir = cv.add(img1, img3, mask=maskCir)  # 掩模加法

    plt.figure(figsize=(9, 6))
    plt.subplot(231), plt.title("1. Original"), plt.axis('off')
    plt.imshow(cv.cvtColor(img1, cv.COLOR_BGR2RGB))
    plt.subplot(232), plt.title("2. Rectangle mask"), plt.axis('off')

程序说明:

运行结果,带掩模图像的加法运算如图5-2所示。

(1) 图5-2(2)和图5-2(5)所示为单通道二值掩模图像,背景为黑色,开窗为白色。图5-2(2)通过切片得到矩形窗口,图5-2(5)通过绘制圆形填充图形得到圆形窗口。

(2) 图5-2(4)所示为无掩模图像的饱和加法运算结果,图5-2(3)所示为以图5-2(2)为掩模图像的饱和加法运算结果,图5-2(6)所示为以图5-2(5)为掩模图像的饱和加法运算结果。带有掩模图像的加法运算,只会对掩模图像的开窗区域进行运算处理,对没有开窗的遮蔽区域不进行处理,输出值为0(黑色)。

图5-2 带掩模图像的加法运算


<br>

版权声明:
youcans@xupt 原创作品,转载必须标注原文链接:(https://blog.csdn.net/youcans/article/details/134014675)
Copyright 2023 youcans, XUPT
Crated:2023-10-31


欢迎关注本书CSDN独家连载专栏
**《数字图像处理-OpenCV/Python》连载: https://blog.csdn.net/youcans/category_12418787.html**


http://www.niftyadmin.cn/n/5134399.html

相关文章

【Java】HashSet存入学生对象

使用 HashSet 存入学生对象 定义学生 Student 实体类 成员属性 学号、姓名定义 HashSet 集合存入 Student 对象&#xff0c;保证存放的学生对象&#xff08;相同的学号和姓名&#xff09;不允许重复定义 StudentManage 对 Student 对象集合实现增删改查 示例代码 package com.…

【洛谷算法题】P5709-Apples Prologue / 苹果和虫子【入门2分支结构】

&#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5709-Apples Prologue / 苹果和虫子【入门2分支结构】&#x1f30f;题目描述&am…

SpringCloud之Eureka的学习【详细】

目录 服务架构演变 单体架构 分布式架构 分布式架构需要考虑的问题 微服务 架构比较 微服务技术对比 服务拆分注意事项 案例 服务远程调用 RestTemplate Eureka注册中心 RestTemplate存在的问题 服务调用考虑的问题 Eureka的作用 搭建EurekaServer 服务注册 …

计算机网络——第一章体系结构相关习题及详细解析

1-1 在OSI参考模型中&#xff0c;自下而上第一个提供端到端服务的层次是&#xff1a; A.数据链路层 B.传输层 C.会话层 D.应用层 答案选择&#xff1a;B.传输层 即&#xff0c;在OSI参考模型中&#xff0c;自下而上第一个提供端到端服务的层次是传输层。…

抓包分析DSCP字段在FTP/RSTP协议中的应用

抓包分析DSCP字段在FTP协议中的应用 简介 本文介绍DSCP字段的作用&#xff0c;以及抓包分析DSCP字段在FTP协议中的应用。最后通过实验证明有可能DSCP字段实际上对普通用户没啥用&#xff0c;原因是运营商可能会将用户设置的DSCP字段重置。 DSCP IP报文中有个TOS字段 &#…

【python练习】三种排序算法

排序算法 Description试用选择算法或冒泡算法或快速排序算法对一列数进行升序排列。如&#xff1a;9 9 1 4 10 2 1 8 7 4排列后为&#xff1a;1 1 2 4 4 7 8 9 9 10Input 一列若干个整数Output 排序后的一列整数Sample Input 1 9 9 1 4 10 2 1 8 7 4 Sample Output 11 1 2 4 4 …

多线程---线程池

文章目录 什么是线程池&#xff1f;线程池的实现标准库中的线程池&#xff08;四种&#xff09;自己实现一个线程池 线程池支持的参数在实际的开发中&#xff0c;线程池的线程数如何确定&#xff1f; 什么是线程池&#xff1f; 线程诞生的原因就是进程太“重量”了。虽然线程的…

【Python实现坦克大战,带你找回童年的快乐】附源码

文章目录 前言&#xff1a;第一步&#xff1a;安装Pygame库第二步&#xff1a;实现思路&#xff1a;场景实现&#xff1a;石头墙&#xff1a;钢墙&#xff1a;地面类&#xff08;Grass&#xff09;地图&#xff1a; 第三步&#xff1a;坦克类的详细实现&#xff1a;坦克类&…