54 cout <<
"[Test_SwissRanger] Camera open, serial #" 59 const double aspect_ratio = cam.
rows() / double(cam.
cols());
64 cout <<
"[Test_SwissRanger] Version: " << ver <<
"\n";
68 bool there_is_obs =
true, hard_error;
72 win3D.setCameraAzimuthDeg(140);
73 win3D.setCameraElevationDeg(20);
74 win3D.setCameraZoom(6.0);
75 win3D.setCameraPointingToPoint(2.5, 0, 0);
88 gl_points->setPointSize(4.5);
92 0.5, -0.5, -0.5 * aspect_ratio, 0.5 * aspect_ratio);
95 0.5, -0.5, -0.5 * aspect_ratio, 0.5 * aspect_ratio);
98 0.5, -0.5, -0.5 * aspect_ratio, 0.5 * aspect_ratio);
104 scene->insert(gl_points);
108 const int VW_WIDTH = 200;
109 const int VW_HEIGHT = 150;
110 const int VW_GAP = 10;
114 win3D.addTextMessage(
115 30, -10 - 1 * (VW_GAP + VW_HEIGHT),
"Range data", 1);
117 scene->createViewport(
"view2d_range");
118 scene->insert(gl_img_range,
"view2d_range");
119 viewRange->setViewportPosition(
120 5, -10 - 1 * (VW_GAP + VW_HEIGHT), VW_WIDTH, VW_HEIGHT);
121 viewRange->setTransparent(
true);
122 viewRange->getCamera().setOrthogonal(
true);
123 viewRange->getCamera().setAzimuthDegrees(90);
124 viewRange->getCamera().setElevationDegrees(90);
125 viewRange->getCamera().setZoomDistance(1.0);
127 win3D.addTextMessage(
128 30, -10 - 2 * (VW_GAP + VW_HEIGHT),
"Intensity data", 2);
130 scene->createViewport(
"view2d_int");
131 scene->insert(gl_img_intensity,
"view2d_int");
132 viewInt->setViewportPosition(
133 5, -10 - 2 * (VW_GAP + VW_HEIGHT), VW_WIDTH, VW_HEIGHT);
134 viewInt->setTransparent(
true);
135 viewInt->getCamera().setOrthogonal(
true);
136 viewInt->getCamera().setAzimuthDegrees(90);
137 viewInt->getCamera().setElevationDegrees(90);
138 viewInt->getCamera().setZoomDistance(1.0);
140 win3D.addTextMessage(
141 30, -10 - 3 * (VW_GAP + VW_HEIGHT),
"Intensity data (undistorted)",
144 scene->createViewport(
"view2d_intrect");
145 scene->insert(gl_img_intensity_rect,
"view2d_intrect");
146 viewIntRect->setViewportPosition(
147 5, -10 - 3 * (VW_GAP + VW_HEIGHT), VW_WIDTH, VW_HEIGHT);
148 viewIntRect->setTransparent(
true);
149 viewIntRect->getCamera().setOrthogonal(
true);
150 viewIntRect->getCamera().setAzimuthDegrees(90);
151 viewIntRect->getCamera().setElevationDegrees(90);
152 viewIntRect->getCamera().setZoomDistance(1.0);
154 win3D.unlockAccess3DScene();
161 bool endLoop =
false;
163 while (there_is_obs && !endLoop && win3D.isOpen())
173 win3D.get3DSceneAndLock();
174 gl_img_range->assignImage(std::move(img));
175 win3D.unlockAccess3DScene();
181 win3D.get3DSceneAndLock();
186 gl_img_intensity_rect->assignImage(undistortImg);
187 win3D.unlockAccess3DScene();
196 CColouredPointsMap::cmFromIntensityImage;
199 win3D.get3DSceneAndLock();
200 gl_points->loadFromPointsMap(&pntsMap);
201 win3D.unlockAccess3DScene();
208 win3D.get3DSceneAndLock();
209 win3D.addTextMessage(
210 0.01, 0.01,
format(
"%.02f Hz", nImgs / tictac.
Tac()), 100);
211 win3D.unlockAccess3DScene();
220 const int key = tolower(win3D.getPushedKey());
244 win3D.get3DSceneAndLock();
245 win3D.addTextMessage(
248 "Keyboard switches: H (hist.equal: %s) | G (convGray: %s) | D " 249 "(denoise: %s) | F (medianFilter: %s)",
255 win3D.unlockAccess3DScene();
257 std::this_thread::sleep_for(1ms);
268 catch (
const std::exception& e)
275 printf(
"Another exception!!");
double Tac() noexcept
Stops the stopwatch.
static Ptr Create(Args &&... args)
mrpt::img::TCamera cameraParams
Projection parameters of the depth camera.
static Ptr Create(Args &&... args)
void setOpenFromUSB(bool USB)
true: open from USB, false: open from ethernet.
std::string std::string format(std::string_view fmt, ARGS &&... args)
void enableConvGray(bool enable)
bool isEnabledImageHistEqualization() const
A class for grabing "range images" from a MESA imaging SwissRanger 3D cameras (SR-2, SR-3000, SR-4k).
A high-performance stopwatch, with typical resolution of nanoseconds.
A range or depth 3D scan measurement, as from a time-of-flight range camera or a structured-light dep...
double getMaxRange() const
Returns the maximum camera range, as deduced from its operating frequency.
Contains classes for various device interfaces.
void setSave3D(bool save)
TColourOptions colorScheme
The options employed when inserting laser scans in the map.
void initialize() override
Initializes the 3D camera - should be invoked after calling loadConfig()
void enableDenoiseANF(bool enable)
This base provides a set of functions for maths stuff.
bool getMesaLibVersion(std::string &out_version) const
Get the version of the MESA library.
size_t rows() const
Get the row count in the camera images, loaded automatically upon camera open().
mrpt::img::CImage intensityImage
If hasIntensityImage=true, a color or gray-level intensity image of the same size than "rangeImage"...
This namespace contains representation of robot actions and observations.
bool hasRangeImage
true means the field rangeImage contains valid data
A map of 2D/3D points with individual colours (RGB).
void setSaveIntensityImage(bool save)
bool hasPoints3D
true means the field points3D contains valid data.
bool isEnabledDenoiseANF() const
This is the global namespace for all Mobile Robot Programming Toolkit (MRPT) libraries.
bool isOpen() const
whether the camera is open and comms work ok.
CSetOfObjects::Ptr CornerXYZ(float scale=1.0)
Returns three arrows representing a X,Y,Z 3D corner.
void loadFromRangeScan(const mrpt::obs::CObservation2DRangeScan &rangeScan, const mrpt::poses::CPose3D *robotPose=nullptr) override
See CPointsMap::loadFromRangeScan()
bool hasIntensityImage
true means the field intensityImage contains valid data
void enableMedianFilter(bool enable)
void getNextObservation(mrpt::obs::CObservation3DRangeScan &out_obs, bool &there_is_obs, bool &hardware_error)
The main data retrieving function, to be called after calling loadConfig() and initialize().
mrpt::img::CImage rangeImage_getAsImage(const std::optional< mrpt::img::TColormap > color=std::nullopt, const std::optional< float > normMinRange=std::nullopt, const std::optional< float > normMaxRange=std::nullopt, const std::optional< std::string > additionalLayerName=std::nullopt) const
Builds a visualization from the rangeImage.
The namespace for 3D scene representation and rendering.
void setSaveConfidenceImage(bool save)
std::string exception_to_str(const std::exception &e)
Builds a nice textual representation of a nested exception, which if generated using MRPT macros (THR...
bool isEnabledConvGray() const
Classes for creating GUI windows for 2D and 3D visualization.
unsigned int getCameraSerialNumber() const
Get the camera serial number, loaded automatically upon camera open().
void Tic() noexcept
Starts the stopwatch.
void undistort(CImage &out_img, const mrpt::img::TCamera &cameraParams) const
Undistort the image according to some camera parameters, and returns an output undistorted image...
size_t cols() const
Get the col count in the camera images, loaded automatically upon camera open().
void enableImageHistEqualization(bool enable)
static Ptr Create(Args &&... args)
void setSaveRangeImage(bool save)
A class for storing images as grayscale or RGB bitmaps.
A graphical user interface (GUI) for efficiently rendering 3D scenes in real-time.
bool isEnabledMedianFilter() const