- Added progress bar support to all multimedia controllers
This commit is contained in:
parent
338f38391f
commit
93cc4235b7
|
@ -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
|
|
|
@ -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)
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
33
themeMgr.py
33
themeMgr.py
|
@ -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
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
Loading…
Reference in New Issue