48 #include <visp3/core/vpConfig.h> 49 #include <visp3/core/vpDebug.h> 56 #include <visp3/core/vpImage.h> 57 #include <visp3/gui/vpDisplayX.h> 58 #include <visp3/io/vpImageIo.h> 60 #include <visp3/core/vpIoTools.h> 61 #include <visp3/io/vpParseArgv.h> 74 #define GETOPTARGS "cdi:o:h" 87 void usage(
const char *name,
const char *badparam, std::string ipath, std::string opath, std::string user)
90 Read an image on the disk, display it using X11, display some\n\ 91 features (line, circle, caracters) in overlay and finaly write \n\ 92 the image and the overlayed features in an image on the disk.\n\ 95 %s [-i <input image path>] [-o <output image path>]\n\ 101 -i <input image path> %s\n\ 102 Set image input path.\n\ 103 From this path read \"Klimt/Klimt.pgm\"\n\ 104 and \"Klimt/Klimt.ppm\" images.\n\ 105 Setting the VISP_INPUT_IMAGE_PATH environment\n\ 106 variable produces the same behaviour than using\n\ 109 -o <output image path> %s\n\ 110 Set image output path.\n\ 111 From this directory, creates the \"%s\"\n\ 112 subdirectory depending on the username, where \n\ 113 Klimt_grey.overlay.ppm output image is written.\n\ 116 Disable the mouse click. Useful to automate the \n\ 117 execution of this program without humain intervention.\n\ 120 Disable the image display. This can be useful \n\ 121 for automatic tests using crontab under Unix or \n\ 122 using the task manager under Windows.\n\ 125 Print the help.\n\n", ipath.c_str(), opath.c_str(), user.c_str());
128 fprintf(stderr,
"ERROR: \n");
129 fprintf(stderr,
"\nBad parameter [%s]\n", badparam);
150 bool getOptions(
int argc,
const char **argv, std::string &ipath, std::string &opath,
bool &click_allowed,
151 const std::string &user,
bool &display)
159 click_allowed =
false;
171 usage(argv[0], NULL, ipath, opath, user);
176 usage(argv[0], optarg_, ipath, opath, user);
182 if ((c == 1) || (c == -1)) {
184 usage(argv[0], NULL, ipath, opath, user);
185 std::cerr <<
"ERROR: " << std::endl;
186 std::cerr <<
" Bad argument " << optarg_ << std::endl << std::endl;
193 int main(
int argc,
const char **argv)
196 std::string env_ipath;
197 std::string opt_ipath;
198 std::string opt_opath;
201 std::string filename;
202 std::string username;
203 bool opt_click_allowed =
true;
204 bool opt_display =
true;
211 if (!env_ipath.empty())
215 #if !defined(_WIN32) && (defined(__unix__) || defined(__unix) || (defined(__APPLE__) && defined(__MACH__))) // UNIX 217 #elif defined(_WIN32) 218 opt_opath =
"C:\\temp";
225 if (getOptions(argc, argv, opt_ipath, opt_opath, opt_click_allowed, username, opt_display) ==
false) {
230 if (!opt_ipath.empty())
232 if (!opt_opath.empty())
244 usage(argv[0], NULL, ipath, opath, username);
245 std::cerr << std::endl <<
"ERROR:" << std::endl;
246 std::cerr <<
" Cannot create " << odirname << std::endl;
247 std::cerr <<
" Check your -o " << opath <<
" option " << std::endl;
254 if (!opt_ipath.empty() && !env_ipath.empty()) {
255 if (ipath != env_ipath) {
256 std::cout << std::endl <<
"WARNING: " << std::endl;
257 std::cout <<
" Since -i <visp image path=" << ipath <<
"> " 258 <<
" is different from VISP_IMAGE_PATH=" << env_ipath << std::endl
259 <<
" we skip the environment variable." << std::endl;
264 if (opt_ipath.empty() && env_ipath.empty()) {
265 usage(argv[0], NULL, ipath, opath, username);
266 std::cerr << std::endl <<
"ERROR:" << std::endl;
267 std::cerr <<
" Use -i <visp image path> option or set VISP_INPUT_IMAGE_PATH " << std::endl
268 <<
" environment variable to specify the location of the " << std::endl
269 <<
" image path where test images are located." << std::endl
283 std::cerr << std::endl <<
"ERROR:" << std::endl;
284 std::cerr <<
" Cannot read " << filename << std::endl;
285 std::cerr <<
" Check your -i " << ipath <<
" option " << std::endl
286 <<
" or VISP_INPUT_IMAGE_PATH environment variable." << std::endl;
294 std::cerr << std::endl <<
"ERROR:" << std::endl;
295 std::cerr <<
" Cannot read " << filename << std::endl;
296 std::cerr <<
" Check your -i " << ipath <<
" option " << std::endl
297 <<
" or VISP_INPUT_IMAGE_PATH environment variable." << std::endl;
307 display1.
init(I1, 0, 0,
"X11 Display 1...");
309 display2.
init(I2, 200, 200,
"X11 Display 2...");
315 for (
unsigned int i = 0; i < I1.
getHeight(); i += 20) {
324 for (
unsigned int i = 0; i < I1.
getWidth(); i += 20) {
342 for (
unsigned int i = 0; i < 100; i += 20) {
360 if (opt_click_allowed) {
361 std::cout <<
"\nA click in the first display to draw a cross..." << std::endl;
367 std::cout <<
"Cross position: " << ip << std::endl;
374 std::cout <<
"Cross position: " << ip << std::endl;
390 if (opt_click_allowed) {
391 std::cout <<
"\nA click in the second display to close the windows " 400 std::cout <<
"Catch an exception: " << e << std::endl;
406 std::cout <<
"You do not have X11 functionalities to display images..." << std::endl;
407 std::cout <<
"Tip if you are on a unix-like system:" << std::endl;
408 std::cout <<
"- Install X11, configure again ViSP using cmake and build again this example" << std::endl;
void init(vpImage< unsigned char > &I, int winx=-1, int winy=-1, const std::string &title="")
static bool getClick(const vpImage< unsigned char > &I, bool blocking=true)
static void displayText(const vpImage< unsigned char > &I, const vpImagePoint &ip, const std::string &s, const vpColor &color)
Use the X11 console to display images on unix-like OS. Thus to enable this class X11 should be instal...
error that can be emited by ViSP classes.
static const vpColor green
static void flush(const vpImage< unsigned char > &I)
static bool parse(int *argcPtr, const char **argv, vpArgvInfo *argTable, int flags)
static void write(const vpImage< unsigned char > &I, const std::string &filename)
static void displayArrow(const vpImage< unsigned char > &I, const vpImagePoint &ip1, const vpImagePoint &ip2, const vpColor &color=vpColor::white, unsigned int w=4, unsigned int h=2, unsigned int thickness=1)
static void display(const vpImage< unsigned char > &I)
static void getImage(const vpImage< unsigned char > &Is, vpImage< vpRGBa > &Id)
static void displayCircle(const vpImage< unsigned char > &I, const vpImagePoint ¢er, unsigned int radius, const vpColor &color, bool fill=false, unsigned int thickness=1)
static void displayCross(const vpImage< unsigned char > &I, const vpImagePoint &ip, unsigned int size, const vpColor &color, unsigned int thickness=1)
unsigned int getHeight() const
static void read(vpImage< unsigned char > &I, const std::string &filename)
Class that defines a 2D point in an image. This class is useful for image processing and stores only ...
static const vpColor yellow
unsigned int getWidth() const
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 displayDotLine(const vpImage< unsigned char > &I, const vpImagePoint &ip1, const vpImagePoint &ip2, const vpColor &color, unsigned int thickness=1)
static const vpColor blue