get_status() and play_pause() implemented

This commit is contained in:
coderkun 2012-06-24 00:13:24 +02:00
parent b218c93bd4
commit f59d1a83e2
2 changed files with 126 additions and 49 deletions

62
mcg.py
View file

@ -22,8 +22,8 @@ class MCGClient:
SIGNAL_CONNECT = 'connect'
# Signal: general idle event
SIGNAL_IDLE = 'idle'
# Signal: player idle event
SIGNAL_IDLE_PLAYER = 'idle_player'
# Signal: status event
SIGNAL_STATUS = 'status'
# Signal: update event
SIGNAL_UPDATE = 'update'
@ -79,12 +79,24 @@ class MCGClient:
self._add_action(self._update)
def play(self, album):
def get_status(self):
"""Determines the current status.
"""
self._add_action(self._get_status)
def play_album(self, album):
"""Plays the given album.
"""
self._add_action(self._play, album)
def playpause(self):
"""Plays or pauses the current state.
"""
self._add_action(self._playpause)
def connect_signal(self, signal, callback):
"""Connects a callback function to a signal (event).
"""
@ -157,7 +169,7 @@ class MCGClient:
self._connected = True
self._callback(self.SIGNAL_CONNECT, self._connected, None)
self.update()
self._add_action(self._idle_player)
self._add_action(self._get_status)
except IOError as e:
self._connected = False
self._callback(self.SIGNAL_CONNECT, self._connected, e)
@ -196,6 +208,20 @@ class MCGClient:
self._callback(self.SIGNAL_UPDATE, self._albums)
def _get_status(self):
"""Action: Performs the real status determination
"""
if not self._has_callback(self.SIGNAL_STATUS):
return
status = self._client.status()
state = status['state']
song = self._client.currentsong()
album = None
if song:
album = MCGAlbum(song['artist'], song['album'], song['date'], os.path.dirname(song['file']))
self._callback(self.SIGNAL_STATUS, state, album)
def _play(self, album):
"""Action: Performs the real play command.
"""
@ -207,6 +233,18 @@ class MCGClient:
self._client.playid(track_ids[0])
def _playpause(self):
"""Action: Performs the real play/pause command.
"""
status = self._client.status()
state = status['state']
if state == 'play':
self._client.pause()
else:
self._client.play()
def _idle(self, modules):
"""Reacts to idle events from MPD.
"""
@ -214,7 +252,7 @@ class MCGClient:
return
if 'player' in modules:
self._idle_player()
self._get_status()
if 'database' in modules:
# TODO update DB
pass
@ -226,20 +264,6 @@ class MCGClient:
pass
def _idle_player(self):
"""Reacts on the player idle event.
"""
if not self._has_callback(self.SIGNAL_IDLE_PLAYER):
return
status = self._client.status()
state = status['state']
song = self._client.currentsong()
album = None
if song:
album = MCGAlbum(song['artist'], song['album'], song['date'], os.path.dirname(song['file']))
self._callback(self.SIGNAL_IDLE_PLAYER, state, album)
def _idle_playlist(self):
""" Reacts on the playlist idle event.
"""

111
mcgGtk.py
View file

