mrs_lib
Various reusable classes, functions and utilities for use in MRS projects
Loading...
Searching...
No Matches
batch_visualizer.h
1#ifndef BATCH_VISUALIZER_H
2#define BATCH_VISUALIZER_H
3
4#include <vector>
5#include <rclcpp/rclcpp.hpp>
6#include <visualization_msgs/msg/marker_array.hpp>
8#include <mrs_msgs/msg/path.hpp>
9#include <mrs_msgs/msg/trajectory_reference.hpp>
10#include <mrs_lib/visual_object.h>
11#include <set>
12
13#define DEFAULT_ELLIPSE_POINTS 64
14
15namespace mrs_lib
16{
17
22
23public:
39 BatchVisualizer(const std::shared_ptr<rclcpp::Node>& node, std::string marker_topic_name, std::string parent_frame);
40
51 void addPoint(const Eigen::Vector3d &point, const double r = 0.0, const double g = 1.0, const double b = 0.3, const double a = 1.0,
52 const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
53
64 void addRay(const mrs_lib::geometry::Ray &ray, const double r = 1.0, const double g = 0.0, const double b = 0.0, const double a = 1.0,
65 const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
66
78 void addTriangle(const mrs_lib::geometry::Triangle &tri, const double r = 0.5, const double g = 0.5, const double b = 0.0, const double a = 1.0,
79 const bool filled = true, const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
80
92 void addRectangle(const mrs_lib::geometry::Rectangle &rect, const double r = 0.5, const double g = 0.5, const double b = 0.0, const double a = 1.0,
93 const bool filled = true, const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
94
106 void addCuboid(const mrs_lib::geometry::Cuboid &cuboid, const double r = 0.5, const double g = 0.5, const double b = 0.0, const double a = 1.0,
107 const bool filled = true, const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
108
121 void addEllipse(const mrs_lib::geometry::Ellipse &ellipse, const double r = 0.0, const double g = 1.0, const double b = 1.0, const double a = 1.0,
122 const bool filled = true, const int num_points = DEFAULT_ELLIPSE_POINTS, const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
123
137 void addCylinder(const mrs_lib::geometry::Cylinder &cylinder, const double r = 0.7, const double g = 0.8, const double b = 0.3, const double a = 1.0,
138 const bool filled = true, const bool capped = true, const int sides = DEFAULT_ELLIPSE_POINTS,
139 const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
153 void addCone(const mrs_lib::geometry::Cone &cone, const double r = 0.7, const double g = 0.8, const double b = 0.3, const double a = 1.0,
154 const bool filled = true, const bool capped = true, const int sides = DEFAULT_ELLIPSE_POINTS, const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
155
167 void addPath(const mrs_msgs::msg::Path &p, const double r = 0.3, const double g = 1.0, const double b = 0.3, const double a = 1.0, const bool filled = true,
168 const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
169
181 void addTrajectory(const mrs_msgs::msg::TrajectoryReference &traj, const double r = 0.3, const double g = 1.0, const double b = 0.3, const double a = 1.0,
182 const bool filled = true, const rclcpp::Duration &timeout = rclcpp::Duration(std::chrono::seconds(0)));
183
187 void addNullPoint();
188
192 void addNullLine();
193
197 void addNullTriangle();
198
204 void setPointsScale(const double scale);
205
211 void setParentFrame(const std::string parent_frame);
212
218 void setLinesScale(const double scale);
219
223 void clearBuffers();
224
228 void clearVisuals();
229
233 void publish();
234
238 void publish(const rclcpp::Time stamp);
239
240private:
241 std::shared_ptr<rclcpp::Node> node;
242 rclcpp::Publisher<visualization_msgs::msg::MarkerArray>::SharedPtr visual_pub;
243 visualization_msgs::msg::MarkerArray msg;
244
245 std::string parent_frame; // coordinate frame id
246 std::string marker_topic_name;
247
248 std::set<VisualObject> visual_objects; // buffer for objects to be visualized
249
250 visualization_msgs::msg::Marker points_marker;
251 visualization_msgs::msg::Marker lines_marker;
252 visualization_msgs::msg::Marker triangles_marker;
253
254 bool initialized = false;
255 void initialize();
256
257 double points_scale = 0.02;
258 double lines_scale = 0.04;
259
260 unsigned long uuid = 0; // create unique ID for items in object buffer
261};
262
263} // namespace mrs_lib
264
265#endif
library for drawing large amounts of geometric objects in RVIZ at the same time
Definition batch_visualizer.h:21
void addEllipse(const mrs_lib::geometry::Ellipse &ellipse, const double r=0.0, const double g=1.0, const double b=1.0, const double a=1.0, const bool filled=true, const int num_points=DEFAULT_ELLIPSE_POINTS, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add an ellipse to the buffer
Definition batch_visualizer.cpp:134
void addCylinder(const mrs_lib::geometry::Cylinder &cylinder, const double r=0.7, const double g=0.8, const double b=0.3, const double a=1.0, const bool filled=true, const bool capped=true, const int sides=DEFAULT_ELLIPSE_POINTS, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add a cylinder to the buffer
Definition batch_visualizer.cpp:142
void setParentFrame(const std::string parent_frame)
set the parent frame_id
Definition batch_visualizer.cpp:28
BatchVisualizer()
dummy constructor
Definition batch_visualizer.cpp:9
void clearBuffers()
remove all objects from the buffer
Definition batch_visualizer.cpp:253
void addRectangle(const mrs_lib::geometry::Rectangle &rect, const double r=0.5, const double g=0.5, const double b=0.0, const double a=1.0, const bool filled=true, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add a rectangle to the buffer
Definition batch_visualizer.cpp:118
void publish()
publish the visual markers rclcpp message and populates it with buffer content
Definition batch_visualizer.cpp:271
void addRay(const mrs_lib::geometry::Ray &ray, const double r=1.0, const double g=0.0, const double b=0.0, const double a=1.0, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add a ray to the buffer
Definition batch_visualizer.cpp:102
void addTrajectory(const mrs_msgs::msg::TrajectoryReference &traj, const double r=0.3, const double g=1.0, const double b=0.3, const double a=1.0, const bool filled=true, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add a trajectory to the buffer
Definition batch_visualizer.cpp:163
void addCuboid(const mrs_lib::geometry::Cuboid &cuboid, const double r=0.5, const double g=0.5, const double b=0.0, const double a=1.0, const bool filled=true, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add a cuboid to the buffer
Definition batch_visualizer.cpp:126
void addNullTriangle()
helper function for adding an invisible triangle to the buffer
Definition batch_visualizer.cpp:212
void addNullPoint()
helper function for adding an invisible point to the object buffer
Definition batch_visualizer.cpp:170
void addNullLine()
helper function for adding an invisible line to the object buffer
Definition batch_visualizer.cpp:188
~BatchVisualizer()
destructor
Definition batch_visualizer.cpp:12
void addPoint(const Eigen::Vector3d &point, const double r=0.0, const double g=1.0, const double b=0.3, const double a=1.0, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add a point to the buffer
Definition batch_visualizer.cpp:94
void clearVisuals()
publishes an empty message. Removes all objects drawn onto the scene, but keeps them in buffer
Definition batch_visualizer.cpp:259
void addPath(const mrs_msgs::msg::Path &p, const double r=0.3, const double g=1.0, const double b=0.3, const double a=1.0, const bool filled=true, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add a path to the buffer
Definition batch_visualizer.cpp:156
void setPointsScale(const double scale)
set the scale of all points
Definition batch_visualizer.cpp:241
void addTriangle(const mrs_lib::geometry::Triangle &tri, const double r=0.5, const double g=0.5, const double b=0.0, const double a=1.0, const bool filled=true, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add a triangle to the buffer
Definition batch_visualizer.cpp:110
void addCone(const mrs_lib::geometry::Cone &cone, const double r=0.7, const double g=0.8, const double b=0.3, const double a=1.0, const bool filled=true, const bool capped=true, const int sides=DEFAULT_ELLIPSE_POINTS, const rclcpp::Duration &timeout=rclcpp::Duration(std::chrono::seconds(0)))
add a cone to the buffer
Definition batch_visualizer.cpp:149
void setLinesScale(const double scale)
set the thickness of all lines
Definition batch_visualizer.cpp:247
geometric representaiton of a cone
Definition shapes.h:575
geometric representation of a cuboid
Definition shapes.h:319
geometric representation of a cylinder
Definition shapes.h:492
geometric representation of an ellipse
Definition shapes.h:428
geometric representation of a ray. Instantiate it by two input Vector3. Use static methods for from-t...
Definition shapes.h:26
geometric representation of a rectangle (can represent any quadrilateral)
Definition shapes.h:189
geometric representation of a triangle. Instantiate a new triangle by providing three vertices
Definition shapes.h:100
All mrs_lib functions, classes, variables and definitions are contained in this namespace.
Definition attitude_converter.h:24
Defines various geometrical shapes and their relations.