news 2026/6/9 22:34:31

cv2.cornerHarris() 详解(Harris 角点检测)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
cv2.cornerHarris() 详解(Harris 角点检测)

cv2.cornerHarris() 详解(Harris 角点检测)

cv2.cornerHarris() 是 OpenCV 中实现Harris 角点检测的核心函数,用于检测图像中的角点(角点定义:图像中在两个正交方向上灰度变化都很大的像素点,如物体边缘的交点)。以下是完整的使用指南、参数解析、实战示例和避坑技巧:

一、核心原理

Harris 角点检测通过计算像素点的自相关矩阵,分析该点邻域内的灰度变化:
若两个方向的灰度变化都大 → 角点;
仅一个方向变化大 → 边缘;
无明显变化 → 平坦区域。最终通过响应值(R)判断是否为角点:R > 阈值 则判定为角点。

二、函数语法与参数

dst = cv2.cornerHarris(src, blockSize, ksize, k)

完整使用步骤

# -*- coding:utf-8 -*-importcv2 as cvimportnumpy as npimportsysif__name__=='__main__':# 读取图像image=cv.imread('./images/test.jpg')ifimage is None: print('Failed to read test.jpg.')sys.exit()# 转为灰度图像gray=cv.cvtColor(image, cv.COLOR_BGR2GRAY)# 计算Harris系数harris=cv.cornerHarris(gray,2,3,0.04,borderType=cv.BORDER_DEFAULT)# 对Harris进行归一化便于进行数值比较harris_nor=cv.normalize(harris, None,alpha=0,beta=255,norm_type=cv.NORM_MINMAX)harris_nor=harris_nor.astype('uint8')# 寻找Harris角点kps=[]foriinnp.argwhere(harris_nor>125): kps.append(cv.KeyPoint(i[1], i[0],1))# 绘制角点result=cv.drawKeypoints(image, kps, None)# 展示结果cv.imshow('R', harris_nor)cv.imshow('Harris KeyPoints', result)cv.waitKey(0)cv.destroyAllWindows()

常见错误及解决

错误 1:输入图像类型错误

plaintext
error: (-215:Assertion failed) src.type() == CV_32F || src.type() == CV_8U
原因:输入图像不是单通道灰度图,或未转为浮点型;
解决:确保 src 是灰度图,且执行 gray = np.float32(gray)。

错误 2:角点标记无效果

原因:阈值过高,或 k 取值不合理;
解决:降低阈值(如 0.01dst.max() → 0.005dst.max()),调整 k 至 0.04~0.06。

错误 3:亚像素检测报错

plaintext
error: (-215:Assertion failed) src.size() == patternSize
原因:corners 格式错误(需是 (N,2) 的浮点数组);
解决:确保 corners = np.float32(corners[:, ::-1]) 转换坐标格式。

适用场景与局限性

总结

cv2.cornerHarris() 核心是调参 blockSize、ksize、k,需根据图像分辨率 / 噪声调整;
降噪(高斯模糊)是提升检测效果的关键前置步骤;
高精度场景需结合 cv2.cornerSubPix() 实现亚像素级检测;
对比 Shi-Tomasi 角点检测,Harris 更适合粗检测,Shi-Tomasi 速度更快、结果更稳定。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 23:57:48

LangFlow FullStory完全还原用户操作

LangFlow:可视化构建与操作还原如何重塑LLM应用开发 在大模型时代,一个产品从灵感到上线的周期正在被前所未有地压缩。但对大多数开发者而言,真正棘手的问题不是“有没有想法”,而是“怎么快速验证”。尤其是在构建基于大语言模型…

作者头像 李华
网站建设 2026/6/9 11:20:32

esp32连接onenet云平台通俗解释通信原理

ESP32如何“对话”OneNet?一文讲透物联网通信底层逻辑你有没有想过,一个不到十块钱的ESP32开发板,是怎么把温湿度数据传到千里之外的云端,并在手机上实时显示的?这背后并不是魔法,而是一套精心设计的“端-云…

作者头像 李华
网站建设 2026/6/6 4:07:30

LangFlow Huawei Cloud CES接入

LangFlow 华为云 CES 接入 在大模型技术迅猛发展的今天,越来越多企业开始尝试将大型语言模型(LLM)融入业务流程——从智能客服到自动报告生成,从知识库问答到营销文案创作。然而,真正落地这些 AI 应用时,开…

作者头像 李华
网站建设 2026/6/7 2:50:47

15、Irrlicht 3D 引擎开发与部署全解析

Irrlicht 3D 引擎开发与部署全解析 1. Irrlicht 应用部署基础 在使用 Xcode 编译 Irrlicht 应用时,Xcode 会负责保持应用程序包的更新。但要确保像模型、图标或图形等资源被列入“Copy Bundle Resources”。若未列入,应用将无法显示这些资源。 1.1 创建通用应用及兼容性处…

作者头像 李华
网站建设 2026/6/9 21:55:56

手把手实现ModbusRTU串行通信(工业场景)

手把手实现ModbusRTU串行通信:工业现场的“硬核”实战指南在一间嘈杂的生产车间里,一台PLC正通过一根双绞线与十几台设备“低声对话”。没有Wi-Fi,不依赖以太网交换机,甚至不需要IP地址——它靠的,是一套诞生于1979年的…

作者头像 李华
网站建设 2026/6/9 14:55:18

利用nanopb压缩物联网传输数据:快速理解

让每一比特都物尽其用:用 nanopb 打造高效物联网通信你有没有遇到过这样的场景?一个温湿度传感器,每30秒上报一次数据,原本只是{"temp":25.3,"humid":60}这么点信息,但走JSON协议一发,…

作者头像 李华