cv2.cornerHarris 例子

时间: 2023-07-24 10:18:45 浏览: 43
cv2.cornerHarris是OpenCV中用于角点检测的函数,它可以检测出图像中的拐角,返回角点图像。 下面是一个使用cv2.cornerHarris函数的简单例子: ```python import cv2 import numpy as np # 读取图像 img = cv2.imread('image.jpg') # 转换成灰度图像 gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) # 使用cv2.cornerHarris函数进行角点检测 dst = cv2.cornerHarris(gray,2,3,0.04) # 结果转换为uint8类型的图像 dst = cv2.convertScaleAbs(dst) # 在原图像上绘制角点 img[dst>0.01*dst.max()]=[0,0,255] # 显示图像 cv2.imshow('dst',img) if cv2.waitKey(0) & 0xff == 27: cv2.destroyAllWindows() ``` 在这个例子中,首先读入了一张图片,将其转换为灰度图像,然后使用cv2.cornerHarris函数进行角点检测,返回的结果dst是一个和原图像大小相同的单通道图像,其中每个像素代表该点的角点响应值。 最后,我们将结果转换为uint8类型的图像,找到大于0.01倍最大响应值的像素点,将其在原图像上标记为红色,最终显示结果。
相关问题

python cv2.cornerHarris

`cv2.cornerHarris()`是OpenCV库中用于角点检测的函数之一。它基于Harris角点检测算法,用于识别图像中的角点。 下面是一个使用`cv2.cornerHarris()`函数进行角点检测的示例: ```python import cv2 import numpy as np # 读取图像 image = cv2.imread('image.jpg', 0) # 替换为你的图像路径 # 转换为float32类型 image = np.float32(image) # 执行角点检测 dst = cv2.cornerHarris(image, blockSize=2, ksize=3, k=0.04) # 标记角点 dst = cv2.dilate(dst, None) image[dst > 0.01 * dst.max()] = 255 # 显示结果 cv2.imshow('Corner Detection', image) cv2.waitKey(0) cv2.destroyAllWindows() ``` 在上述示例中,我们首先使用`cv2.imread()`函数读取一张图像。然后,我们将图像转换为float32类型。接下来,我们使用`cv2.cornerHarris()`函数执行角点检测,其中`blockSize`参数指定邻域大小,`ksize`参数指定Sobel导数的孔径大小,`k`参数为角点检测方程中的自由参数。 然后,我们使用`cv2.dilate()`函数对角点结果进行膨胀操作,并将大于阈值的角点位置标记为白色。最后,我们使用`cv2.imshow()`和`cv2.waitKey()`函数显示图像中的角点。 请注意,此示例假设输入图像是灰度图像。如果你的图像是彩色图像,可以使用`cv2.cvtColor()`函数将其转换为灰度图像。

介绍cv2.cornerHarris

`cv2.cornerHarris` 是 OpenCV 中用于检测角点(Corner)的函数。角点是图像中比较特殊的点,它们是两条边缘线交叉处的点,通常被用于图像识别、三维重建等领域。 `cv2.cornerHarris` 函数的调用形式如下: ``` dst = cv2.cornerHarris(src, blockSize, ksize, k) ``` 其中: - `src`:待检测的输入图像,必须为单通道浮点型图像。 - `blockSize`:角点检测时考虑的邻域大小,一般取值为 2、3、4、5、6、7 等。 - `ksize`:Sobel 算子的大小,一般取值为 3。 - `k`:角点检测参数,一般取值范围为 0.04~0.06。 函数的返回值是一个与输入图像大小相同的单通道浮点型图像,其中图像的每个像素值表示该点的角点响应程度,响应程度越高则表示该点越有可能是角点。 使用 `cv2.cornerHarris` 函数进行角点检测的一般步骤如下: 1. 读入待检测的图像并将其转换为灰度图像。 2. 对灰度图像进行角点检测。 3. 根据角点响应程度对图像中的角点进行筛选。 4. 在原图像中标注出检测到的角点。 值得注意的是,`cv2.cornerHarris` 函数只能检测到图像中的角点,对于其他特征点(如直线端点、交叉点等),需要使用其他的算法进行检测。

相关推荐

最新推荐

recommend-type

对python opencv 添加文字 cv2.putText 的各参数介绍

今天小编就为大家分享一篇对python opencv 添加文字 cv2.putText 的各参数介绍,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

解决python cv2.imread 读取中文路径的图片返回为None的问题

主要介绍了解决python cv2.imread 读取中文路径的图片返回为None的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

python cv2.resize函数high和width注意事项说明

主要介绍了python cv2.resize函数high和width注意事项说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Python OpenCV之图片缩放的实现(cv2.resize)

主要介绍了Python OpenCV之图片缩放的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

用Spring boot和vue写一个登录注册界面

好的,这是一个比较常见的技术问题,我可以为您提供一些参考资料和思路。首先,您可以使用Spring Boot作为后端框架来处理用户认证和注册的逻辑,比如使用Spring Security实现用户登录认证。同时,您还需要设计相应的数据模型和数据库表结构来存储用户信息。在前端方面,您可以使用Vue.js作为框架来构建登录注册页面,使用Axios来发起API请求并和后端进行交互。当然,在实现过程中,还需要考虑一些具体细节,比如数据校验、安全性和用户体验等方面。希望这些信息能够帮助到您。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依