opencv礼帽和黑帽运算

ops/2024/12/19 4:59:48/

礼帽 = 原始输入 - 开运算结果,留存的以白色毛刺为主
黑帽 = 闭运算 - 原始输入,保留的更多是原始轮廓

# 导入OpenCV库,用于图像处理  
import cv2  
import numpy as np  
# 从matplotlib库中导入pyplot模块,用于绘制图像  
from matplotlib import pyplot as plt  # 创建一个名为'window'的窗口,窗口大小自动调整  
cv2.namedWindow('window', cv2.WINDOW_AUTOSIZE)  # cv2.WINDOW_AUTOSIZE: 窗口大小自动调整,不允许用户改变窗口大小  # 使用OpenCV的imread函数读取名为"mao.jpg"的图片,参数1表示读取彩色图像  
cat = cv2.imread("mao.jpg", 0)  # cat变量存储读取的图像数据,OpenCV默认以BGR格式读取  # 在名为'window'的窗口中显示图像  
cv2.imshow('window', cat)  kernel = np.ones((5, 5), np.uint8)  
opening = cv2.morphologyEx(cat, cv2.MORPH_TOPHAT, kernel)  # 礼帽运算  
closing = cv2.morphologyEx(cat, cv2.MORPH_BLACKHAT, kernel)  # 黑帽运算  
cv2.imshow('window1', opening)  
cv2.imshow('window2', closing)  # 等待按键事件,0表示无限期等待  
key = cv2.waitKey(0)  # 检查按下的键是否是'q',如果是则销毁所有窗口  
if key & 0xFF == ord('q'):  # 0xFF是掩码,用于确保只检查最低8位  print("准备销毁窗口")  cv2.destroyAllWindows()


http://www.ppmy.cn/ops/143082.html

相关文章

包子凑数(2017年蓝桥杯试题H)

【问题描述】 小明几乎每天早晨都会在一家包子铺吃早餐,他发现这家包子铺有N种蒸笼,其中第i种蒸笼恰好能放Ai(i为下标)个包子。每种蒸笼都有非常多个,可以认为是无限笼。 每当有顾客想买X个包子。卖包子的大叔就会迅速选出若干笼包子&#xf…

【C++】sophus : common.hpp 丰富的字符串格式化、日志记录和数学常量处理功能 (七)...

这段C代码实现了一个名为Sophus的库,提供了各种实用功能。主要内容包括: 宏定义和条件编译: 使用条件编译定义了一些宏,用于在不同编译器下处理函数名称等。定义了用于格式化字符串和打印日志的宏。定义了用于运行时断言的宏&…

Python爬虫获取商品销量详情

在这个数据驱动的时代,获取商品销量详情已经不再是简单的点击和浏览。我们需要的是速度、效率,还有一点点的...偷偷摸摸。没错,今天我们要聊的是如何使用Python爬虫来“偷窥”商品销量详情。别担心,我们保证一切都是合法合规的&am…

revit转gltf,revit转3dtiles,如何将Revit模型转为3DTiles格式并在Cesiumjs中高效可视化

Revit模型导出gltf、glb与3dtiles有多种方式,但一般的商业工具收费普遍较高:Cesiumlab导出3dTile格式数据,Cesiumlab暂时可试用3天,会员版收费每年800;BimAngleEngine导出3dTile格式数据BimAngleEngine暂时可试用30天&…

CTFHUB靶场关于SSRF保姆级攻略

一.内网访问 输入127.0.0.1/flag.php 二.伪协议读取文件 输入?urlfile:///var/www/html/flag.php 右键页面查看源代码 三.端口扫描 尝试一下index.php,没有显示,说明有这个文件 上方题中提示我们端口在8000-9000中我们用burp suite抓包,开启…

Mysql笔记

windows安装记录Windows中Mysql安装-CSDN博客 用到的库 通过网盘分享的文件:atguigudb.sql 链接: https://pan.baidu.com/s/1YfC20c2vK9odn-XRJJwUJw 提取码: utk7 --来自百度网盘超级会员v5的分享 Mysql4中表关联关系 1.1对1,比较少用,因为完全可以一张表,当有…

pytest -s执行的路径

pytest -s执行的路径: 直接写pytest -s,表示从当前路径下开始执行全部.py的文件。 执行具体指定文件:pytest -s .\testXdist\test_dandu.py 下面这样执行pytest -s 会报找不到文件或没权限访问, 必须要加上具体文件路径pytest -s…

鸿蒙Next状态管理最佳实践

在鸿蒙Next应用开发中,合理的状态管理是确保应用性能和响应性的关键。以下是基于最佳实践的详细阐述,每个实践都包含反例分析和正例改进,并提供了相应的代码示例。 一、使用ObjectLink代替Prop减少不必要的深拷贝 (一&#xff0…