32 OpenCV Harris角点检测

2024-05-06 08:52
文章标签 opencv 检测 角点 harris 32

本文主要是介绍32 OpenCV Harris角点检测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • cornerHarris 算子
  • 示例

角点检测

cornerHarris 算子

void cv::cornerHarris ( InputArray  src,OutputArray dst,int  blockSize,int ksize,double K,int borderType = BORDER_DEFAULT)
src:待检测Harris角点的输入图像,图像必须是CV 8U或者CV 32F的单通道灰度图像
dst: 存放Harris评价系数的R矩阵,数据类型为CV 32F的单通道图像,与输入图像具有相同的尺寸
blockSize:邻域大小
ksize: Sobel算子的半径,用于得到梯度信息   
k:计算Harris评价系数R的权重系数
borderType:像素外推算法标志

示例

#include <opencv2/opencv.hpp>
#include <iostream>using namespace cv;
using namespace std;// 声明全局变量,用于存储输入图像和处理后的图像,以及阈值和最大阈值计数。
Mat src, gray_src;
int thresh = 130;
int max_count = 255;// 定义输出窗口的标题。
const char* output_title = "HarrisCornerDetection Result";// 执行Harris角点检测并显示结果的函数。
void Harris_Demo(int, void*);int main(int argc, char** argv) {// 加载输入图像。src = imread("D:/vcprojects/images/home.jpg");if (src.empty()) {printf("无法加载图像...\n");return -1;}// 在窗口中显示输入图像。namedWindow("输入图像", CV_WINDOW_AUTOSIZE);imshow("输入图像", src);// 创建窗口以显示Harris角点检测结果。namedWindow(output_title, CV_WINDOW_AUTOSIZE);// 将输入图像转换为灰度图像。cvtColor(src, gray_src, COLOR_BGR2GRAY);// 创建一个滑动条,用于交互式调整阈值值。createTrackbar("阈值:", output_title, &thresh, max_count, Harris_Demo);// 首先执行Harris角点检测。Harris_Demo(0, 0);// 无限等待按键。waitKey(0);return 0;
}// 执行Harris角点检测的函数。
void Harris_Demo(int, void*) {// 初始化变量,用于存储Harris角点检测的输出。Mat dst, norm_dst, normScaleDst;// 初始化Harris角点检测算法的参数。int blockSize = 2;int ksize = 3;double k = 0.04;// 将Harris角点检测算法应用于灰度输入图像。cornerHarris(gray_src, dst, blockSize, ksize, k, BORDER_DEFAULT);// 将输出归一化到范围[0, 255]。normalize(dst, norm_dst, 0, 255, NORM_MINMAX, CV_32FC1, Mat());// 将归一化输出转换为8位无符号整数。convertScaleAbs(norm_dst, normScaleDst);// 创建输入图像的副本,在其上绘制检测到的角点。Mat resultImg = src.clone();// 遍历归一化输出中的每个像素。for (int row = 0; row < resultImg.rows; row++) {//获取 normScaleDst 图像的第 row 行的指针,这样就可以通过该指针访问该行的像素值uchar* currentRow = normScaleDst.ptr(row);for (int col = 0; col < resultImg.cols; col++) {// 获取当前像素的值。int value = (int)*currentRow;// 如果值超过阈值,则在相应位置绘制一个圆圈。if (value > thresh) {circle(resultImg, Point(col, row), 2, Scalar(0, 0, 255), 2, 8, 0);}// 移动到行中的下一个像素。currentRow++;}}// 显示带有检测到的角点的结果图像。imshow(output_title, resultImg);
}

在这里插入图片描述

这篇关于32 OpenCV Harris角点检测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/963933

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj