- Added progress bar support to all multimedia controllers

This commit is contained in:
noisymime 2008-05-22 12:41:04 +00:00
parent 338f38391f
commit 93cc4235b7
9 changed files with 241 additions and 48 deletions

View File

@ -49,11 +49,7 @@ class Module:
self.timeout_id = 0 self.timeout_id = 0
self.queue_id = 0 self.queue_id = 0
#There has be 3 of these labels, one left, center and right self.heading = None
self.artist_label_1 = clutter.Label()
self.artist_label_2 = clutter.Label()
self.artist_label_3 = clutter.Label()
self.artist_label_current = self.artist_label_1
self.setup_ui() self.setup_ui()
@ -64,12 +60,18 @@ class Module:
self.default_album_cover = self.glossMgr.themeMgr.get_texture("music_default_album_image", None, None).get_pixbuf() self.default_album_cover = self.glossMgr.themeMgr.get_texture("music_default_album_image", None, None).get_pixbuf()
self.main_img = self.glossMgr.themeMgr.get_imageFrame("music_main_image") self.main_img = self.glossMgr.themeMgr.get_imageFrame("music_main_image")
colour = clutter.color_parse('White')
font_string = "Tahoma 30"
self.heading = musicHeading(colour, font_string)
self.heading.set_position(400, 250)
"""
self.artist_label_1.set_position(200, 200) self.artist_label_1.set_position(200, 200)
self.artist_label_2.set_position(200, 200) self.artist_label_2.set_position(200, 200)
self.artist_label_3.set_position(200, 200) self.artist_label_3.set_position(200, 200)
self.artist_label_1.set_color(clutter.color_parse('White')) self.artist_label_1.set_color(clutter.color_parse('White'))
self.artist_label_2.set_color(clutter.color_parse('White')) self.artist_label_2.set_color(clutter.color_parse('White'))
self.artist_label_3.set_color(clutter.color_parse('White')) self.artist_label_3.set_color(clutter.color_parse('White'))
"""
#Get the images dir setting our of the DB #Get the images dir setting our of the DB
#But also creates the setting if it doesn't already exist #But also creates the setting if it doesn't already exist
@ -128,7 +130,7 @@ class Module:
self.playlist.add_songs(songs) self.playlist.add_songs(songs)
self.playlist.play() self.playlist.play()
self.play_screen.append_playlist(self.playlist) #self.play_screen.append_playlist(self.playlist)
self.play_screen.display(self.artistImageRow.get_current_texture())#.get_texture()) self.play_screen.display(self.artistImageRow.get_current_texture())#.get_texture())
self.current_context = self.CONTEXT_PLAY_SCR self.current_context = self.CONTEXT_PLAY_SCR
@ -181,7 +183,7 @@ class Module:
self.conn_id = self.backend.connect("query-complete", self.update_for_albums, artist) self.conn_id = self.backend.connect("query-complete", self.update_for_albums, artist)
self.backend.get_albums_by_artistID(artist.artistID) self.backend.get_albums_by_artistID(artist.artistID)
self.transition_heading(self.direction, self.previous_music_object, artist, None) self.heading.transition_heading(self.direction, self.previous_music_object, artist, None)
#thread = threading.Thread(target=self.backend.get_albums_by_artistID, args=(artist.artistID,)) #thread = threading.Thread(target=self.backend.get_albums_by_artistID, args=(artist.artistID,))
#thread.start() #thread.start()
@ -298,15 +300,53 @@ class Module:
self.main_img.show() self.main_img.show()
self.stage.add(self.main_img) self.stage.add(self.main_img)
self.stage.add(self.artist_label_1) self.stage.add(self.heading)
self.artist_label_1.show() self.heading.show()
self.stage.add(self.artist_label_2)
self.artist_label_2.show()
self.stage.add(self.artist_label_3)
self.artist_label_3.show()
self.timeline_display.start() self.timeline_display.start()
def stop(self):
pass
def pause(self):
pass
def unpause(self):
pass
class musicHeading(clutter.Group):
DIRECTION_LEFT, DIRECTION_RIGHT = range(2)
def __init__(self, colour = None, font_string = None):
clutter.Group.__init__(self)
if colour is None: colour = clutter.color_parse('White')
if font_string is None: font_string = "Tahoma 30"
#There has be 3 of these labels, one left, center and right
self.label_1 = clutter.Label()
self.label_2 = clutter.Label()
self.label_3 = clutter.Label()
self.label_1.set_font_name(font_string)
self.label_2.set_font_name(font_string)
self.label_3.set_font_name(font_string)
self.label_1.set_color(colour)
self.label_2.set_color(colour)
self.label_3.set_color(colour)
self.label_current = self.label_1
self.add(self.label_1)
self.add(self.label_2)
self.add(self.label_3)
self.label_1.show()
self.label_2.show()
self.label_3.show()
def transition_heading(self, direction, old_music_item, new_music_item, timeline = None): def transition_heading(self, direction, old_music_item, new_music_item, timeline = None):
start_timeline = False start_timeline = False
if timeline is None: if timeline is None:
@ -317,33 +357,33 @@ class Module:
self.alpha = clutter.Alpha(timeline, clutter.ramp_inc_func) self.alpha = clutter.Alpha(timeline, clutter.ramp_inc_func)
if direction == self.DIRECTION_LEFT: if direction == self.DIRECTION_LEFT:
if self.artist_label_current == self.artist_label_1: next_label = self.artist_label_2 if self.label_current == self.label_1: next_label = self.label_2
elif self.artist_label_current == self.artist_label_2: next_label = self.artist_label_3 elif self.label_current == self.label_2: next_label = self.label_3
elif self.artist_label_current == self.artist_label_3: next_label = self.artist_label_1 elif self.label_current == self.label_3: next_label = self.label_1
else: else:
if self.artist_label_current == self.artist_label_1: next_label = self.artist_label_3 if self.label_current == self.label_1: next_label = self.label_3
elif self.artist_label_current == self.artist_label_2: next_label = self.artist_label_1 elif self.label_current == self.label_2: next_label = self.label_1
elif self.artist_label_current == self.artist_label_3: next_label = self.artist_label_2 elif self.label_current == self.label_3: next_label = self.label_2
next_label.set_opacity(0) next_label.set_opacity(0)
next_label.set_scale(0.5, 0.5) next_label.set_scale(0.5, 0.5)
next_label.set_text(new_music_item.name) next_label.set_text(new_music_item.name)
if direction == self.DIRECTION_LEFT: if direction == self.DIRECTION_RIGHT:
next_label.set_x( self.artist_label_current.get_x() + (self.artist_label_current.get_width())) next_label.set_x( self.label_current.get_x() + (self.label_current.get_width()))
outgoing_x = self.artist_label_current.get_x() - int(self.artist_label_current.get_width()/2) outgoing_x = self.label_current.get_x() - int(self.label_current.get_width()/2)
else: else:
next_label.set_x( self.artist_label_current.get_x() - (next_label.get_width())) next_label.set_x( self.label_current.get_x() - (next_label.get_width()))
outgoing_x = self.artist_label_current.get_x() + int(self.artist_label_current.get_width()) outgoing_x = self.label_current.get_x() + int(self.label_current.get_width())
incoming_x = self.artist_label_current.get_x() + int(self.artist_label_current.get_width()/2) - int(next_label.get_width()/2) incoming_x = self.label_current.get_x() + int(self.label_current.get_width()/2) - int(next_label.get_width()/2)
knots_incoming =(\ knots_incoming =(\
(next_label.get_x(), next_label.get_y()), (next_label.get_x(), next_label.get_y()),
(incoming_x, next_label.get_y()) (incoming_x, next_label.get_y())
) )
knots_outgoing =(\ knots_outgoing =(\
(self.artist_label_current.get_x(), self.artist_label_current.get_y()), (self.label_current.get_x(), self.label_current.get_y()),
(outgoing_x, next_label.get_y()) (outgoing_x, next_label.get_y())
) )
@ -357,9 +397,9 @@ class Module:
self.behaviourIncomingPath.apply(next_label) self.behaviourIncomingPath.apply(next_label)
self.behaviourIncomingOpacity.apply(next_label) self.behaviourIncomingOpacity.apply(next_label)
self.behaviourIncomingScale.apply(next_label) self.behaviourIncomingScale.apply(next_label)
self.behaviourOutgoingPath.apply(self.artist_label_current) self.behaviourOutgoingPath.apply(self.label_current)
self.behaviourOutgoingOpacity.apply(self.artist_label_current) self.behaviourOutgoingOpacity.apply(self.label_current)
self.behaviourOutgoingScale.apply(self.artist_label_current) self.behaviourOutgoingScale.apply(self.label_current)
timeline.connect("completed", self.set_next_heading, next_label) timeline.connect("completed", self.set_next_heading, next_label)
@ -367,14 +407,4 @@ class Module:
timeline.start() timeline.start()
def set_next_heading(self, data, new_heading): def set_next_heading(self, data, new_heading):
self.artist_label_current = new_heading self.label_current = new_heading
def stop(self):
pass
def pause(self):
pass
def unpause(self):
pass

