Compare commits
No commits in common. "8acd279cfeeeaa9157dd4638b524d4688cabc902" and "2ca2471f5e0ab1622c7e46319ed0c46ad53a7011" have entirely different histories.
8acd279cfe
...
2ca2471f5e
@ -53,9 +53,8 @@ class Config(object):
|
||||
FADE_CURVE_BACKGROUND = "lightyellow"
|
||||
FADE_CURVE_FOREGROUND = "blue"
|
||||
FADE_CURVE_MS_BEFORE_FADE = 5000
|
||||
FADEOUT_DB = -10
|
||||
FADEOUT_SECONDS = 5
|
||||
FADEOUT_STEPS_PER_SECOND = 5
|
||||
FADE_STEPS = 20
|
||||
FADE_TIME = 3000
|
||||
HIDE_AFTER_PLAYING_OFFSET = 5000
|
||||
INFO_TAB_TITLE_LENGTH = 15
|
||||
LAST_PLAYED_TODAY_STRING = "Today"
|
||||
|
||||
43
app/music.py
43
app/music.py
@ -19,10 +19,9 @@ lock = threading.Lock()
|
||||
|
||||
|
||||
class FadeTrack(QRunnable):
|
||||
def __init__(self, player: vlc.MediaPlayer, fade_seconds) -> None:
|
||||
def __init__(self, player: vlc.MediaPlayer) -> None:
|
||||
super().__init__()
|
||||
self.player = player
|
||||
self.fade_seconds = fade_seconds
|
||||
|
||||
def run(self):
|
||||
"""
|
||||
@ -32,18 +31,24 @@ class FadeTrack(QRunnable):
|
||||
if not self.player:
|
||||
return
|
||||
|
||||
# Reduce volume logarithmically
|
||||
total_steps = self.fade_seconds * Config.FADEOUT_STEPS_PER_SECOND
|
||||
db_reduction_per_step = Config.FADEOUT_DB / total_steps
|
||||
reduction_factor_per_step = pow(10, (db_reduction_per_step / 20))
|
||||
fade_time = Config.FADE_TIME / 1000
|
||||
steps = Config.FADE_STEPS
|
||||
sleep_time = fade_time / steps
|
||||
original_volume = self.player.audio_get_volume()
|
||||
|
||||
volume = self.player.audio_get_volume()
|
||||
# We reduce volume by one mesure first, then by two measures,
|
||||
# then three, and so on.
|
||||
# The sum of the arithmetic sequence 1, 2, 3, ..n is
|
||||
# (n**2 + n) / 2
|
||||
total_measures_count = (steps**2 + steps) / 2
|
||||
|
||||
for i in range(1, total_steps + 1):
|
||||
self.player.audio_set_volume(
|
||||
int(volume * pow(reduction_factor_per_step, i))
|
||||
)
|
||||
sleep(1 / Config.FADEOUT_STEPS_PER_SECOND)
|
||||
measures_to_reduce_by = 0
|
||||
|
||||
for i in range(1, steps + 1):
|
||||
measures_to_reduce_by += i
|
||||
volume_factor = 1 - (measures_to_reduce_by / total_measures_count)
|
||||
self.player.audio_set_volume(int(original_volume * volume_factor))
|
||||
sleep(sleep_time)
|
||||
|
||||
self.player.stop()
|
||||
log.debug(f"Releasing player {self.player=}")
|
||||
@ -60,7 +65,7 @@ class Music:
|
||||
self.player = None
|
||||
self.max_volume = Config.VOLUME_VLC_DEFAULT
|
||||
|
||||
def fade(self, fade_seconds: int = Config.FADEOUT_SECONDS) -> None:
|
||||
def fade(self) -> None:
|
||||
"""
|
||||
Fade the currently playing track.
|
||||
|
||||
@ -81,7 +86,7 @@ class Music:
|
||||
self.player = None
|
||||
|
||||
pool = QThreadPool.globalInstance()
|
||||
fader = FadeTrack(p, fade_seconds=fade_seconds)
|
||||
fader = FadeTrack(p)
|
||||
pool.start(fader)
|
||||
|
||||
def get_position(self) -> Optional[float]:
|
||||
@ -91,7 +96,7 @@ class Music:
|
||||
return None
|
||||
return self.player.get_position()
|
||||
|
||||
def play(self, path: str, position: Optional[float] = None) -> None:
|
||||
def play(self, path: str, position: Optional[float] = None) -> Optional[int]:
|
||||
"""
|
||||
Start playing the track at path.
|
||||
|
||||
@ -102,15 +107,19 @@ class Music:
|
||||
log.error(f"play({path}): path not readable")
|
||||
return None
|
||||
|
||||
status = -1
|
||||
|
||||
media = self.VLC.media_new_path(path)
|
||||
self.player = media.player_new_from_media()
|
||||
if self.player:
|
||||
_ = self.player.play()
|
||||
status = self.player.play()
|
||||
self.set_volume(self.max_volume)
|
||||
if position:
|
||||
self.player.set_position(position)
|
||||
|
||||
def set_volume(self, volume=None, set_default=True) -> None:
|
||||
return status
|
||||
|
||||
def set_volume(self, volume=None, set_default=True):
|
||||
"""Set maximum volume used for player"""
|
||||
|
||||
if not self.player:
|
||||
|
||||
Loading…
Reference in New Issue
Block a user