00001 #!/usr/bin/env python 00002 00003 # Software License Agreement (BSD License) 00004 # 00005 # Copyright (c) 2010, UC Regents 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 University of California 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 import roslib; roslib.load_manifest('flyer_common') 00036 import rospy 00037 from visualization_msgs.msg import Marker 00038 from flyer_common.rviz import ellipsoid_marker, mesh_marker 00039 from tf.transformations import quaternion_from_euler 00040 from math import radians 00041 00042 class TestRviz: 00043 def __init__(self): 00044 rospy.init_node('test_rviz') 00045 self.marker_pub = rospy.Publisher("test_markers", Marker) 00046 00047 def test_markers(self): 00048 # test_ellipsoid = ellipsoid_marker([0,0,0], frame_id="/map") 00049 # self.marker_pub.publish(test_ellipsoid) 00050 quat = quaternion_from_euler(radians(-90),radians(-90),0,'rxyz') 00051 test_mesh = mesh_marker([1,0,0], orientation=quat, mesh_resource="file:///tmp/hybridlab.dae", frame_id="/map", 00052 rgba=[1,1,1,0.5]) 00053 self.marker_pub.publish(test_mesh) 00054 00055 def go(self): 00056 r = rospy.Rate(10) 00057 while not rospy.is_shutdown(): 00058 self.test_markers() 00059 r.sleep() 00060 00061 if __name__ == "__main__": 00062 self = TestRviz() 00063 self.go()