full_size_data_plot.py
Go to the documentation of this file.
00001 #!/usr/bin/env python
00002 #       
00003 # License: BSD
00004 #   https://raw.github.com/yujinrobot/kobuki_desktop/master/kobuki_qtestsuite/LICENSE 
00005 #
00006 ##############################################################################
00007 # Imports
00008 ##############################################################################
00009 
00010 import operator
00011 import numpy
00012 
00013 #from rqt_plot.qwt_data_plot import QwtDataPlot
00014 from rqt_plot.mat_data_plot import MatDataPlot
00015 
00016 ##############################################################################
00017 # Classes
00018 ##############################################################################
00019 
00020 class FullSizeDataPlot(MatDataPlot):
00021     def __init__(self, parent=None):
00022         super(FullSizeDataPlot, self).__init__(parent)
00023         self.max_range = 180
00024         self.min_range = 0
00025         self.dynamic_range = False
00026         self._ymin = 0
00027         self._ymax = 0
00028         
00029     def reset(self):
00030         self._ymin = 0
00031         self._ymax = 0
00032         
00033     ######################################
00034     # Overrides
00035     ######################################
00036     def _update_legend(self):
00037         handles, labels = self._canvas.axes.get_legend_handles_labels()
00038         if handles:
00039             hl = sorted(zip(handles, labels), key=operator.itemgetter(1))
00040             handles, labels = zip(*hl)
00041         self._canvas.axes.legend(handles, labels, loc='lower right')
00042         
00043     def redraw(self):
00044         ''' 
00045           We fix the y axis and continually resize the x axis to encapsulate
00046           the entire domain, range of the battery profile.
00047           
00048           @Todo : the domain is simply the data value, we could use
00049         '''
00050         self._canvas.axes.grid(True, color='gray')
00051         # Set axis bounds
00052         xmax = 0
00053         for curve in self._curves.values():
00054             data_x, data_y, plot, min_max_y = curve
00055             if len(data_x) == 0:
00056                 continue
00057             
00058             xmax = max(xmax, data_x[-1])
00059             self._ymin = min(self._ymin, min_max_y[0])
00060             self._ymax = max(self._ymax, min_max_y[1] + 1)
00061             self._canvas.axes.set_xbound(lower=0, upper=xmax)
00062             
00063         if self.dynamic_range:
00064             self._canvas.axes.set_ybound(lower=self._ymin, upper=self._ymax)
00065         else:
00066             self._canvas.axes.set_ybound(self.min_range, upper=self.max_range)
00067 
00068         # Set plot data on current axes
00069         for curve in self._curves.values():
00070             data_x, data_y, plot, min_max_y = curve
00071             plot.set_data(numpy.array(data_x), numpy.array(data_y))
00072 
00073         self._canvas.draw()


kobuki_qtestsuite
Author(s): Daniel Stonier
autogenerated on Wed Aug 26 2015 12:18:33