5#include <visp3/core/vpConfig.h>
6#include <visp3/core/vpImage.h>
7#include <visp3/gui/vpDisplayFactory.h>
8#include <visp3/io/vpImageIo.h>
10#if defined(VISP_HAVE_MODULE_IMGPROC)
12#include <visp3/imgproc/vpImgproc.h>
16int main(
int argc,
const char **argv)
19#if defined(VISP_HAVE_MODULE_IMGPROC) && (defined(VISP_HAVE_X11) || defined(VISP_HAVE_GDI) || defined(VISP_HAVE_OPENCV))
22#ifdef ENABLE_VISP_NAMESPACE
26 std::string input_filename =
"img.pgm";
29 for (
int i = 1;
i < argc;
i++) {
30 if (std::string(argv[i]) ==
"--input" && i + 1 < argc) {
31 input_filename = std::string(argv[i + 1]);
33 else if (std::string(argv[i]) ==
"--connexity" && i + 1 < argc) {
36 else if (std::string(argv[i]) ==
"--help" || std::string(argv[i]) ==
"-h") {
37 std::cout <<
"Usage: " << argv[0]
38 <<
" [--input <input image>] [--connexity <0: 4-connexity, "
39 "1: 8-connexity>] [--help]"
50#if (VISP_CXX_STANDARD >= VISP_CXX_STANDARD_11)
60 std::cout <<
"nbComponents=" << nbComponents << std::endl;
65 for (
unsigned int i = 0;
i < I_conn.getHeight();
i++) {
66 for (
unsigned int j = 0;
j < I_conn.getWidth();
j++) {
67 if (labels[i][j] != 0) {
76#if (VISP_CXX_STANDARD >= VISP_CXX_STANDARD_11)
89#if (VISP_CXX_STANDARD < VISP_CXX_STANDARD_11)
90 if (display !=
nullptr) {
94 if (display2 !=
nullptr) {
static vpColor getColor(const unsigned int &i)
Class that defines generic functionalities for display.
static bool getClick(const vpImage< unsigned char > &I, bool blocking=true)
static void display(const vpImage< unsigned char > &I)
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)
static void read(vpImage< unsigned char > &I, const std::string &filename, int backend=IO_DEFAULT_BACKEND)
Definition of the vpImage class member functions.
VISP_EXPORT void connectedComponents(const VISP_NAMESPACE_ADDRESSING vpImage< unsigned char > &I, VISP_NAMESPACE_ADDRESSING vpImage< int > &labels, int &nbComponents, const VISP_NAMESPACE_ADDRESSING vpImageMorphology::vpConnexityType &connexity=VISP_NAMESPACE_ADDRESSING vpImageMorphology::CONNEXITY_4)
std::shared_ptr< vpDisplay > createDisplay()
Return a smart pointer vpDisplay specialization if a GUI library is available or nullptr otherwise.
vpDisplay * allocateDisplay()
Return a newly allocated vpDisplay specialization if a GUI library is available or nullptr otherwise.