]> git.immae.eu Git - perso/Immae/Projets/Python/MusicSampler.git/commitdiff
Handle fade for master volume
authorIsmaël Bouya <ismael.bouya@normalesup.org>
Thu, 21 Jul 2016 07:26:20 +0000 (09:26 +0200)
committerIsmaël Bouya <ismael.bouya@normalesup.org>
Thu, 21 Jul 2016 07:26:20 +0000 (09:26 +0200)
helpers/action.py
helpers/mapping.py

index b8e44e6783267fcfd9781f3817cf1fbd58f550ee..247e0a9c50ff765cdf73d33490a5895930575a53 100644 (file)
@@ -106,7 +106,7 @@ class Action:
         if music is not None:
             music.set_volume(value, delta=delta, fade=fade)
         else:
-            self.mapping.set_master_volume(value, delta=delta)
+            self.mapping.set_master_volume(value, delta=delta, fade=fade)
 
     def wait(self, duration=0, music=None, **kwargs):
         self.sleep_event = threading.Event()
@@ -210,7 +210,7 @@ class Action:
                 message += "setting volume to {}%" \
                         .format(value)
 
-        if music is not None and fade > 0:
+        if fade > 0:
             message += " with {}s fade".format(fade)
 
         return message
index 9420acff8b4f07ab69023cab62af0965eb2f30d8..3622f9d8d42086369d59702cf45e6e3cd03fa9d5 100644 (file)
@@ -10,6 +10,7 @@ import sys
 from .music_file import *
 from .mixer import Mixer
 from . import Config, gain, error_print
+from .music_effect import GainEffect
 
 class Mapping(RelativeLayout):
     expected_keys = NumericProperty(0)
@@ -32,13 +33,22 @@ class Mapping(RelativeLayout):
     def master_gain(self):
         return gain(self.master_volume)
 
-    def set_master_volume(self, value, delta=False):
+    def set_master_volume(self, value, delta=False, fade=0):
         [db_gain, self.master_volume] = gain(
                 value + int(delta) * self.master_volume,
                 self.master_volume)
 
         for music in self.open_files.values():
-            music.set_gain(db_gain)
+            if fade > 0:
+                music.gain_effects.append(GainEffect(
+                    "fade",
+                    music.current_audio_segment,
+                    music.current_loop,
+                    music.sound_position,
+                    music.sound_position + fade,
+                    gain=db_gain))
+            else:
+                music.set_gain(db_gain)
 
     def _keyboard_closed(self):
         self._keyboard.unbind(on_key_down=self._on_keyboard_down)