Browse Source

Fix axis and improve xy text

pull/8/head
Florian Mounier 13 years ago
parent
commit
a2d2f0afcb
  1. 2
      pygal/css/graph.css
  2. 20
      pygal/svg.py
  3. 2
      pygal/xy.py

2
pygal/css/graph.css

@ -65,7 +65,7 @@ svg * {
opacity: 0; opacity: 0;
} }
.axis.y .guides:hover .guide.line, .Line .axis.x .guides:hover .guide.line { .axis.y .guides:hover .guide.line, .Line .axis.x .guides:hover .guide.line, .XY .axis.x .guides:hover .guide.line {
stroke: {{ style.foreground_light }}; stroke: {{ style.foreground_light }};
opacity: 1; opacity: 1;
} }

20
pygal/svg.py

@ -79,7 +79,8 @@ class Svg(object):
def x_axis(self, labels): def x_axis(self, labels):
axis = self.node(self.plot, class_="axis x") axis = self.node(self.plot, class_="axis x")
# Plot axis
if 0 not in [label[1] for label in labels]:
self.node(axis, 'path', self.node(axis, 'path',
d='M%f %f v%f' % (0, 0, self.view.height), d='M%f %f v%f' % (0, 0, self.view.height),
class_='line') class_='line')
@ -91,14 +92,15 @@ class Svg(object):
if x != 0: if x != 0:
self.node(guides, 'path', self.node(guides, 'path',
d='M%f %f v%f' % (x, 0, self.view.height), d='M%f %f v%f' % (x, 0, self.view.height),
class_='guide line') class_='%sline' % (
'guide ' if position != 0 else ''))
text = self.node(guides, 'text', x=x, y=self.view.height + 5) text = self.node(guides, 'text', x=x, y=self.view.height + 5)
text.text = label text.text = label
def y_axis(self, labels): def y_axis(self, labels):
axis = self.node(self.plot, class_="axis y") axis = self.node(self.plot, class_="axis y")
# Plot axis
if 0 not in [label[1] for label in labels]:
self.node(axis, 'path', self.node(axis, 'path',
d='M%f %f h%f' % (0, self.view.height, self.view.width), d='M%f %f h%f' % (0, self.view.height, self.view.width),
class_='line') class_='line')
@ -108,7 +110,8 @@ class Svg(object):
if y != self.view.height: if y != self.view.height:
self.node(guides, 'path', self.node(guides, 'path',
d='M%f %f h%f' % (0, y, self.view.width), d='M%f %f h%f' % (0, y, self.view.width),
class_='guide line') class_='%sline' % (
'guide ' if position != 0 else ''))
text = self.node(guides, 'text', x=-5, y=y) text = self.node(guides, 'text', x=-5, y=y)
text.text = label text.text = label
@ -133,7 +136,7 @@ class Svg(object):
return self.node( return self.node(
self.plot, class_='series serie-%d color-%d' % (serie, serie)) self.plot, class_='series serie-%d color-%d' % (serie, serie))
def line(self, serie_node, values): def line(self, serie_node, values, xy=False):
view_values = map(self.view, values) view_values = map(self.view, values)
origin = '%f %f' % view_values[0] origin = '%f %f' % view_values[0]
@ -141,7 +144,8 @@ class Svg(object):
for i, (x, y) in enumerate(view_values): for i, (x, y) in enumerate(view_values):
dot = self.node(dots, class_='dot') dot = self.node(dots, class_='dot')
self.node(dot, 'circle', cx=x, cy=y, r=2.5) self.node(dot, 'circle', cx=x, cy=y, r=2.5)
self.node(dot, 'text', x=x, y=y).text = str(values[i][1]) self.node(dot, 'text', x=x, y=y).text = str(
values[i]) if xy else str(values[i][1])
svg_values = ' '.join(map(lambda x: '%f %f' % x, view_values)) svg_values = ' '.join(map(lambda x: '%f %f' % x, view_values))
self.node(serie_node, 'path', self.node(serie_node, 'path',
@ -245,7 +249,7 @@ class Svg(object):
start_angle * 180 / pi, center_str), start_angle * 180 / pi, center_str),
class_='slice') class_='slice')
text_angle = pi / 2. - (start_angle + angle / 2.) text_angle = pi / 2. - (start_angle + angle / 2.)
text_r = min(center) text_r = min(center) * .8
self.node(slice_, 'text', self.node(slice_, 'text',
x=center[0] + text_r * cos(text_angle), x=center[0] + text_r * cos(text_angle),
y=center[1] - text_r * sin(text_angle), y=center[1] - text_r * sin(text_angle),

2
pygal/xy.py

@ -28,4 +28,4 @@ class XY(BaseGraph):
for serie in self.series: for serie in self.series:
self.svg.line( self.svg.line(
self.svg.serie(serie.index), serie.values) self.svg.serie(serie.index), serie.values, True)

Loading…
Cancel
Save