bag2png.py
Go to the documentation of this file.
00001 #!/usr/bin/env python
00002 # Software License Agreement (BSD License)
00003 #
00004 # Copyright (c) 2009, Willow Garage, Inc.
00005 # All rights reserved.
00006 #
00007 # Redistribution and use in source and binary forms, with or without
00008 # modification, are permitted provided that the following conditions
00009 # are met:
00010 #
00011 #  * Redistributions of source code must retain the above copyright
00012 #    notice, this list of conditions and the following disclaimer.
00013 #  * Redistributions in binary form must reproduce the above
00014 #    copyright notice, this list of conditions and the following
00015 #    disclaimer in the documentation and/or other materials provided
00016 #    with the distribution.
00017 #  * Neither the name of Willow Garage, Inc. nor the names of its
00018 #    contributors may be used to endorse or promote products derived
00019 #    from this software without specific prior written permission.
00020 #
00021 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00022 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00023 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00024 # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00025 # COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00026 # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00027 # BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00028 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00029 # CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00030 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00031 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00032 # POSSIBILITY OF SUCH DAMAGE.
00033 
00034 import sys
00035 import array
00036 import Image
00037 
00038 import rospy
00039 import rosbag
00040 
00041 def int16_str(d):
00042     return array.array('B', [ min(x, 255) for x in d ]).tostring()
00043     #return array.array('f', [ float(x) for x in d ]).tostring()
00044 
00045 def msg2im(msg):
00046     """Take an sensor_msgs/Image and return a PIL image"""
00047     if len(msg.uint8_data.data) == 0 and len(msg.int16_data.data) == 0:
00048         return None
00049     
00050     if msg.depth == 'uint8':
00051         ma, image_data = msg.uint8_data, ma.data
00052     else:
00053         ma, image_data = msg.int16_data, int16_str(ma.data)
00054         
00055     dim = dict([(d.label, d.size) for d in ma.layout.dim])
00056     mode = { ('uint8',1) : "L", ('uint8',3) : "RGB", ('int16',1) : "L" }[msg.depth, dim['channel']]
00057     (w, h) = (dim['width'], dim['height'])
00058 
00059     return Image.fromstring(mode, (w, h), image_data)
00060 
00061 counter = 0
00062 for topic, msg, t in rosbag.Bag(sys.argv[1]).read_messages():
00063     if topic.endswith('stereo/raw_stereo'):
00064         for (mi, c) in [ (msg.left_image, 'L'), (msg.right_image, 'R'), (msg.disparity_image, 'D')]:
00065             im = msg2im(mi)
00066             if im:
00067                 ext = { 'L':'png', 'RGB':'png', 'F':'tiff' }[im.mode]
00068                 im.save('%06d%s.%s' % (counter, c, ext))
00069         counter += 1


rosbag
Author(s): Tim Field, Jeremy Leibs, James Bowman
autogenerated on Fri Aug 28 2015 12:33:52