基于MFC和OpenCV实现角点检测

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

// 角点检测
// 根据《基于OpenCV的计算机视觉技术实现》

#define max_corners 200;          // 限定的最大角点数

IplImage* srcImage = 0;          // 待处理的源图像
IplImage* ImageShow = 0;          // 存储显示带角点的图像
IplImage* grayImage = 0;          // 原始图像转换成的灰阶图像
IplImage* corners1 = 0;          // 临时图像
IplImage* corners2 = 0;          // 临时图像

int cornerCount0 = max_corners;
int cornerCount;              // 实际测得角点数
int qualityLevel = 0;            // 最小质量因子
int minDistance = 15;           // 角点最小距离
CvScalar color = CV_RGB(255,0,0);      // 绘图颜色
CvPoint2D32f corners[200];         // 角点坐标
CvRect ROI_rect;              // 测试范围
char  chek_area_state = 0;         // 鼠标状态

void re_find_corners(int)          // 滑动条响应函数
{
 int  i,x,y,xl,yu,xr,yd,k;
 int  radius = 5;
 int  thickness = 1;
 double quality_level = (double) qualityLevel / 100 + 0.02;
 double min_distance = (double) minDistance;

 cornerCount=cornerCount0;        // 设置最大角点数
 cvGoodFeaturesToTrack(grayImage,    // 角点检测
 corners1,corners2,corners,&cornerCount,
 quality_level,min_distance,NULL);

 if (cornerCount>0) {          // 测到角点
 xl=ROI_rect.x;   yu=ROI_rect.y;  // 设置初始测试范围
 xr=ROI_rect.x+ROI_rect.width;
 yd=ROI_rect.y+ROI_rect.height;
 cvCopy(srcImage,ImageShow);     // 恢复源图像
 for (i=0,k=0;i<cornerCount;i++) {
  x=(int)corners[i].x;
  y=(int)corners[i].y;
  if ((xl<x)&&(x<xr)&&(yu<y)&&(y<yd)) { // 范围检查
  corners[k].x=corners[i].x; // 保存范围内角点
  corners[k].y=corners[i].y;
  k++;
  }
 }
 cornerCount=k;           // 范围内角点数
 cvCopy(srcImage,ImageShow);
 for (i=0;i<cornerCount;i++) {
  x=(int)corners[i].x;
  y=(int)corners[i].y;
  cvCircle(ImageShow,cvPoint(x,y),  // 角点处画圈
  radius,color,thickness,CV_AA,0);
 }
 cvRectangle(ImageShow,cvPoint(xl,yu),cvPoint(xr,yd),
  CV_RGB(0,255,0),thickness,CV_AA,0); // 画矩形
 cvShowImage("image", ImageShow);  // 显示画圈图像
 }
}

void on_mouse2(int event,int x,int y,int flags,void* param)
{                      // 鼠标响应函数
 int thickness = 1;
 CvPoint point1,point2;

 if (event == CV_EVENT_LBUTTONDOWN) {  // 鼠标左键按下
 ROI_rect.x = x;           // 记录检测窗口一角坐标
 ROI_rect.y = y;
 chek_area_state = 1;        // 设置状态标志
 }
 else if (chek_area_state && event == CV_EVENT_MOUSEMOVE) { // 鼠标移动
 cvCopy(srcImage,ImageShow);     // 恢复原始图像
 point1 = cvPoint(ROI_rect.x, ROI_rect.y);
 point2 = cvPoint(x,y);       // 当前坐标
 cvRectangle(ImageShow,point1,point2,CV_RGB(0,255,0),
  thickness,CV_AA,0);     // 画矩形
 cvShowImage("image", ImageShow);  // 显示检测结果
 cvWaitKey(20);           // 延时
 }
 else if (chek_area_state && event == CV_EVENT_LBUTTONUP) { // 鼠标左键抬起
 ROI_rect.width = abs(x - ROI_rect.x); // 记录检测窗口对角坐标
 ROI_rect.height = abs(y - ROI_rect.y);

 re_find_corners(0);         // 角点检测
 chek_area_state = 0;        // 恢复状态标志
 cvWaitKey(20);
 }
}