View File

@ -1,5 +1,6 @@
import clutter import clutter
from modules.music_player.playlist import Playlist from modules.music_player.playlist import Playlist
from multimedia.progress_bar import ProgressBar
from ui_elements.image_frame import ImageFrame from ui_elements.image_frame import ImageFrame
from ui_elements.image_clone import ImageClone from ui_elements.image_clone import ImageClone
from ui_elements.label_list import LabelList from ui_elements.label_list import LabelList
@ -17,11 +18,16 @@ class PlayScreen(clutter.Group):
self.main_img = None self.main_img = None
self.song_list = LabelList(8) self.song_list = LabelList(8)
self.playlist = Playlist(musicPlayer) self.playlist = musicPlayer.playlist #Playlist(musicPlayer)
controller = self.playlist.audio_controller
self.progress_bar = ProgressBar(controller)
self.setup() self.setup()
def setup(self): def setup(self):
self.progress_bar.setup_from_theme_id(self.glossMgr.themeMgr, "music_progress_bar")
self.song_list.setup_from_theme_id(self.glossMgr.themeMgr, "music_play_screen_songs") self.song_list.setup_from_theme_id(self.glossMgr.themeMgr, "music_play_screen_songs")
self.main_img_theme = self.glossMgr.themeMgr.get_imageFrame("music_playing_image") self.main_img_theme = self.glossMgr.themeMgr.get_imageFrame("music_playing_image")
self.img_size = self.main_img_theme.img_size self.img_size = self.main_img_theme.img_size
@ -78,6 +84,10 @@ class PlayScreen(clutter.Group):
self.song_list.show() self.song_list.show()
self.add(self.song_list) self.add(self.song_list)
self.add(self.progress_bar)
self.progress_bar.set_position(400, 650)
self.progress_bar.display()
self.show() self.show()
self.stage.add(self) self.stage.add(self)

