Visual Servoing Platform  version 3.0.0
testKeyPoint.cpp
1 /****************************************************************************
2  *
3  * This file is part of the ViSP software.
4  * Copyright (C) 2005 - 2015 by Inria. All rights reserved.
5  *
6  * This software is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * ("GPL") version 2 as published by the Free Software Foundation.
9  * See the file LICENSE.txt at the root directory of this source
10  * distribution for additional information about the GNU GPL.
11  *
12  * For using ViSP with software that can not be combined with the GNU
13  * GPL, please contact Inria about acquiring a ViSP Professional
14  * Edition License.
15  *
16  * See http://visp.inria.fr for more information.
17  *
18  * This software was developed at:
19  * Inria Rennes - Bretagne Atlantique
20  * Campus Universitaire de Beaulieu
21  * 35042 Rennes Cedex
22  * France
23  *
24  * If you have questions regarding the use of this file, please contact
25  * Inria at visp@inria.fr
26  *
27  * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
28  * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
29  *
30  * Description:
31  * Test keypoint matching.
32  *
33  * Authors:
34  * Souriya Trinh
35  *
36  *****************************************************************************/
37 
38 #include <iostream>
39 
40 #include <visp3/core/vpConfig.h>
41 
42 #if defined(VISP_HAVE_OPENCV) && (VISP_HAVE_OPENCV_VERSION >= 0x020301)
43 
44 #include <visp3/vision/vpKeyPoint.h>
45 #include <visp3/core/vpImage.h>
46 #include <visp3/io/vpImageIo.h>
47 #include <visp3/gui/vpDisplayX.h>
48 #include <visp3/gui/vpDisplayGTK.h>
49 #include <visp3/gui/vpDisplayGDI.h>
50 #include <visp3/gui/vpDisplayOpenCV.h>
51 #include <visp3/io/vpVideoReader.h>
52 #include <visp3/core/vpIoTools.h>
53 #include <visp3/io/vpParseArgv.h>
54 
55 // List of allowed command line options
56 #define GETOPTARGS "cdh"
57 
58 void usage(const char *name, const char *badparam);
59 bool getOptions(int argc, const char **argv, bool &click_allowed, bool &display);
60 
69 void usage(const char *name, const char *badparam)
70 {
71  fprintf(stdout, "\n\
72 Test keypoints matching.\n\
73 \n\
74 SYNOPSIS\n\
75  %s [-c] [-d] [-h]\n", name);
76 
77  fprintf(stdout, "\n\
78 OPTIONS: \n\
79 \n\
80  -c\n\
81  Disable the mouse click. Useful to automate the \n\
82  execution of this program without human intervention.\n\
83 \n\
84  -d \n\
85  Turn off the display.\n\
86 \n\
87  -h\n\
88  Print the help.\n");
89 
90  if (badparam)
91  fprintf(stdout, "\nERROR: Bad parameter [%s]\n", badparam);
92 }
93 
105 bool getOptions(int argc, const char **argv, bool &click_allowed, bool &display)
106 {
107  const char *optarg_;
108  int c;
109  while ((c = vpParseArgv::parse(argc, argv, GETOPTARGS, &optarg_)) > 1) {
110 
111  switch (c) {
112  case 'c': click_allowed = false; break;
113  case 'd': display = false; break;
114  case 'h': usage(argv[0], NULL); return false; break;
115 
116  default:
117  usage(argv[0], optarg_);
118  return false; break;
119  }
120  }
121 
122  if ((c == 1) || (c == -1)) {
123  // standalone param or error
124  usage(argv[0], NULL);
125  std::cerr << "ERROR: " << std::endl;
126  std::cerr << " Bad argument " << optarg_ << std::endl << std::endl;
127  return false;
128  }
129 
130  return true;
131 }
132 
138 int main(int argc, const char ** argv) {
139  try {
140  std::string env_ipath;
141  bool opt_click_allowed = true;
142  bool opt_display = true;
143 
144  // Read the command line options
145  if (getOptions(argc, argv, opt_click_allowed, opt_display) == false) {
146  exit (-1);
147  }
148 
149  // Get the visp-images-data package path or VISP_INPUT_IMAGE_PATH environment variable value
150  env_ipath = vpIoTools::getViSPImagesDataPath();
151 
152  if(env_ipath.empty()) {
153  std::cerr << "Please set the VISP_INPUT_IMAGE_PATH environment variable value." << std::endl;
154  return -1;
155  }
156 
157  vpImage<unsigned char> Iref, Icur, Imatch;
158 
159  //Set the path location of the image sequence
160  std::string dirname = vpIoTools::createFilePath(env_ipath, "ViSP-images/mbt/cube");
161 
162  //Build the name of the image files
163  std::string filenameRef = vpIoTools::createFilePath(dirname, "image0000.pgm");
164  vpImageIo::read(Iref, filenameRef);
165  std::string filenameCur = vpIoTools::createFilePath(dirname, "image%04d.pgm");
166 
167  //Init keypoints
168  vpKeyPoint keypoints("ORB", "ORB", "BruteForce-Hamming");
169  std::cout << "Build " << keypoints.buildReference(Iref) << " reference points." << std::endl;
170 
171  vpVideoReader g;
172  g.setFileName(filenameCur);
173  g.open(Icur);
174  g.acquire(Icur);
175 
176  Imatch.resize(Icur.getHeight(), 2*Icur.getWidth());
177  Imatch.insert(Iref, vpImagePoint(0,0));
178 
179 #if defined VISP_HAVE_X11
180  vpDisplayX display;
181 #elif defined VISP_HAVE_GTK
182  vpDisplayGTK display;
183 #elif defined VISP_HAVE_GDI
184  vpDisplayGDI display;
185 #else
186  vpDisplayOpenCV display;
187 #endif
188 
189  if (opt_display) {
190  display.init(Imatch, 0, 0, "ORB keypoints matching");
191  }
192 
193  bool opt_click = false;
195  while(!g.end()) {
196  g.acquire(Icur);
197  Imatch.insert(Icur, vpImagePoint(0, Icur.getWidth()));
198 
199  if(opt_display) {
200  vpDisplay::display(Imatch);
201  }
202 
203  //Match keypoints
204  keypoints.matchPoint(Icur);
205  //Display image with keypoints matched
206  keypoints.displayMatching(Iref, Imatch);
207 
208  if(opt_display) {
209  vpDisplay::flush(Imatch);
210  }
211 
212  //Click requested to process next image
213  if (opt_click_allowed && opt_display) {
214  if(opt_click) {
215  vpDisplay::getClick(Imatch, button, true);
216  if(button == vpMouseButton::button3) {
217  opt_click = false;
218  }
219  } else {
220  //Use right click to enable/disable step by step tracking
221  if(vpDisplay::getClick(Imatch, button, false)) {
222  if (button == vpMouseButton::button3) {
223  opt_click = true;
224  }
225  else if(button == vpMouseButton::button1) {
226  break;
227  }
228  }
229  }
230  }
231  }
232 
233  } catch(vpException &e) {
234  std::cerr << e.what() << std::endl;
235  return -1;
236  }
237 
238  std::cout << "testKeyPoint is ok !" << std::endl;
239  return 0;
240 }
241 #else
242 int main() {
243  std::cerr << "You need OpenCV library." << std::endl;
244 
245  return 0;
246 }
247 
248 #endif
void init(vpImage< unsigned char > &I, int winx=-1, int winy=-1, const char *title=NULL)
static std::string getViSPImagesDataPath()
Definition: vpIoTools.cpp:1091
unsigned int getWidth() const
Definition: vpImage.h:161
Display for windows using GDI (available on any windows 32 platform).
Definition: vpDisplayGDI.h:128
Define the X11 console to display images.
Definition: vpDisplayX.h:148
Class that enables to manipulate easily a video file or a sequence of images. As it inherits from the...
error that can be emited by ViSP classes.
Definition: vpException.h:73
static void flush(const vpImage< unsigned char > &I)
Definition: vpDisplay.cpp:2233
static bool parse(int *argcPtr, const char **argv, vpArgvInfo *argTable, int flags)
Definition: vpParseArgv.cpp:76
void open(vpImage< vpRGBa > &I)
const char * what() const
static std::string createFilePath(const std::string &parent, const std::string child)
Definition: vpIoTools.cpp:1265
static void display(const vpImage< unsigned char > &I)
Definition: vpDisplay.cpp:206
The vpDisplayOpenCV allows to display image using the opencv library.
The vpDisplayGTK allows to display image using the GTK+ library version 1.2.
Definition: vpDisplayGTK.h:141
void acquire(vpImage< vpRGBa > &I)
void resize(const unsigned int h, const unsigned int w)
set the size of the image without initializing it.
Definition: vpImage.h:616
void setFileName(const char *filename)
Class that allows keypoints detection (and descriptors extraction) and matching thanks to OpenCV libr...
Definition: vpKeyPoint.h:213
void insert(const vpImage< Type > &src, const vpImagePoint topLeft)
Definition: vpImage.h:935
unsigned int getHeight() const
Definition: vpImage.h:152
virtual bool getClick(bool blocking=true)=0
Class that defines a 2D point in an image. This class is useful for image processing and stores only ...
Definition: vpImagePoint.h:88
static void read(vpImage< unsigned char > &I, const char *filename)
Definition: vpImageIo.cpp:274