1 #include <visp3/detection/vpDetectorDataMatrixCode.h>
4 #include <visp3/detection/vpDetectorQRCode.h>
6 #include <visp3/gui/vpDisplayGDI.h>
7 #include <visp3/gui/vpDisplayOpenCV.h>
8 #include <visp3/gui/vpDisplayX.h>
9 #include <visp3/io/vpImageIo.h>
11 int main(
int argc,
const char **argv)
14 #if (defined(VISP_HAVE_ZBAR) || defined(VISP_HAVE_DMTX)) && \
15 (defined(VISP_HAVE_X11) || defined(VISP_HAVE_GDI) || defined(VISP_HAVE_OPENCV))
17 #ifdef ENABLE_VISP_NAMESPACE
26 #elif defined(VISP_HAVE_GDI)
28 #elif defined(HAVE_OPENCV_HIGHGUI)
36 #if (defined(VISP_HAVE_ZBAR) && defined(VISP_HAVE_DMTX))
39 for (
int i = 0; i < argc; i++) {
40 if (std::string(argv[i]) ==
"--code-type")
41 opt_barcode = atoi(argv[i + 1]);
42 else if (std::string(argv[i]) ==
"--help" || std::string(argv[i]) ==
"-h") {
43 std::cout <<
"Usage: " << argv[0] <<
" [--code-type <0 for QR code | 1 for DataMatrix code>] [--help] [-h]"
50 detector =
new vpDetectorQRCode;
54 #elif defined(VISP_HAVE_ZBAR)
55 detector =
new vpDetectorQRCode;
58 #elif defined(VISP_HAVE_DMTX)
67 bool status = detector->
detect(I);
69 std::ostringstream legend;
70 legend << detector->
getNbObjects() <<
" bar code detected";
78 std::vector<vpImagePoint> p = detector->
getPolygon(i);
86 for (
size_t j = 0; j < p.size(); j++) {
88 std::ostringstream number;
101 std::cout <<
"Catch an exception: " << e.
getMessage() << std::endl;
static const vpColor blue
static const vpColor green
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).
The vpDisplayOpenCV allows to display image using the OpenCV library. Thus to enable this class OpenC...
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 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.
const char * getMessage() const
static void read(vpImage< unsigned char > &I, const std::string &filename, int backend=IO_DEFAULT_BACKEND)
Class that defines a 2D point in an image. This class is useful for image processing and stores only ...
unsigned int getHeight() const
Defines a rectangle in the plane.