View File

@ -8,12 +8,12 @@ class AudioController(MediaController):
def __init__(self, glossMgr): def __init__(self, glossMgr):
MediaController.__init__(self, glossMgr) MediaController.__init__(self, glossMgr)
self.isPlaying = False self.isPlaying = False
"""
# Primary audio object # Primary audio object
self.audio = clutter.cluttergst.Audio() self.audio = clutter.cluttergst.Audio()
self.audio.connect("eos", self.stream_complete) self.audio.connect("eos", self.stream_complete)
self.media_element = self.audio self.media_element = self.audio
"""
#self.osd = osd(glossMgr) #self.osd = osd(glossMgr)
@ -29,10 +29,12 @@ class AudioController(MediaController):
if self.isPlaying: if self.isPlaying:
self.audio.set_playing(False) self.audio.set_playing(False)
"""
# Primary audio object # Primary audio object
self.audio = clutter.cluttergst.Audio() self.audio = clutter.cluttergst.Audio()
self.audio.connect("eos", self.stream_complete) self.audio.connect("eos", self.stream_complete)
self.media_element = self.audio self.media_element = self.audio
"""
self.audio.set_uri(uri) self.audio.set_uri(uri)
self.audio.set_playing(True) self.audio.set_playing(True)

View File

@ -2,6 +2,9 @@ import clutter
import gobject import gobject
from multimedia.MediaOSD import osd from multimedia.MediaOSD import osd
# This is an abstract class
# It should not be instantiated directly
class MediaController(gobject.GObject): class MediaController(gobject.GObject):
#Setup signals #Setup signals
@ -42,3 +45,14 @@ class MediaController(gobject.GObject):
#Until then use: #Until then use:
self.media_element.set_property("position", int(new_pos)) self.media_element.set_property("position", int(new_pos))
if self.use_osd: self.osd.shift_media(amount) if self.use_osd: self.osd.shift_media(amount)
def get_position_percent(self):
length = int(self.media_element.get_duration())
pos = int(self.media_element.get_property("position"))
#Sanity check
if length == 0: return 0
percent = float( float(pos) / float(length) )
return percent

View File

