torus_array_display.h
Go to the documentation of this file.
00001 // -*- mode: c++; -*-
00002 /*********************************************************************
00003  * Software License Agreement (BSD License)
00004  *
00005  *  Copyright (c) 2014, JSK Lab
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/o2r other materials provided
00017  *     with the distribution.
00018  *   * Neither the name of the JSK Lab 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 
00036 #ifndef JSK_RVIZ_PLUGINS_TORUS_ARRAY_DISPLAY_H_
00037 #define JSK_RVIZ_PLUGINS_TORUS_ARRAY_DISPLAY_H_
00038 
00039 #include <jsk_recognition_msgs/TorusArray.h>
00040 #include <rviz/properties/color_property.h>
00041 #include <rviz/properties/bool_property.h>
00042 #include <rviz/properties/float_property.h>
00043 #include <rviz/properties/int_property.h>
00044 #include <rviz/message_filter_display.h>
00045 #include <rviz/ogre_helpers/shape.h>
00046 #include <rviz/ogre_helpers/mesh_shape.h>
00047 #include <rviz/ogre_helpers/arrow.h>
00048 #include <OGRE/OgreSceneNode.h>
00049 
00050 namespace jsk_rviz_plugins
00051 {
00052   struct Triangle
00053   {
00054     unsigned v1, v2, v3; // index for the 3 vertices that make up a triangle
00055   };
00056 
00057   class TorusArrayDisplay: public rviz::MessageFilterDisplay<jsk_recognition_msgs::TorusArray>
00058   {
00059     Q_OBJECT
00060   public:
00061     typedef boost::shared_ptr<rviz::Arrow> ArrowPtr;
00062     typedef boost::shared_ptr<rviz::MeshShape> ShapePtr;
00063     TorusArrayDisplay();
00064     virtual ~TorusArrayDisplay();
00065   protected:
00066     virtual void onInitialize();
00067     virtual void reset();
00068     void allocateShapes(int num);
00069     QColor getColor(size_t index);
00070     rviz::ColorProperty* color_property_;
00071     rviz::FloatProperty* alpha_property_;
00072     rviz::IntProperty* uv_property_;
00073     rviz::BoolProperty* auto_color_property_;
00074     rviz::BoolProperty* show_normal_property_;
00075     rviz::FloatProperty* normal_length_property_;
00076     QColor color_;
00077     double alpha_;
00078     bool auto_color_;
00079     bool show_normal_;
00080     double normal_length_;
00081     int uv_dimension_;
00082     std::vector<Ogre::SceneNode*> arrow_nodes_;
00083     std::vector<ArrowPtr> arrow_objects_;
00084     std::vector<ShapePtr> shapes_;
00085   private Q_SLOTS:
00086     void updateColor();
00087     void updateAlpha();
00088     void updateUVdimension();
00089     void updateAutoColor();
00090     void updateShowNormal();
00091     void updateNormalLength();
00092 
00093     void calcurateTriangleMesh(
00094                                int large_dimension, int small_dimension,
00095                                float large_radius, float small_radius,
00096                                Ogre::Vector3 pos, Ogre::Quaternion q,
00097                                std::vector<Triangle> &triangles,
00098                                std::vector<Ogre::Vector3> &vertices,
00099                                std::vector<Ogre::Vector3> &normals
00100                                );
00101   private:
00102     void processMessage(const jsk_recognition_msgs::TorusArray::ConstPtr& msg);
00103   };
00104 
00105 }
00106 #endif


jsk_rviz_plugins
Author(s): Kei Okada , Yohei Kakiuchi , Shohei Fujii , Ryohei Ueda
autogenerated on Sun Sep 13 2015 22:29:03