void CCVMFCView::OnCornersTest()      // 角点检测
{
 if (workImg->nChannels>1) {       // 原图为真彩色图像==3
 srcImage = cvCloneImage(workImg);
 }
 else {                 // 原图为灰阶图像
 srcImage = cvCreateImage(cvGetSize(workImg),IPL_DEPTH_8U,3);
 cvCvtColor(workImg,srcImage,CV_GRAY2BGR);
 }
 cvFlip(srcImage);

 grayImage = cvCreateImage(cvGetSize(srcImage),IPL_DEPTH_8U,1);
 cvCvtColor(srcImage,grayImage,CV_BGR2GRAY); // 转换为灰阶图像
 ImageShow = cvCloneImage(srcImage);

 ROI_rect.x =0;
 ROI_rect.y =0;
 ROI_rect.width = grayImage->width;
 ROI_rect.height = grayImage->height;

 corners1 = cvCreateImage(cvGetSize(grayImage),IPL_DEPTH_32F,1);
 corners2 = cvCreateImage(cvGetSize(grayImage),IPL_DEPTH_32F,1);

 cvNamedWindow("image",0);        // 设置显示窗口
 cvResizeWindow("image",325,350);    // 改变窗口尺寸

 cvCreateTrackbar("角点最小距离", "image", // 设置距离滑动条
 &minDistance, 200,re_find_corners);
 cvCreateTrackbar("最小质量因子","image", // 设置质量滑动条
 &qualityLevel,100,re_find_corners);

 re_find_corners(0);           // 角点检测

 cvSetMouseCallback("image",on_mouse2,0); // 设置鼠标响应函数

 cvWaitKey(0);              // 等待键输入

 cvDestroyWindow( "image" );       // 关闭窗口

 cvReleaseImage(&srcImage);       // 释放图像存储单元
 cvReleaseImage(&grayImage);
 cvReleaseImage(&corners1);
 cvReleaseImage(&corners2);

 cvFlip(ImageShow);
 m_dibFlag=imageReplace(ImageShow,&workImg); // 输出检测结果

 m_ImageType=-2;
 Invalidate();
}

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

(0)

