ArVizDrawer.h
Go to the documentation of this file.
1/*
2 * This file is part of ArmarX.
3 *
4 * ArmarX is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 *
8 * ArmarX is distributed in the hope that it will be useful, but
9 * WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
15 *
16 * @author Fabian Reister ( fabian dot reister at kit dot edu )
17 * @date 2021
18 * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
19 * GNU General Public License
20 */
21
22#pragma once
23
24#include <set>
25#include <vector>
26
27#include <VirtualRobot/BoundingBox.h>
28
31#include <RobotAPI/interface/units/LaserScannerUnit.h>
32
34
36{
38 {
39 public:
40 using ScopedClient::ScopedClient;
41
42 void drawBoundingBoxes(const std::vector<VirtualRobot::BoundingBox>& boundingBoxes);
43 void drawOccupancyGrid(const OccupancyGrid& grid, float boxPosZ);
44
45 void prepareScan(const LaserScan& scan,
46 const std::string& frame,
47 const Eigen::Affine3f& scannerPose);
48 void drawScans();
49
50 private:
51 // as the set is ordered, laser scans will always have the same color
52 std::set<std::string> frames;
53
54 std::unordered_map<std::string, viz::PointCloud> clouds;
55 };
56
57} // namespace armarx::laser_scanner_simulation
void drawBoundingBoxes(const std::vector< VirtualRobot::BoundingBox > &boundingBoxes)
void drawOccupancyGrid(const OccupancyGrid &grid, float boxPosZ)
void prepareScan(const LaserScan &scan, const std::string &frame, const Eigen::Affine3f &scannerPose)
viz::Client that will delete (clear) committed layers when destroyed.