@ -36,13 +36,16 @@ class MCGGtk(Gtk.Window):
self.connect('window-state-event', self.save_state)
self.connect('delete-event', self.destroy)
self._toolbar.connect_signal(Toolbar.SIGNAL_CONNECT, self._connect)
self._toolbar.connect_signal(Toolbar.SIGNAL_UPDATE, self._update)
self._toolbar.connect_signal(Toolbar.SIGNAL_UPDATE, self.update)
self._toolbar.connect_signal(Toolbar.SIGNAL_PREV, self.prev)
self._toolbar.connect_signal(Toolbar.SIGNAL_PLAYPAUSE, self.playpause)
self._toolbar.connect_signal(Toolbar.SIGNAL_NEXT, self.next)
self._cover_panel.connect_signal(CoverPanel.SIGNAL_UPDATE_START, self.update_start_callback)
self._cover_panel.connect_signal(CoverPanel.SIGNAL_UPDATE_END, self.update_end_callback)
self._cover_panel.connect_signal(CoverPanel.SIGNAL_PLAY, self.play_callback)
self._mcg.connect_signal(mcg.MCGClient.SIGNAL_CONNECT, self.connect_callback)
self._mcg.connect_signal(mcg.MCGClient.SIGNAL_STATUS, self.status_callback)
self._mcg.connect_signal(mcg.MCGClient.SIGNAL_UPDATE, self.update_callback)
self._mcg.connect_signal(mcg.MCGClient.SIGNAL_IDLE_PLAYER, self.idle_player_callback)
self.set_hide_titlebar_when_maximized(True)
self.resize_to_geometry(self._config.window_width, self._config.window_height)
@ -89,6 +92,51 @@ class MCGGtk(Gtk.Window):
GObject.idle_add(self._connect_disconnected)
def prev(self):
"""TODO prev()
"""
pass
def playpause(self):
self._mcg.playpause()
def next(self):
"""TODO next()
"""
pass
def play_callback(self, album):
self._mcg.play_album(album)
def status_callback(self, state, album):
if state == 'play':
GObject.idle_add(self._toolbar.set_pause)
elif state == 'pause' or state == 'stop':
GObject.idle_add(self._toolbar.set_play)
if album:
GObject.idle_add(self._cover_panel.set_album, album.get_cover())
def update(self):
self._toolbar.lock()
self._mcg.update()
def update_callback(self, albums):
self._cover_panel.update(albums)
def update_start_callback(self):
GObject.idle_add(self._toolbar.lock)
def update_end_callback(self):
GObject.idle_add(self._toolbar.unlock)
def _connect_connected(self):
self._toolbar.connected()
@ -105,38 +153,14 @@ class MCGGtk(Gtk.Window):
self._toolbar.disconnected()
def _update(self):
self._toolbar.lock()
self._mcg.update()
def update_callback(self, albums):
self._cover_panel.update(albums)
def update_start_callback(self):
GObject.idle_add(self._toolbar.lock)
def update_end_callback(self):
GObject.idle_add(self._toolbar.unlock)
def idle_player_callback(self, state, album):
if album:
GObject.idle_add(self._cover_panel.set_album, album.get_cover())
def play_callback(self, album):
self._mcg.play(album)
class Toolbar(Gtk.Toolbar):
SIGNAL_CONNECT = 'connect'
SIGNAL_UPDATE = 'update'
SIGNAL_PREV = 'prev'
SIGNAL_NEXT = 'next'
SIGNAL_PLAYPAUSE = 'playpause'
def __init__(self):
Gtk.Toolbar.__init__(self)
@ -149,10 +173,20 @@ class Toolbar(Gtk.Toolbar):
self.add(self._connection_button)
self._update_button = Gtk.ToolButton(Gtk.STOCK_REFRESH)
self.add(self._update_button)
self.add(Gtk.SeparatorToolItem())
self._prev_button = Gtk.ToolButton(Gtk.STOCK_MEDIA_PREVIOUS)
self.add(self._prev_button)
self._playpause_button = Gtk.ToolButton(Gtk.STOCK_MEDIA_PLAY)
self.add(self._playpause_button)
self._next_button = Gtk.ToolButton(Gtk.STOCK_MEDIA_NEXT)
self.add(self._next_button)
# Signals
self._connection_button.connect('clicked', self._callback)
self._update_button.connect('clicked', self._callback)
self._prev_button.connect('clicked', self._callback)
self._playpause_button.connect('clicked', self._callback)
self._next_button.connect('clicked', self._callback)
def connect_signal(self, signal, callback):
@ -175,12 +209,31 @@ class Toolbar(Gtk.Toolbar):
self.set_sensitive(True)
def set_play(self):
self._playpause_button.set_stock_id(Gtk.STOCK_MEDIA_PLAY)
def set_pause(self):
self._playpause_button.set_stock_id(Gtk.STOCK_MEDIA_PAUSE)
def lock_playpause(self):
self._playpause_button.set_stock_id(Gtk.STOCK_MEDIA_PLAY)
self._playpause_button.set_sensitive(False);
def _callback(self, widget):
signal = None
if widget == self._connection_button:
signal = self.SIGNAL_CONNECT
if widget == self._update_button:
signal = self.SIGNAL_UPDATE
if widget == self._prev_button:
signal = self.SIGNAL_PREV
if widget == self._playpause_button:
signal = self.SIGNAL_PLAYPAUSE
if widget == self._next_button:
signal = self.SIGNAL_NEXT
if signal in self._callbacks:
callback = self._callbacks[signal]