2 #include <visp3/core/vpConfig.h>
3 #include <visp3/core/vpIoTools.h>
4 #include <visp3/core/vpPixelMeterConversion.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 #include <visp3/io/vpImageIo.h>
10 #include <visp3/vision/vpPose.h>
12 #include "pose_helper.h"
14 int main(
int,
char *argv[])
16 #if defined(VISP_HAVE_ZBAR)
17 #ifdef ENABLE_VISP_NAMESPACE
24 #if defined(VISP_HAVE_X11)
26 #elif defined(VISP_HAVE_GDI)
28 #elif defined(HAVE_OPENCV_HIGHGUI)
36 std::vector<vpPoint> point;
37 point.push_back(
vpPoint(-0.06, -0.06, 0));
38 point.push_back(
vpPoint(0.06, -0.06, 0));
39 point.push_back(
vpPoint(0.06, 0.06, 0));
40 point.push_back(
vpPoint(-0.06, 0.06, 0));
45 vpDetectorQRCode detector;
51 bool status = detector.detect(I);
53 std::ostringstream legend;
54 legend << detector.getNbObjects() <<
" bar code detected";
58 for (
size_t i = 0; i < detector.getNbObjects(); i++) {
60 std::vector<vpImagePoint> p = detector.getPolygon(i);
62 for (
size_t j = 0; j < p.size(); j++) {
64 std::ostringstream number;
69 computePose(point, p, cam, init, cMo);
85 std::cout <<
"Catch an exception: " << e.
getMessage() << std::endl;
89 std::cout <<
"ViSP is not build with zbar 3rd party." << std::endl;
Generic class defining intrinsic camera parameters.
static const vpColor none
static const vpColor blue
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 displayFrame(const vpImage< unsigned char > &I, const vpHomogeneousMatrix &cMo, const vpCameraParameters &cam, double size, const vpColor &color=vpColor::none, unsigned int thickness=1, const vpImagePoint &offset=vpImagePoint(0, 0), const std::string &frameName="", const vpColor &textColor=vpColor::black, const vpImagePoint &textOffset=vpImagePoint(15, 15))
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 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
Implementation of an homogeneous matrix and operations on such kind of matrices.
vpRotationMatrix getRotationMatrix() const
vpTranslationVector getTranslationVector() 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 getWidth() const
unsigned int getHeight() const
Class that defines a 3D point in the object frame and allows forward projection of a 3D point in the ...
Implementation of a rotation vector as quaternion angle minimal representation.
VISP_EXPORT int wait(double t0, double t)