Browse Source

PolarLogView

pull/242/head
Florian Mounier 10 years ago
parent
commit
65bdc4ae75
  1. 13
      pygal/view.py

13
pygal/view.py

@ -255,8 +255,9 @@ class PolarThetaView(View):
class PolarThetaLogView(View): class PolarThetaLogView(View):
"""Logarithmic polar projection""" """Logarithmic polar projection"""
def __init__(self, width, height, box): def __init__(self, width, height, box, aperture=pi / 3):
super(PolarThetaLogView, self).__init__(width, height, box) super(PolarThetaLogView, self).__init__(width, height, box)
self.aperture = aperture
if not hasattr(box, '_tmin') or not hasattr(box, '_tmax'): if not hasattr(box, '_tmin') or not hasattr(box, '_tmax'):
raise Exception( raise Exception(
'Box must be set with set_polar_box for polar charts') 'Box must be set with set_polar_box for polar charts')
@ -276,14 +277,14 @@ class PolarThetaLogView(View):
theta = self.box._tmin + (self.box._tmax - self.box._tmin) * ( theta = self.box._tmin + (self.box._tmax - self.box._tmin) * (
log10(theta) - self.log10_tmin) / ( log10(theta) - self.log10_tmin) / (
self.log10_tmax - self.log10_tmin) self.log10_tmax - self.log10_tmin)
aperture = pi / 3
if theta > self.box._tmax: if theta > self.box._tmax:
theta = (3 * pi - aperture / 2) / 2 theta = (3 * pi - self.aperture / 2) / 2
elif theta < self.box._tmin: elif theta < self.box._tmin:
theta = (3 * pi + aperture / 2) / 2 theta = (3 * pi + self.aperture / 2) / 2
else: else:
start = 3 * pi / 2 + aperture / 2 start = 3 * pi / 2 + self.aperture / 2
theta = start + (2 * pi - aperture) * ( theta = start + (2 * pi - self.aperture) * (
theta - self.box._tmin) / ( theta - self.box._tmin) / (
self.box._tmax - self.box._tmin) self.box._tmax - self.box._tmin)

Loading…
Cancel
Save