1990-10-25 19:51:42 +01:00
|
|
|
# Module 'Soundogram'
|
|
|
|
|
|
|
|
import audio
|
|
|
|
from Histogram import Histogram
|
|
|
|
|
1991-12-26 14:06:29 +01:00
|
|
|
class Soundogram(Histogram):
|
1990-10-25 19:51:42 +01:00
|
|
|
#
|
1992-12-14 13:57:56 +01:00
|
|
|
def define(self, win, chunk):
|
1990-10-25 19:51:42 +01:00
|
|
|
width, height = corner = win.getwinsize()
|
|
|
|
bounds = (0, 0), corner
|
|
|
|
self.chunk = chunk
|
|
|
|
self.step = (len(chunk)-1)/(width/2+1) + 1
|
|
|
|
ydata = _make_ydata(chunk, self.step)
|
|
|
|
return Histogram.define(self, (win, bounds, ydata, (0, 128)))
|
|
|
|
#
|
|
|
|
def setchunk(self, chunk):
|
|
|
|
self.chunk = chunk
|
|
|
|
self.recompute()
|
|
|
|
#
|
|
|
|
def recompute(self):
|
|
|
|
(left, top), (right, bottom) = self.bounds
|
|
|
|
width = right - left
|
|
|
|
self.step = (len(chunk)-1)/width + 1
|
|
|
|
ydata = _make_ydata(chunk, self.step)
|
|
|
|
self.setdata(ydata, (0, 128))
|
|
|
|
#
|
|
|
|
|
|
|
|
|
|
|
|
def _make_ydata(chunk, step):
|
|
|
|
ydata = []
|
|
|
|
for i in range(0, len(chunk), step):
|
|
|
|
piece = audio.chr2num(chunk[i:i+step])
|
|
|
|
mi, ma = min(piece), max(piece)
|
|
|
|
y = max(abs(mi), abs(ma))
|
|
|
|
ydata.append(y)
|
|
|
|
return ydata
|