shape_extents.cpp
Go to the documentation of this file.
1 /*********************************************************************
2  * Software License Agreement (BSD License)
3  *
4  * Copyright (c) 2012, Willow Garage, Inc.
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * * Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  * * Redistributions in binary form must reproduce the above
14  * copyright notice, this list of conditions and the following
15  * disclaimer in the documentation and/or other materials provided
16  * with the distribution.
17  * * Neither the name of the Willow Garage nor the names of its
18  * contributors may be used to endorse or promote products derived
19  * from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32  * POSSIBILITY OF SUCH DAMAGE.
33  *********************************************************************/
34 
37 #include <limits>
38 
39 void geometric_shapes::getShapeExtents(const shape_msgs::SolidPrimitive& shape_msg, double& x_extent, double& y_extent,
40  double& z_extent)
41 {
42  x_extent = y_extent = z_extent = 0.0;
43 
44  if (shape_msg.type == shape_msgs::SolidPrimitive::SPHERE)
45  {
46  if (shape_msg.dimensions.size() >=
48  x_extent = y_extent = z_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::SPHERE_RADIUS] * 2.0;
49  }
50  else if (shape_msg.type == shape_msgs::SolidPrimitive::BOX)
51  {
53  {
54  x_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::BOX_X];
55  y_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::BOX_Y];
56  z_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::BOX_Z];
57  }
58  }
59  else if (shape_msg.type == shape_msgs::SolidPrimitive::CYLINDER)
60  {
61  if (shape_msg.dimensions.size() >=
63  {
64  x_extent = y_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::CYLINDER_RADIUS] * 2.0;
65  z_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::CYLINDER_HEIGHT];
66  }
67  }
68  else if (shape_msg.type == shape_msgs::SolidPrimitive::CONE)
69  {
70  if (shape_msg.dimensions.size() >=
72  {
73  x_extent = y_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::CONE_RADIUS] * 2.0;
74  z_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::CONE_HEIGHT];
75  }
76  }
77 }
78 
79 void geometric_shapes::getShapeExtents(const shape_msgs::Mesh& shape_msg, double& x_extent, double& y_extent,
80  double& z_extent)
81 {
82  x_extent = y_extent = z_extent = 0.0;
83  if (!shape_msg.vertices.empty())
84  {
85  double xmin = std::numeric_limits<double>::max(), ymin = std::numeric_limits<double>::max(),
86  zmin = std::numeric_limits<double>::max();
87  double xmax = -std::numeric_limits<double>::max(), ymax = -std::numeric_limits<double>::max(),
88  zmax = -std::numeric_limits<double>::max();
89  for (const geometry_msgs::Point& vertex : shape_msg.vertices)
90  {
91  if (vertex.x > xmax)
92  xmax = vertex.x;
93  if (vertex.x < xmin)
94  xmin = vertex.x;
95  if (vertex.y > ymax)
96  ymax = vertex.y;
97  if (vertex.y < ymin)
98  ymin = vertex.y;
99  if (vertex.z > zmax)
100  zmax = vertex.z;
101  if (vertex.z < zmin)
102  zmin = vertex.z;
103  }
104  x_extent = xmax - xmin;
105  y_extent = ymax - ymin;
106  z_extent = zmax - zmin;
107  }
108 }
void getShapeExtents(const shape_msgs::SolidPrimitive &shape_msg, double &x_extent, double &y_extent, double &z_extent)
Get the dimensions of an axis-aligned bounding box for the shape described by shape_msg.
The number of dimensions of a particular shape.


geometric_shapes
Author(s): Ioan Sucan , Gil Jones
autogenerated on Fri Apr 14 2023 02:14:40