在opencv中,特征检测、描述、匹配都有集成的函数。vector<DMatch> bestMatches;用来存储得到的匹配点对。那么如何提取出其中的坐标呢?
int index1, index2; for (int i = 0; i < bestMatches.size(); i++)//将匹配的特征点坐标赋给point { index1 = bestMatches.at(i).queryIdx; index2 = bestMatches.at(i).trainIdx; cout << keyImg1.at(index1).pt.x << " " << keyImg1.at(index1).pt.y << " " << keyImg2.at(index2).pt.x << " " << keyImg2.at(index2).pt.y << endl; }
补充知识:OpenCV 如何获取一个连通域中的所有坐标点
#include "stdafx.h" #include "cv.h" #include "highgui.h" #include "cxcore.h" int main(int argc, char* argv[]) { IplImage* img; img = cvLoadImage("D:\\OOTT\\WEEK5\\2.png"); IplImage* gray = cvCreateImage(cvGetSize(img),IPL_DEPTH_8U,1); cvCvtColor(img,gray,CV_BGR2GRAY); cvThreshold(gray,gray,128,255,CV_THRESH_BINARY); CvMemStorage* storage = cvCreateMemStorage(); CvSeq * first_contour = NULL; int Ncontour = cvFindContours(gray,storage,&first_contour,sizeof(CvContour),CV_RETR_LIST); //Ncontour为cvFindContours函数返回的轮廓个数 for(CvSeq* c = first_contour;c!= NULL;c=c->h_next) { // cvDrawContours(img,c,cvScalar(255,255,0),cvScalar(255,0,255),0,2,8); cvNamedWindow("contours",CV_WINDOW_AUTOSIZE); // cvShowImage("contours",img); for(int k = 0;k <c->total;++k) { CvPoint* p = CV_GET_SEQ_ELEM(CvPoint,c,k); printf("(%d,%d)\n",p->x,p->y); } CvRect rect; rect = cvBoundingRect(c,0); cvFloodFill(img,cvPoint(img->width/2,img->height/2),cvScalar(255,255,255),cvScalar(20),cvScalar(20),NULL,4,NULL); cvShowImage("contours",img); int Num[500][500]; for (int i=0;i<(img->height-5);i++) for (int j=0;j<(img->width-5);j++) { CvScalar S0; S0=cvGet2D(img,i,j); if(S0.val[0] == 255) Num[i][j]=1; else Num[i][j]=0; printf("(%d,%d)\n",i,j); } } cvWaitKey(0); cvReleaseImage(&img); cvReleaseImage(&gray); cvDestroyWindow("contours"); return 0; }
以上这篇使用opencv中匹配点对的坐标提取方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
形状多边形的例子
问题内容: 我正在尝试实现一个非常简单的程序来查找两个图像之间的相似性。 我正在为此任务使用ORB特征检测器和图像描述符,并且正在使用 knnMatch 识别匹配 项 : 我能够按照以下方式绘制比赛: 问题是比赛太多,而且还包括相距遥远的比赛。我似乎找不到如何仅提取好的匹配项(超过某个阈值)?有人可以指出我正确的方向还是将我重定向到一些基本的工作示例?我已经花了几个小时,似乎迷路了。 问题答案:
有可能吗?如果是,那么它可以怎么做。
嗨,这个问题是指之前的帖子: 有人能给我举个例子,说明如何使用PDFBox提取“单词”的坐标吗 我使用的是PDFBOX 2.0.10 我已成功编译了组合代码,但在尝试运行示例时出现异常错误。 提供的解决方案没有标准的主方法,这是我感到困惑的地方。 有人能告诉我怎样才能成功运行组合代码吗。 堆栈跟踪 可以在这里找到坐标https://github.com/mkl-public/testarea-pd
问题内容: 我已将一些地址上传到BatchGeo,并下载了要从中提取坐标的结果KML文件。我设法在这里在线整理了混乱的文本文件,但是我不知道如何解析它以提取坐标。 似乎有几个适用于python的kml库,但在文档方面却没有太多(例如pyKML)。通过本教程,我已经了解了这一点,并创建了一个’lxml.etree._ElementTree’对象,但不确定其属性: 这给出了错误: 那么如何获取坐标列表
Im使用java中的OpenCV,使用eclipse开发,图像以这种方式读取以进行模板匹配。 这很好,但我的图像不在本地计算机中。我应该比较mysql数据库中服务器上的2000个图像。把2000张图片保存到我的电脑上,然后读取它们是没有意义的。 所以我需要的是那个高鬼。imread(infle)读取图像:Highgui。imread(图像中的图像)或Highgui。imread(文件填充),我找不