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 
36 #include <limits>
37 
38 void geometric_shapes::getShapeExtents(const shape_msgs::SolidPrimitive& shape_msg, double& x_extent, double& y_extent,
39  double& z_extent)
40 {
41  x_extent = y_extent = z_extent = 0.0;
42 
43  if (shape_msg.type == shape_msgs::SolidPrimitive::SPHERE)
44  {
45  if (shape_msg.dimensions.size() > shape_msgs::SolidPrimitive::SPHERE_RADIUS)
46  x_extent = y_extent = z_extent = shape_msg.dimensions[shape_msgs::SolidPrimitive::SPHERE_RADIUS] * 2.0;
47  }
48  else if (shape_msg.type == shape_msgs::SolidPrimitive::BOX)
49  {
50  if (shape_msg.dimensions.size() > shape_msgs::SolidPrimitive::BOX_X &&
51  shape_msg.dimensions.size() > shape_msgs::SolidPrimitive::BOX_Y &&
52  shape_msg.dimensions.size() > shape_msgs::SolidPrimitive::BOX_Z)
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() > shape_msgs::SolidPrimitive::CYLINDER_RADIUS &&
62  shape_msg.dimensions.size() > shape_msgs::SolidPrimitive::CYLINDER_HEIGHT)
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() > shape_msgs::SolidPrimitive::CONE_RADIUS &&
71  shape_msg.dimensions.size() > shape_msgs::SolidPrimitive::CONE_HEIGHT)
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.size() > 0)
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 (std::size_t i = 0; i < shape_msg.vertices.size(); ++i)
90  {
91  if (shape_msg.vertices[i].x > xmax)
92  xmax = shape_msg.vertices[i].x;
93  if (shape_msg.vertices[i].x < xmin)
94  xmin = shape_msg.vertices[i].x;
95  if (shape_msg.vertices[i].y > ymax)
96  ymax = shape_msg.vertices[i].y;
97  if (shape_msg.vertices[i].y < ymin)
98  ymin = shape_msg.vertices[i].y;
99  if (shape_msg.vertices[i].z > zmax)
100  zmax = shape_msg.vertices[i].z;
101  if (shape_msg.vertices[i].z < zmin)
102  zmin = shape_msg.vertices[i].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.


geometric_shapes
Author(s): Ioan Sucan , Gil Jones
autogenerated on Fri Jun 7 2019 21:59:29