opencv实现角点检测

本文实例为大家分享了opencv实现角点检测的具体代码,供大家参考,具体内容如下

1、特征点的作用:使用特征点代表图像内容

运动目标跟踪
物体识别
图像配准
全景图像拼接
三维重建

2、Harris角点检测基本思想

角点定义 :窗口向任意方向的移动都导致图像灰度的明显变化

opencv实现角点检测_第1张图片

opencv实现角点检测_第2张图片

平坦区域:任意方向移动,无灰度变化

opencv实现角点检测_第3张图片

边缘:

沿着边缘方向移动,无灰度变化

opencv实现角点检测_第4张图片

opencv实现角点检测_第5张图片
opencv实现角点检测_第6张图片
opencv实现角点检测_第7张图片
opencv实现角点检测_第8张图片
opencv实现角点检测_第9张图片
opencv实现角点检测_第10张图片
opencv实现角点检测_第11张图片

#include "opencv2/opencv.hpp"
#include 

using namespace cv;
using namespace std;
//全局变量


int main()
{
    Mat src_image ;
    Mat gray_image ;
    VideoCapture vidcap(0);

    vector conners;//检测到的角点
    int maxConers = 300;//检测角点上限
    double qualityLevel = 0.1;//最小特征值
    double minDistance = 10;//最小距离

    while (true)
    {
        vidcap >> src_image;

        cvtColor( src_image, gray_image, CV_BGR2GRAY);//转换为灰度图

        //Shi-Tomasi角点检测
        goodFeaturesToTrack( gray_image, conners, maxConers, qualityLevel, minDistance);

        //cout<<"检测到的角点坐标:"< 
 

opencv实现角点检测_第12张图片

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

你可能感兴趣的:(opencv实现角点检测)