pole_structure_visualizer.cpp
Go to the documentation of this file.
00001 /*********************************************************************
00002 *
00003 * Software License Agreement (BSD License)
00004 *
00005 *  Copyright (c) 2011, ISR University of Coimbra.
00006 *  All rights reserved.
00007 *
00008 *  Redistribution and use in source and binary forms, with or without
00009 *  modification, are permitted provided that the following conditions
00010 *  are met:
00011 *
00012 *   * Redistributions of source code must retain the above copyright
00013 *     notice, this list of conditions and the following disclaimer.
00014 *   * Redistributions in binary form must reproduce the above
00015 *     copyright notice, this list of conditions and the following
00016 *     disclaimer in the documentation and/or other materials provided
00017 *     with the distribution.
00018 *   * Neither the name of the ISR University of Coimbra nor the names of its
00019 *     contributors may be used to endorse or promote products derived
00020 *     from this software without specific prior written permission.
00021 *
00022 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00023 *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00024 *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00025 *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00026 *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00027 *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00028 *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00029 *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00030 *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00031 *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00032 *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00033 *  POSSIBILITY OF SUCH DAMAGE.
00034 *
00035 * Author: Gonçalo Cabrita on 05/03/2012
00036 *********************************************************************/
00037 
00038 #include <ros/ros.h>
00039 #include <tf/tf.h>
00040 #include <boost/foreach.hpp>
00041 #include <visualization_msgs/Marker.h>
00042 #include <pole_structure_mapper/PoleSectionStamped.h>
00043 #include <pole_structure_mapper/PoleStructure.h>
00044 
00045 #include <tf/transform_listener.h>
00046 #include <tf/message_filter.h>
00047 #include <message_filters/subscriber.h>
00048 
00049 ros::Publisher * marker_pub_;
00050 
00051 void poleStructureCallback(const pole_structure_mapper::PoleStructure::ConstPtr& msg)
00052 {
00053     //ROS_INFO("Got a structure msg!!!");
00054 
00055     pole_structure_mapper::PoleStructure pole_structure_ = *msg;
00056     
00057     for(int i=0 ; i<pole_structure_.pole.size() ; i++)
00058     {      
00059         char tag[16];
00060         sprintf(tag, "pole_%d", i);
00061         
00062         // Display the cylinder
00063         visualization_msgs::Marker marker;
00064         marker.header.frame_id = "map";
00065         marker.header.stamp = ros::Time::now();
00066         
00067         marker.ns = tag;
00068         marker.id = 0;
00069         
00070         marker.type = visualization_msgs::Marker::CYLINDER;
00071         
00072         marker.action = visualization_msgs::Marker::ADD;
00073         
00074         // For the marker the position is the middle point between the bottom and the top
00075         marker.pose.position.x = pole_structure_.pole[i].base.x + pole_structure_.pole[i].length/2.0 * pole_structure_.pole[i].axis.x;
00076         marker.pose.position.y = pole_structure_.pole[i].base.y + pole_structure_.pole[i].length/2.0 * pole_structure_.pole[i].axis.y;
00077         marker.pose.position.z = pole_structure_.pole[i].base.z + pole_structure_.pole[i].length/2.0 * pole_structure_.pole[i].axis.z;
00078 
00079         tf::Vector3 axis_vector(pole_structure_.pole[i].axis.x, pole_structure_.pole[i].axis.y, pole_structure_.pole[i].axis.z);
00080         tf::Vector3 up_vector(0.0, 0.0, 1.0);
00081         tf::Vector3 right_vector = axis_vector.cross(up_vector);
00082         right_vector.normalized();
00083         tf::Quaternion q(right_vector, -1.0*acos(axis_vector.dot(up_vector)));
00084         q.normalize();
00085         geometry_msgs::Quaternion cylinder_orientation;
00086         tf::quaternionTFToMsg(q, cylinder_orientation);
00087 
00088         marker.pose.orientation = cylinder_orientation;
00089         
00090         marker.scale.x = pole_structure_.pole[i].diameter;
00091         marker.scale.y = pole_structure_.pole[i].diameter;
00092         marker.scale.z = pole_structure_.pole[i].length;
00093         
00094         marker.color.r = 1.0f;
00095         marker.color.g = 0.0f;
00096         marker.color.b = 0.0f;
00097         marker.color.a = 0.8;
00098         
00099         marker.lifetime = ros::Duration();
00100         
00101         // Publish the marker
00102         marker_pub_->publish(marker);
00103     }
00104 }
00105 
00106 int main(int argc, char** argv)
00107 {
00108         ros::init(argc, argv, "pole_structure_visualizer_node");
00109     
00110     ROS_INFO("Pole Structure Visualizer for ROS v0.1");
00111     
00112     // ROS stuff
00113         ros::NodeHandle n;
00114     
00115     ros::Subscriber sub = n.subscribe("pole_structure", 1, poleStructureCallback);
00116     ros::Publisher pub = n.advertise<visualization_msgs::Marker>("pole_structure_visualizer", 30);
00117     marker_pub_ = &pub;
00118 
00119     ros::spin();
00120 
00121 }
00122 
00123 // EOF
00124 


pole_structure_mapper
Author(s): Gonçalo Cabrita and Mahmoud Tavakoli
autogenerated on Mon Jan 6 2014 11:26:24