@ -0,0 +1,63 @@
import clutter
import gobject
class ProgressBar(clutter.Group):
def __init__(self, Controller):
clutter.Group.__init__(self)
self.media_controller = Controller
self.bg = clutter.Rectangle()
self.fg = clutter.Rectangle()
self.add(self.bg)
self.bg.show()
self.add(self.fg)
self.fg.show()
def setup_from_theme_id(self, themeMgr, id):
element = themeMgr.search_docs("progress_bar", id).childNodes
colour_element = themeMgr.search_docs("progress_bar", id).getElementsByTagName("colour")
#width = clutter.Stage.get_width(), height = 10
(self.width, self.height) = themeMgr.get_dimensions(element, themeMgr.stage)
colour_element_bg = themeMgr.find_element(colour_element, "id", "background")
colour_element_fg = themeMgr.find_element(colour_element, "id", "foreground")
if not colour_element_bg is None:
colour_element_bg = colour_element_bg.childNodes
bgColour = themeMgr.get_colour(colour_element_bg, "background")
if not colour_element_fg is None:
colour_element_fg = colour_element_fg.childNodes
fgColour = themeMgr.get_colour(colour_element_fg, "foreground")
#bgColour = themeMgr.get_colour(element, "background")
#fgColour = themeMgr.get_colour(element, "foreground")
self.bg.set_color(bgColour)
self.bg.set_size(self.width, self.height)
self.fg.set_color(fgColour)
self.fg.set_size(20, self.height)
def display(self):
self.displayed = True
self.show()
gobject.timeout_add(1000, self.tick)
def tick(self):
if self.displayed:
percent = self.media_controller.get_position_percent()
new_width = int(float(self.width) * float(percent))
#print "new width: %s" % float(new_width)
self.fg.set_width(new_width)
return True
else:
return False

View File

@ -26,7 +26,7 @@ class mythDB():
def read_config(self): def read_config(self):
conf_file = os.path.expanduser("~/.mythtv/mysql.txt") conf_file = os.path.expanduser("~/.mythtv/mysql.txt")
if not os.path.exists(conf_file): if not os.path.exists(conf_file):
print "ERROR: No config file found at ~.mythtv/mysql.txt!" print "ERROR: No config file found at ~/.mythtv/mysql.txt!"
print "No connection to MythTV Database can be made. Quitting" print "No connection to MythTV Database can be made. Quitting"
clutter.main_quit() clutter.main_quit()
return False return False

View File

@ -264,6 +264,20 @@ class ThemeMgr:
return (int(x), int(y)) return (int(x), int(y))
def get_colour(self, element, name):
if element is None:
element = self.search_docs("colour", name).childNodes
#Quick check to make sure we found something
if element is None:
return None
r = int(self.find_child_value(element, "r"))
g = int(self.find_child_value(element, "g"))
b = int(self.find_child_value(element, "b"))
colour = clutter.Color(r, g, b)
return colour
def get_texture(self, name, parent, texture = None, element = None): def get_texture(self, name, parent, texture = None, element = None):
texture_src = None texture_src = None
if texture is None: if texture is None:
@ -292,6 +306,7 @@ class ThemeMgr:
return texture return texture
def get_font(self, name, element): def get_font(self, name, element):
if element is None: if element is None:
element = self.search_docs("font", name).childNodes element = self.search_docs("font", name).childNodes
@ -381,3 +396,21 @@ class ThemeMgr:
img_frame.set_position(int(x), int(y)) img_frame.set_position(int(x), int(y))
return img_frame return img_frame
def get_label(self, id, parent = None, element = None, label = None):
if element is None:
element = self.search_docs("label", id).childNodes
#Quick check to make sure we found something
if element is None:
return None
if label is None: label = clutter.Label()
if parent is None: parent = self.stage
font_string = self.get_font("font", element)
label.set_font_name(font_string)
self.setup_actor(label, element, parent)
return label

View File

@ -109,4 +109,23 @@
<y>40%</y> <y>40%</y>
</position> </position>
</image_frame> </image_frame>
<label id="heading">
<font id="font">
<face>Tahoma</face>
<size id="default">30</size>
<size id="1024x768">38</size>
<size id="800x600">30</size>
<size id="1920x1080">25</size>
</font>
<dimensions type="relativeToStage">
<width>25%</width>
<height>25%</height>
</dimensions>
<position type="relativeToStage">
<x>10%</x>
<y>40%</y>
</position>
</label>
</gloss-theme> </gloss-theme>

View File

@ -92,4 +92,26 @@
</position> </position>
</image_frame> </image_frame>
<progress_bar id="music_progress_bar">
<colour id="background">
<r>100</r>
<g>100</g>
<b>100</b>
</colour>
<colour id="foreground">
<r>255</r>
<g>255</g>
<b>255</b>
</colour>
<dimensions type="relativeToStage">
<width>30%</width>
<height>10%</height>
</dimensions>
<position type="relativeToStage">
<x>10%</x>
<y>35%</y>
</position>
</progress_bar>
</gloss-theme> </gloss-theme>