|
|
@ -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), |
|
|
|