1 #include <visp/vpDetectorDataMatrixCode.h>
4 #include <visp/vpDetectorQRCode.h>
6 #include <visp/vpDisplayGDI.h>
7 #include <visp/vpDisplayOpenCV.h>
8 #include <visp/vpDisplayX.h>
9 #include <visp/vpImageIo.h>
11 int main(
int argc,
const char** argv)
14 #if (defined(VISP_HAVE_ZBAR) || defined(VISP_HAVE_DMTX)) && (defined(VISP_HAVE_X11) || defined(VISP_HAVE_GDI) || defined(VISP_HAVE_OPENCV))
22 #elif defined(VISP_HAVE_GDI)
24 #elif defined(VISP_HAVE_OPENCV)
32 #if (defined(VISP_HAVE_ZBAR) && defined(VISP_HAVE_DMTX))
35 for (
int i=0; i<argc; i++) {
36 if (std::string(argv[i]) ==
"--code-type")
37 opt_barcode = atoi(argv[i+1]);
38 else if (std::string(argv[i]) ==
"--help") {
39 std::cout <<
"Usage: " << argv[0]
40 <<
" [--code-type <0 for QRcode | 1 for DataMatrix>] [--help]"
51 #elif defined(VISP_HAVE_ZBAR)
55 #elif defined(VISP_HAVE_DMTX)
64 bool status = detector->
detect(I);
66 std::ostringstream legend;
67 legend << detector->
getNbObjects() <<
" bar code detected";
75 std::vector<vpImagePoint> p = detector->
getPolygon(i);
81 "Message: \"" + detector->getMessage(i) + "\"",
84 for(
size_t j=0; j < p.size(); j++) {
86 std::ostringstream number;
99 std::cout <<
"Catch an exception: " << e << std::endl;
Display for windows using GDI (available on any windows 32 platform).
Class to define colors available for display functionnalities.
static void displayText(const vpImage< unsigned char > &I, const vpImagePoint &ip, const std::string &s, const vpColor &color)
Define the X11 console to display images.
error that can be emited by ViSP classes.
virtual bool detect(const vpImage< unsigned char > &I)=0
size_t getNbObjects() const
static const vpColor green
static void flush(const vpImage< unsigned char > &I)
std::vector< std::vector< vpImagePoint > > & getPolygon()
static void display(const vpImage< unsigned char > &I)
The vpDisplayOpenCV allows to display image using the opencv library.
virtual void displayCross(const vpImagePoint &ip, unsigned int size, const vpColor &color, unsigned int thickness=1)=0
virtual void displayRectangle(const vpImagePoint &topLeft, unsigned int width, unsigned int height, const vpColor &color, bool fill=false, unsigned int thickness=1)=0
unsigned int getHeight() const
Defines a rectangle in the plane.
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 ...
vpRect getBBox(size_t i) const
static void read(vpImage< unsigned char > &I, const char *filename)
static const vpColor blue