相关推荐

  • OpenCV利用背景建模检测运动物体

    本文实例为大家分享了OpenCV利用背景建模检测运动物体的具体代码,供大家参考,具体内容如下 #include <opencv\highgui.h> #include <stdio.h> int main( int argc, char** argv ){ IplImage* pFrame = NULL; IplImage* pFrImg = NULL; IplImage* pBkImg = NULL; CvMat* pFrameMat = NULL; CvMat* pFrMat

  • OpenCV实现人脸检测

    前段日子,写了个人脸检测的小程序,可以检测标记图片.视频.摄像头中的人脸.效果还行吧,用的是opencv提供人脸库.至于具体的人脸检测原理,找资料去啃吧. 环境:VS2013+OPENCV2.4.10+Win8.1 一.基于对话框的MFC 首先,新建一个基于对话框的MFC应用程序,命名为myFaceDetect(取消"安全开发周期(SDL)检查"勾选,我自己习惯取消这个). 放置Button,设置Button的ID和Caption. 图片按钮--ID:IDC_FACEDETECT 视频

  • opencv实现图片与视频中人脸检测功能

    本文实例为大家分享了opencv实现人脸检测功能的具体代码,供大家参考,具体内容如下 第一章:反思与总结 上一篇博客我相信自己将人脸检测中的AdaBoost算法解释的非常清晰了,以及如何训练人脸检测的强分类器:人脸检测中AdaBoost算法详解.事后,自我感觉对这个人脸检测还是不够具体,所以自己抽了一下午的时间用opencv实现图片与视频中的人脸检测,下面是我用vs2013加opencv4.9来实现的.做一下声明,我的代码是参考OpenCV实现人脸检测的一个博客写的,非常感谢这位博主,我学到了很

  • 基于OpenCv的运动物体检测算法

    基于一个实现的基于OpenCv的运动物体检测算法,可以用于检测行人或者其他运动物体. #include <stdio.h> #include <cv.h> #include <cxcore.h> #include <highgui.h> int main( int argc, char** argv ) //声明IplImage指针 IplImage* pFrame = NULL; IplImage* pFrImg = NULL; IplImage* pBk

  • 基于MFC和OpenCV实现角点检测

    本文实例为大家分享了MFC和OpenCV实现角点检测的具体代码,供大家参考,具体内容如下 // 角点检测 // 根据<基于OpenCV的计算机视觉技术实现> #define max_corners 200; // 限定的最大角点数 IplImage* srcImage = 0; // 待处理的源图像 IplImage* ImageShow = 0; // 存储显示带角点的图像 IplImage* grayImage = 0; // 原始图像转换成的灰阶图像 IplImage* corners1

  • opencv实现角点检测

    本文实例为大家分享了opencv实现角点检测的具体代码,供大家参考,具体内容如下 1.特征点的作用:使用特征点代表图像内容 运动目标跟踪物体识别图像配准全景图像拼接三维重建 2.Harris角点检测基本思想 角点定义 :窗口向任意方向的移动都导致图像灰度的明显变化 平坦区域:任意方向移动,无灰度变化 边缘: 沿着边缘方向移动,无灰度变化 #include "opencv2/opencv.hpp" #include <iostream> using namespace cv;

  • OpenCV特征提取与检测之Harris角点检测

    目录 前言 1. 效果图 2. 原理 3. 源码 3.1 Harris角点检测 3.2 精细角点检测 总结 前言 这篇博客将了解什么是特征,角点,哈里斯角点检测(Harris Corner Detection)的概念.并使用cv2.cornerHarris(),cv2.cornerSubPix()实现哈里斯角点检测: 1. 效果图 原图 VS Harris角点检测效果图如下: 原图 VS Harris角点检测效果图如下: 惊细角点效果图如下:Harris角点用红色像素标记,精细角点用绿色像素标记

  • Android基于OpenCV实现Harris角点检测

    目录 什么是角点? 为什么要检测角点? Harris角点检测 API 操作 效果 源码 什么是角点? 角点就是极值点,即在某方面属性特别突出的点.当然,你可以自己定义角点的属性(设置特定熵值进行角点检测).角点可以是两条线的交叉处,也可以是位于相邻的两个主要方向不同的事物上的点.角点通常被定义为两条边的交点,或者说,角点的局部邻域应该具有两个不同区域的不同方向的边界.常见的角点有: 灰度梯度的最大值对应的像素点: 两条直线或者曲线的交点: 一阶梯度的导数最大值和梯度方向变化率最大的像素点: 一阶

  • OpenCV基于ORB算法实现角点检测

    本文实例为大家分享了OpenCV基于ORB算法实现角点检测的具体代码,供大家参考,具体内容如下 ORB算法是FAST算法和BRIEF算法的结合,ORB可以用来对图像中的关键点快速创建特征向量,并用这些特征向量来识别图像中的对象. 实例化ORB orb = cv.ORB_create(nfeatures) 参数: nfeatures:特征点的最大数量 利用orb.detectAndCompute()检测关键点并计算 kp, des = orb.detectAndCompute(gray, None

  • OpenCV角点检测的实现示例

    目录 Harris 角点检测算法 1. 角点 角点检测算法的基本思想: 2. 流程 3. 实现 Harris 角点检测算法 1. 角点 角点是水平方向.垂直方向变化都很大的像素. 角点检测算法的基本思想: 使用一个固定窗口在图像上进行任意方向上的滑动,比较滑动前与滑动后两种情况,窗口中的像素灰度变化程度,如果存在任意方向上的滑动,都有着较大灰度变化,那么我们可以认为该窗口中存在角点. 目前,角点检测算法还不是十分完善,许多算法需要依赖大量的训练集和冗余数据来防止和减少错误的特征的出现.对于角点检

  • 基于OpenCV的路面质量检测的实现

    本期我们将展示一种对路面类型和质量进行分类的方法及其步骤.为了测试这种方法,我们使用了我们制作的RTK数据集. 路面分类 该数据集[1]包含用低成本相机拍摄的图像,以及新兴国家常见的场景,其中包含未铺砌的道路和坑洼.路面类型是有关人或自动驾驶车辆应如何驾驶的重要信息.除了乘客舒适度和车辆维护以外,它还涉及每个人的安全.我们可以通过[2]中的简单卷积神经网络(CNN)结构来实现. 在这种方法中,我们对表面类型分类任务使用特定的模型,我们将其定义为以下类别:沥青,已铺设(用于所有其他类型的路面)和未

  • python opencv角点检测连线功能的实现代码

    原始图 角点检测 points = cv2.goodFeaturesToTrack(gray, 100, 0.01, 10) points = np.int0(points).reshape(-1,2) for point in points: x, y = point.ravel() cv2.circle(img, (x, y), 10, (0, 255, 0), -1) 连线 cv2.line(img, (0, y1), (1000, y1), (0, 255, 0), thickness=

  • 基于python的opencv图像处理实现对斑马线的检测示例

    基本思路 斑马线检测通过opencv图像处理来进行灰度值转换.高斯滤波去噪.阈值处理.腐蚀和膨胀后对图像进行轮廓检测,通过判断车辆和行人的位置,以及他们之间的距离信息,当车速到超过一定阈值时并且与行人距离较近时,则会被判定车辆为未礼让行人. 结果示例 实验流程 先通过视频截取一张图片来进行测试,如果结果满意之后再嵌套到视频中,从而达到想要的效果. 1.预处理(灰度值转换.高斯滤波去噪.阈值处理.腐蚀和膨胀)> 根据自己的需求来修改一些值 #灰度值转换 imgGray = cv2.cvtColor

随机推荐