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() >= geometric_shapes::solidPrimitiveDimCount<shape_msgs::SolidPrimitive::SPHERE>())
47  x_extent = y_extent = z_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::SPHERE_RADIUS] * 2.0;
48  }
49  else if (shape_msg.type == shape_msgs::SolidPrimitive::BOX)
50  {
51  if (shape_msg.dimensions.size() >= geometric_shapes::solidPrimitiveDimCount<shape_msgs::SolidPrimitive::BOX>())
52  {
53  x_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::BOX_X];
54  y_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::BOX_Y];
55  z_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::BOX_Z];
56  }
57  }
58  else if (shape_msg.type == shape_msgs::SolidPrimitive::CYLINDER)
59  {
60  if (shape_msg.dimensions.size() >= geometric_shapes::solidPrimitiveDimCount<shape_msgs::SolidPrimitive::CYLINDER>())
61  {
62  x_extent = y_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::CYLINDER_RADIUS] * 2.0;
63  z_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::CYLINDER_HEIGHT];
64  }
65  }
66  else if (shape_msg.type == shape_msgs::SolidPrimitive::CONE)
67  {
68  if (shape_msg.dimensions.size() >= geometric_shapes::solidPrimitiveDimCount<shape_msgs::SolidPrimitive::CONE>())
69  {
70  x_extent = y_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::CONE_RADIUS] * 2.0;
71  z_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::CONE_HEIGHT];
72  }
73  }
74 }
75 
76 void geometric_shapes::getShapeExtents(const shape_msgs::Mesh& shape_msg, double& x_extent, double& y_extent,
77  double& z_extent)
78 {
79  x_extent = y_extent = z_extent = 0.0;
80  if (!shape_msg.vertices.empty())
81  {
82  double xmin = std::numeric_limits<double>::max(), ymin = std::numeric_limits<double>::max(),
83  zmin = std::numeric_limits<double>::max();
84  double xmax = -std::numeric_limits<double>::max(), ymax = -std::numeric_limits<double>::max(),
85  zmax = -std::numeric_limits<double>::max();
86  for (const geometry_msgs::Point& vertex : shape_msg.vertices)
87  {
88  if (vertex.x > xmax)
89  xmax = vertex.x;
90  if (vertex.x < xmin)
91  xmin = vertex.x;
92  if (vertex.y > ymax)
93  ymax = vertex.y;
94  if (vertex.y < ymin)
95  ymin = vertex.y;
96  if (vertex.z > zmax)
97  zmax = vertex.z;
98  if (vertex.z < zmin)
99  zmin = vertex.z;
100  }
101  x_extent = xmax - xmin;
102  y_extent = ymax - ymin;
103  z_extent = zmax - zmin;
104  }
105 }
shape_extents.h
shapes::SPHERE
@ SPHERE
Definition: shapes.h:64
geometric_shapes::getShapeExtents
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.
Definition: shape_extents.cpp:39
shapes::CONE
@ CONE
Definition: shapes.h:66
solid_primitive_dims.h
shapes::CYLINDER
@ CYLINDER
Definition: shapes.h:65
shapes::BOX
@ BOX
Definition: shapes.h:67


geometric_shapes
Author(s): Ioan Sucan , Gil Jones
autogenerated on Sun Oct 1 2023 02:40:16