1) make it pretty for large clusters

2) make subticks vertical so they can be longer
3) make inner and outer axes farther apart to make room for subtick's vertical labels

--HG--
extra : convert_revision : 91a1aab3f1078921edd53428e6712744210c9f1b
This commit is contained in:
Lisa Hsu 2006-02-24 18:08:14 -05:00
parent a611b81003
commit fcb9718dcd

View file

@ -151,9 +151,9 @@ class BarChart(ChartOptions):
self.metaaxes.set_yticks([]) self.metaaxes.set_yticks([])
size = [0] * 4 size = [0] * 4
size[0] = self.figure_size[0] size[0] = self.figure_size[0]
size[1] = self.figure_size[1] + .05 size[1] = self.figure_size[1] + .12
size[2] = self.figure_size[2] size[2] = self.figure_size[2]
size[3] = self.figure_size[3] - .05 size[3] = self.figure_size[3] - .12
self.axes = self.figure.add_axes(size) self.axes = self.figure.add_axes(size)
outer_axes = self.metaaxes outer_axes = self.metaaxes
inner_axes = self.axes inner_axes = self.axes
@ -163,12 +163,9 @@ class BarChart(ChartOptions):
inner_axes = self.axes inner_axes = self.axes
bars_in_group = len(self.chartdata) bars_in_group = len(self.chartdata)
if bars_in_group < 5:
width = 1.0 / ( bars_in_group + 1) width = 1.0 / ( bars_in_group + 1)
center = width / 2 center = width / 2
else:
width = .8 / bars_in_group
center = .1
bars = [] bars = []
for i,stackdata in enumerate(self.chartdata): for i,stackdata in enumerate(self.chartdata):
@ -179,7 +176,7 @@ class BarChart(ChartOptions):
ind = arange(len(bardata)) + i * width + center ind = arange(len(bardata)) + i * width + center
bar = self.axes.bar(ind, bardata, width, bottom=bottom, bar = self.axes.bar(ind, bardata, width, bottom=bottom,
color=colors[i][j]) color=colors[i][j])
if dim != 1: if self.xsubticks is not None:
self.metaaxes.bar(ind, [0] * len(bardata), width) self.metaaxes.bar(ind, [0] * len(bardata), width)
stack.append(bar) stack.append(bar)
bottom += bardata bottom += bardata
@ -207,7 +204,7 @@ class BarChart(ChartOptions):
if self.xsubticks is not None: if self.xsubticks is not None:
inner_axes.set_xticks(arange((cshape[0] + 1)*cshape[2])*width + 2*center) inner_axes.set_xticks(arange((cshape[0] + 1)*cshape[2])*width + 2*center)
self.xsubticks.append('') self.xsubticks.append('')
inner_axes.set_xticklabels(self.xsubticks * cshape[2], fontsize=8) inner_axes.set_xticklabels(self.xsubticks * cshape[2], fontsize=7, rotation=90)
if self.legend is not None: if self.legend is not None:
if dim == 1: if dim == 1:
@ -281,7 +278,6 @@ if __name__ == '__main__':
chart1.legend = [ 'x%d' % x for x in xrange(myshape[-1]) ] chart1.legend = [ 'x%d' % x for x in xrange(myshape[-1]) ]
chart1.xticks = [ 'xtick%d' % x for x in xrange(myshape[0]) ] chart1.xticks = [ 'xtick%d' % x for x in xrange(myshape[0]) ]
chart1.title = 'this is the title' chart1.title = 'this is the title'
chart1.figure_size = [0.1, 0.2, 0.7, 0.85 ]
if len(myshape) > 2: if len(myshape) > 2:
chart1.xsubticks = [ '%d' % x for x in xrange(myshape[1]) ] chart1.xsubticks = [ '%d' % x for x in xrange(myshape[1]) ]
chart1.graph() chart1.graph()
@ -298,4 +294,4 @@ if __name__ == '__main__':
chart2.savefig('/tmp/test2.png') chart2.savefig('/tmp/test2.png')
chart2.savefig('/tmp/test2.ps') chart2.savefig('/tmp/test2.ps')
pylab.myshow() # pylab.show()