42 #include <visp3/core/vpImage.h>
43 #include <visp3/core/vpImageConvert.h>
44 #include <visp3/core/vpPolygon.h>
45 #include <visp3/core/vpRect.h>
46 #include <visp3/gui/vpDisplayD3D.h>
47 #include <visp3/gui/vpDisplayGDI.h>
48 #include <visp3/gui/vpDisplayGTK.h>
49 #include <visp3/gui/vpDisplayOpenCV.h>
50 #include <visp3/gui/vpDisplayX.h>
51 #include <visp3/io/vpParseArgv.h>
54 #define GETOPTARGS "cdh"
56 #ifdef ENABLE_VISP_NAMESPACE
60 void usage(
const char *name,
const char *badparam);
61 bool getOptions(
int argc,
const char **argv,
bool &click_allowed,
bool &display);
70 void usage(
const char *name,
const char *badparam)
73 Display polygon lines.\n\
82 Disable the mouse click. Useful to automate the \n\
83 execution of this program without human intervention.\n\
86 Disable the image display. This can be useful \n\
87 for automatic tests. \n\
90 Print the help.\n\n");
93 fprintf(stderr,
"ERROR: \n");
94 fprintf(stderr,
"\nBad parameter [%s]\n", badparam);
112 bool getOptions(
int argc,
const char **argv,
bool &click_allowed,
bool &display)
120 click_allowed =
false;
126 usage(argv[0],
nullptr);
131 usage(argv[0], optarg_);
137 if ((c == 1) || (c == -1)) {
139 usage(argv[0],
nullptr);
140 std::cerr <<
"ERROR: " << std::endl;
141 std::cerr <<
" Bad argument " << optarg_ << std::endl << std::endl;
148 int main(
int argc,
const char **argv)
150 #ifdef VISP_HAVE_DISPLAY
151 bool opt_click_allowed =
true;
152 bool opt_display =
true;
155 if (getOptions(argc, argv, opt_click_allowed, opt_display) ==
false) {
159 if (opt_display && opt_click_allowed) {
163 #if defined(VISP_HAVE_X11)
165 #elif defined(VISP_HAVE_GTK)
167 #elif defined(VISP_HAVE_GDI)
169 #elif defined(VISP_HAVE_D3D9)
171 #elif defined(HAVE_OPENCV_HIGHGUI)
174 d.
init(I, 0, 0,
"Grayscale image");
195 d2.init(I_color, I.
getWidth(), 0,
"Color image");
197 for (
unsigned int i = 0; i < I_color.getHeight(); i++) {
198 double hue = i / (double)I_color.getHeight(), saturation = 1.0, value = 1.0;
199 unsigned char rgb[3];
202 for (
unsigned int j = 0; j < I_color.getWidth(); j++) {
203 I_color[i][j].R = rgb[0];
204 I_color[i][j].G = rgb[1];
205 I_color[i][j].B = rgb[2];
static const vpColor black
Display for windows using Direct3D 3rd party. Thus to enable this class Direct3D should be installed....
Display for windows using GDI (available on any windows 32 platform).
The vpDisplayGTK allows to display image using the GTK 3rd party library. Thus to enable this class G...
The vpDisplayOpenCV allows to display image using the OpenCV library. Thus to enable this class OpenC...
void init(vpImage< unsigned char > &I, int winx=-1, int winy=-1, const std::string &title="") VP_OVERRIDE
static bool getClick(const vpImage< unsigned char > &I, bool blocking=true)
static void display(const vpImage< unsigned char > &I)
static void displayLine(const vpImage< unsigned char > &I, const vpImagePoint &ip1, const vpImagePoint &ip2, const vpColor &color, unsigned int thickness=1, bool segment=true)
static void flush(const vpImage< unsigned char > &I)
static void displayDotLine(const vpImage< unsigned char > &I, const vpImagePoint &ip1, const vpImagePoint &ip2, const vpColor &color, unsigned int thickness=1)
static void displayText(const vpImage< unsigned char > &I, const vpImagePoint &ip, const std::string &s, const vpColor &color)
static void HSVToRGB(const double *hue, const double *saturation, const double *value, unsigned char *rgb, unsigned int size)
unsigned int getWidth() const
static bool parse(int *argcPtr, const char **argv, vpArgvInfo *argTable, int flags)
Defines a generic 2D polygon.
const std::vector< vpImagePoint > & getCorners() const
void initClick(const vpImage< unsigned char > &I, unsigned int size=5, const vpColor &color=vpColor::red, unsigned int thickness=1)