X-Git-Url: https://scm.cri.ensmp.fr/git/minwii.git/blobdiff_plain/ee24fce216592a13d95977d7d4e3374692fd6924..f6e0db47250bd3666e1f46f22ed8153d77b46f2e:/src/app/synth.py?ds=sidebyside diff --git a/src/app/synth.py b/src/app/synth.py index 9fb4a3e..469fd04 100755 --- a/src/app/synth.py +++ b/src/app/synth.py @@ -7,7 +7,9 @@ $URL$ """ from os.path import realpath, sep, exists from fluidsynth import Synth as FSynth -from log import console +from log import console, envLogger, eventLogger +import pygame +import events class Synth(FSynth) : """ @@ -33,10 +35,11 @@ class Synth(FSynth) : self.start() self.fsid = self.sfload(sfPath) self._octaveAjusts = {} - console.info('démarrage du synthétiseur\nsoundfont : %s', sfPath) + console.info('démarrage du synthétiseur') + envLogger.info('soundfont : %s', sfPath) def __del__(self) : - console.info('arrêt du synthétiseur.') + console.info('arrêt du synthétiseur') self.delete() def adjust_octave(self, chan, octave) : @@ -54,10 +57,22 @@ class Synth(FSynth) : def sfont_select(self, chan): FSynth.sfont_select(self, chan, self.fsid) + + # on loggue les noteon / noteoff en utilisant les événements pygame + # mais ils ne sont pas postés -> on fait ça pour que le log de l'événement + # et l'exécution du noteon/off soit effectué au sein de la même itération + # de la boucle principale. + def noteon(self, chan, key, vel): key = key + self._octaveAjusts.get(chan, 0) * 12 FSynth.noteon(self, chan, key, vel) + evt = pygame.event.Event(events.NOTEON, chan=chan, key=key, vel=vel) + eventLogger.info(evt) + #pygame.event.post(evt) def noteoff(self, chan, key) : key = key + self._octaveAjusts.get(chan, 0) * 12 FSynth.noteoff(self, chan, key) + evt = pygame.event.Event(events.NOTEOFF, chan=chan, key=key) + eventLogger.info(evt) + #pygame.event.post(evt)