Visual Servoing Platform version 3.7.0
Loading...
Searching...
No Matches
manGrabDisk.cpp
1/*
2 * ViSP, open source Visual Servoing Platform software.
3 * Copyright (C) 2005 - 2025 by Inria. All rights reserved.
4 *
5 * This software is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 * See the file LICENSE.txt at the root directory of this source
10 * distribution for additional information about the GNU GPL.
11 *
12 * For using ViSP with software that can not be combined with the GNU
13 * GPL, please contact Inria about acquiring a ViSP Professional
14 * Edition License.
15 *
16 * See https://visp.inria.fr for more information.
17 *
18 * This software was developed at:
19 * Inria Rennes - Bretagne Atlantique
20 * Campus Universitaire de Beaulieu
21 * 35042 Rennes Cedex
22 * France
23 *
24 * If you have questions regarding the use of this file, please contact
25 * Inria at visp@inria.fr
26 *
27 * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
28 * WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
29 *
30 * Description:
31 * Images grabbing example.
32 */
45
46#include <visp3/core/vpConfig.h>
47
48#include <visp3/core/vpImage.h>
49#include <visp3/io/vpDiskGrabber.h>
50
51int main()
52{
53#ifdef ENABLE_VISP_NAMESPACE
54 using namespace VISP_NAMESPACE_NAME;
55#endif
56
57 try {
58 vpImage<unsigned char> I; // Grey level image
59
60 // Declare a framegrabber able to read a sequence of successive
61 // images from the disk
63
64 // Set the path to the directory containing the sequence
65 g.setDirectory("/tmp");
66 // Set the image base name. The directory and the base name constitute
67 // the constant part of the full filename
68 g.setBaseName("image");
69 // Set the step between two images of the sequence
70 g.setStep(3);
71 // Set the number of digits to build the image number
72 g.setNumberOfZero(4);
73 // Set the first frame number of the sequence
74 g.setImageNumber(1);
75 // Set the file extension of the images of the sequence
76 g.setExtension("pgm");
77
78 // Open the framegrabber by loading the first image of the sequence
79 g.open(I);
80
81 // this is the loop over the image sequence
82 for (int cpt = 0; cpt < 100; cpt++) {
83 // read the image and then increment the image counter so that the next
84 // call to acquire(I) will get the next image
85 g.acquire(I);
86 }
87
88 return EXIT_SUCCESS;
89 }
90 catch (const vpException &e) {
91 std::cout << "Catch an exception: " << e << std::endl;
92 return EXIT_FAILURE;
93 }
94}
Class to grab (ie. read) images from the disk.
void setStep(long step)
void setDirectory(const std::string &dir)
void setExtension(const std::string &ext)
void open(vpImage< unsigned char > &I) VP_OVERRIDE
void acquire(vpImage< unsigned char > &I) VP_OVERRIDE
void setImageNumber(long number)
void setNumberOfZero(unsigned int noz)
void setBaseName(const std::string &name)
error that can be emitted by ViSP classes.
Definition vpException.h:60
Definition of the vpImage class member functions.
Definition vpImage.h:131