Visual Servoing Platform  version 3.6.1 under development (2024-07-27)
tutorial-barcode-detector-live.cpp
1 #include <visp3/core/vpConfig.h>
3 #include <visp3/core/vpImageConvert.h>
4 #include <visp3/detection/vpDetectorDataMatrixCode.h>
5 #include <visp3/detection/vpDetectorQRCode.h>
6 #include <visp3/gui/vpDisplayGDI.h>
7 #include <visp3/gui/vpDisplayOpenCV.h>
8 #include <visp3/gui/vpDisplayX.h>
9 #ifdef VISP_HAVE_MODULE_SENSOR
10 #include <visp3/sensor/vpV4l2Grabber.h>
11 #endif
12 
13 #if defined(HAVE_OPENCV_VIDEOIO)
14 #include <opencv2/videoio.hpp>
15 #endif
16 
17 int main(int argc, const char **argv)
18 {
19 #if (defined(VISP_HAVE_V4L2) || defined(HAVE_OPENCV_VIDEOIO)) && (defined(VISP_HAVE_ZBAR) || defined(VISP_HAVE_DMTX))
20 #ifdef ENABLE_VISP_NAMESPACE
21  using namespace VISP_NAMESPACE_NAME;
22 #endif
23  int opt_device = 0;
24  int opt_barcode = 0; // 0=QRCode, 1=DataMatrix
25 
26  for (int i = 0; i < argc; i++) {
27  if (std::string(argv[i]) == "--device")
28  opt_device = atoi(argv[i + 1]);
29  else if (std::string(argv[i]) == "--code-type")
30  opt_barcode = atoi(argv[i + 1]);
31  else if (std::string(argv[i]) == "--help" || std::string(argv[i]) == "-h") {
32  std::cout << "Usage: " << argv[0]
33  << " [--device <camera number>] [--code-type <0 for QR code | "
34  "1 for DataMatrix code>] [--help] [-h]"
35  << std::endl;
36  return EXIT_SUCCESS;
37  }
38  }
39  std::cout << "Use device: " << opt_device << std::endl;
40 
41  try {
42  vpImage<unsigned char> I; // for gray images
43 
45 #if defined(VISP_HAVE_V4L2)
46  vpV4l2Grabber g;
47  std::ostringstream device;
48  device << "/dev/video" << opt_device;
49  g.setDevice(device.str());
50  g.setScale(1);
51  g.acquire(I);
52 #elif defined(HAVE_OPENCV_VIDEOIO)
53  cv::VideoCapture cap(opt_device); // open the default camera
54  if (!cap.isOpened()) { // check if we succeeded
55  std::cout << "Failed to open the camera" << std::endl;
56  return EXIT_FAILURE;
57  }
58  cv::Mat frame;
59  cap >> frame; // get a new frame from camera
60  vpImageConvert::convert(frame, I);
61 #endif
63 
64 #if defined(VISP_HAVE_X11)
65  vpDisplayX d(I);
66 #elif defined(VISP_HAVE_GDI)
67  vpDisplayGDI d(I);
68 #elif defined(HAVE_OPENCV_HIGHGUI)
69  vpDisplayOpenCV d(I);
70 #endif
71  vpDisplay::setTitle(I, "ViSP viewer");
72 
73  vpDetectorBase *detector = nullptr;
74 #if (defined(VISP_HAVE_ZBAR) && defined(VISP_HAVE_DMTX))
75  if (opt_barcode == 0)
76  detector = new vpDetectorQRCode;
77  else
78  detector = new vpDetectorDataMatrixCode;
79 #elif defined(VISP_HAVE_ZBAR)
80  detector = new vpDetectorQRCode;
81  (void)opt_barcode;
82 #elif defined(VISP_HAVE_DMTX)
83  detector = new vpDetectorDataMatrixCode;
84  (void)opt_barcode;
85 #endif
86 
87  for (;;) {
89 #if defined(VISP_HAVE_V4L2)
90  g.acquire(I);
91 #elif defined(HAVE_OPENCV_VIDEOIO)
92  cap >> frame; // get a new frame from camera
93  vpImageConvert::convert(frame, I);
94 #endif
97 
98  bool status = detector->detect(I);
99  std::ostringstream legend;
100  legend << detector->getNbObjects() << " bar code detected";
101  vpDisplay::displayText(I, 10, 10, legend.str(), vpColor::red);
102 
103  if (status) {
104  for (size_t i = 0; i < detector->getNbObjects(); i++) {
105  std::vector<vpImagePoint> p = detector->getPolygon(i);
106  vpRect bbox = detector->getBBox(i);
108  vpDisplay::displayText(I, (int)bbox.getTop() - 20, (int)bbox.getLeft(),
109  "Message: \"" + detector->getMessage(i) + "\"", vpColor::red);
110  for (size_t j = 0; j < p.size(); j++) {
111  vpDisplay::displayCross(I, p[j], 14, vpColor::red, 3);
112  std::ostringstream number;
113  number << j;
114  vpDisplay::displayText(I, p[j] + vpImagePoint(10, 0), number.str(), vpColor::blue);
115  }
116  }
117  }
118 
119  vpDisplay::displayText(I, (int)I.getHeight() - 25, 10, "Click to quit...", vpColor::red);
120  vpDisplay::flush(I);
121  if (vpDisplay::getClick(I, false)) // a click to exit
122  break;
123  }
124  delete detector;
125  }
126  catch (const vpException &e) {
127  std::cout << "Catch an exception: " << e << std::endl;
128  }
129 #else
130  (void)argc;
131  (void)argv;
132 #endif
133 }
static const vpColor red
Definition: vpColor.h:217
static const vpColor blue
Definition: vpColor.h:223
static const vpColor green
Definition: vpColor.h:220
std::vector< std::vector< vpImagePoint > > & getPolygon()
vpRect getBBox(size_t i) const
size_t getNbObjects() const
std::vector< std::string > & getMessage()
virtual bool detect(const vpImage< unsigned char > &I)=0
Display for windows using GDI (available on any windows 32 platform).
Definition: vpDisplayGDI.h:130
The vpDisplayOpenCV allows to display image using the OpenCV library. Thus to enable this class OpenC...
Use the X11 console to display images on unix-like OS. Thus to enable this class X11 should be instal...
Definition: vpDisplayX.h:135
static bool getClick(const vpImage< unsigned char > &I, bool blocking=true)
static void display(const vpImage< unsigned char > &I)
static void displayCross(const vpImage< unsigned char > &I, const vpImagePoint &ip, unsigned int size, const vpColor &color, unsigned int thickness=1)
static void setTitle(const vpImage< unsigned char > &I, const std::string &windowtitle)
static void flush(const vpImage< unsigned char > &I)
static void displayRectangle(const vpImage< unsigned char > &I, const vpImagePoint &topLeft, unsigned int width, unsigned int height, const vpColor &color, bool fill=false, unsigned int thickness=1)
static void displayText(const vpImage< unsigned char > &I, const vpImagePoint &ip, const std::string &s, const vpColor &color)
error that can be emitted by ViSP classes.
Definition: vpException.h:60
static void convert(const vpImage< unsigned char > &src, vpImage< vpRGBa > &dest)
Class that defines a 2D point in an image. This class is useful for image processing and stores only ...
Definition: vpImagePoint.h:82
unsigned int getHeight() const
Definition: vpImage.h:181
Defines a rectangle in the plane.
Definition: vpRect.h:79
double getLeft() const
Definition: vpRect.h:173
double getTop() const
Definition: vpRect.h:192
Class that is a wrapper over the Video4Linux2 (V4L2) driver.
void setScale(unsigned scale=vpV4l2Grabber::DEFAULT_SCALE)
void setDevice(const std::string &devname)
void acquire(vpImage< unsigned char > &I)