- More significant work on label_list and music playscreen

This commit is contained in:
noisymime 2008-05-13 13:45:59 +00:00
parent 3a5822db37
commit 87c681cb3b
9 changed files with 121 additions and 37 deletions

View File

@ -138,7 +138,9 @@ class Module:
elif self.current_context == self.CONTEXT_PLAY_SCR: elif self.current_context == self.CONTEXT_PLAY_SCR:
if (event.keyval == clutter.keysyms.Escape): if (event.keyval == clutter.keysyms.Escape):
self.current_context = self.previous_context self.current_context = self.previous_context
self.play_screen.hide() self.play_screen.undisplay()
else:
self.play_screen.on_key_press_event(stage, event)
#Fills self.list2 with songs from an album #Fills self.list2 with songs from an album
def process_songlist_from_album(self, list_item, album): def process_songlist_from_album(self, list_item, album):

View File

@ -26,6 +26,12 @@ class PlayScreen(clutter.Group):
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
def on_key_press_event(self, stage, event):
if (event.keyval == clutter.keysyms.Up):
self.song_list.input_queue.input(event)
elif (event.keyval == clutter.keysyms.Down):
self.song_list.input_queue.input(event)
def append_playlist(self, playlist): def append_playlist(self, playlist):
self.playlist.add_songs(playlist.songs) self.playlist.add_songs(playlist.songs)
@ -68,6 +74,7 @@ class PlayScreen(clutter.Group):
self.song_list.add_item(song.name) self.song_list.add_item(song.name)
self.opacity_behaviour.apply(self.song_list) self.opacity_behaviour.apply(self.song_list)
self.song_list.set_opacity(0) self.song_list.set_opacity(0)
self.song_list.select_first()
self.song_list.show() self.song_list.show()
self.add(self.song_list) self.add(self.song_list)
@ -76,5 +83,6 @@ class PlayScreen(clutter.Group):
self.timeline.start() self.timeline.start()
def hide(self): def undisplay(self):
pass self.playlist.stop()
self.hide()

View File

@ -34,6 +34,10 @@ class Playlist:
self.position += 1 self.position += 1
self.play() self.play()
def stop(self):
if self.is_playing:
self.audio_controller.stop_audio()
def add_song(self, song): def add_song(self, song):
self.songs.append(song) self.songs.append(song)

View File

@ -339,7 +339,7 @@ class ThemeMgr:
if not use_reflections is None: if not use_reflections is None:
use_reflections = (use_reflections.upper() == "TRUE") use_reflections = (use_reflections.upper() == "TRUE")
else: else:
#Gotta have some default value. In reality if this is running, someone else has stuffed up by not providing the size in the theme #Gotta have some default value.
use_reflections = True use_reflections = True
quality = self.find_child_value(element, "quality") quality = self.find_child_value(element, "quality")
@ -354,7 +354,7 @@ class ThemeMgr:
#Default value #Default value
quality = ImageFrame.QUALITY_NORMAL quality = ImageFrame.QUALITY_NORMAL
else: else:
#Gotta have some default value. In reality if this is running, someone else has stuffed up by not providing the size in the theme #Gotta have some default value.
quality = ImageFrame.QUALITY_NORMAL quality = ImageFrame.QUALITY_NORMAL
#Setup the pixbuf #Setup the pixbuf

BIN
themes/Pear/down.png Executable file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

View File

@ -29,8 +29,11 @@
<y>50%</y> <y>50%</y>
</position> </position>
<item_gap>0</item_gap> <!-- This determines the height of each item based on a percentage of the font size.
<num_visible_elements>4</num_visible_elements> Eg: 1.00 means that each item will be the same height as the font,
1.50 means that the item will be 1.x times the height as the font etc
-->
<item_height_percent>1.00</item_height_percent>
<!-- These are the opacity and scale values for the 3 possible steps in the menu <!-- These are the opacity and scale values for the 3 possible steps in the menu
Make all the values the same if you do not want these effects --> Make all the values the same if you do not want these effects -->
@ -65,8 +68,11 @@
<y>50%</y> <y>50%</y>
</position> </position>
<item_gap>0</item_gap> <!-- This determines the height of each item based on a percentage of the font size.
<num_visible_elements>8</num_visible_elements> Eg: 1.00 means that each item will be the same height as the font,
1.50 means that the item will be 1.x times the height as the font etc
-->
<item_height_percent>1.00</item_height_percent>
<!-- These are the opacity and scale values for the 3 possible steps in the menu <!-- These are the opacity and scale values for the 3 possible steps in the menu
Make all the values the same if you do not want these effects --> Make all the values the same if you do not want these effects -->

View File

@ -14,12 +14,15 @@
<height>40%</height> <height>40%</height>
</dimensions> </dimensions>
<position type="relativeToStage"> <position type="relativeToStage">
<x>40%</x> <x>50%</x>
<y>20%</y> <y>25%</y>
</position> </position>
<item_gap>0</item_gap> <!-- This determines the height of each item based on a percentage of the font size.
<num_visible_elements>4</num_visible_elements> Eg: 1.00 means that each item will be the same height as the font,
1.50 means that the item will be 1.x times the height as the font etc
-->
<item_height_percent>1.00</item_height_percent>
<!-- These are the opacity and scale values for the 3 possible steps in the menu <!-- These are the opacity and scale values for the 3 possible steps in the menu
Make all the values the same if you do not want these effects --> Make all the values the same if you do not want these effects -->
@ -44,8 +47,34 @@
<y>0</y> <y>0</y>
</position> </position>
</texture> </texture>
<texture id="image_up">
<image>up.png</image>
<dimensions type="relativeToStage">
<width>3%</width>
<height>3%</height>
</dimensions>
<position type="relativeToSelf">
<x>0</x>
<y>0</y>
</position>
</texture>
<texture id="image_down">
<image>down.png</image>
<dimensions type="relativeToStage">
<width>3%</width>
<height>3%</height>
</dimensions>
<position type="blah">
<x>0</x>
<y>0</y>
</position>
</texture>
<inactive_background>music/songlist_off.png</inactive_background> <inactive_background>music/songlist_off.png</inactive_background>
</label_list> </label_list>
<image_frame id="music_playing_image"> <image_frame id="music_playing_image">
@ -59,7 +88,7 @@
</dimensions> </dimensions>
<position type="relativeToStage"> <position type="relativeToStage">
<x>10%</x> <x>10%</x>
<y>40%</y> <y>35%</y>
</position> </position>
</image_frame> </image_frame>

BIN
themes/Pear/up.png Executable file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

View File

@ -12,7 +12,7 @@ class LabelList(clutter.Group):
#Default font #Default font
font_string = "Tahoma 30" font_string = "Tahoma 30"
item_gap = 0 item_height_percent = 1.00
width = 0 width = 0
def __init__(self, length): def __init__(self, length):
@ -29,22 +29,28 @@ class LabelList(clutter.Group):
self.displayMax = length self.displayMax = length
self.displaySize = self.displayMax - self.displayMin self.displaySize = self.displayMax - self.displayMin
self.item_group = clutter.Group()
self.item_group.show()
self.inactive_item_background = None self.inactive_item_background = None
self.background_group = clutter.Group() self.background_group = clutter.Group()
self.background_group.show() self.background_group.show()
self.add(self.background_group) self.add(self.background_group)
self.image_down = None
self.image_up = None
#Selector bar image, moves with selections to show current item #Selector bar image, moves with selections to show current item
self.selector_bar = None self.selector_bar = None
def setup_from_theme_id(self, themeMgr, id): def setup_from_theme_id(self, themeMgr, id):
element = themeMgr.search_docs("label_list", id).childNodes element = themeMgr.search_docs("label_list", id).childNodes
img_element = themeMgr.search_docs("label_list", id).getElementsByTagName("texture")
#Quick check to make sure we found something #Quick check to make sure we found something
if element is None: if element is None:
return None return None
self.item_gap = int(themeMgr.find_child_value(element, "item_gap")) self.item_height_percent = float(themeMgr.find_child_value(element, "item_height_percent"))
self.displayMax = int(themeMgr.find_child_value(element, "num_visible_elements"))
#Grab the font #Grab the font
font_node = themeMgr.get_subnode(element, "font") font_node = themeMgr.get_subnode(element, "font")
@ -62,18 +68,37 @@ class LabelList(clutter.Group):
self.fps = int(themeMgr.find_child_value(element, "transition_fps")) self.fps = int(themeMgr.find_child_value(element, "transition_fps"))
self.frames = int(themeMgr.find_child_value(element, "transition_frames")) self.frames = int(themeMgr.find_child_value(element, "transition_frames"))
themeMgr.setup_actor(self, element, themeMgr.stage) themeMgr.setup_actor(self, element, themeMgr.stage)
(self.width, self.height) = themeMgr.get_dimensions(element, themeMgr.stage) (self.width, self.height) = themeMgr.get_dimensions(element, themeMgr.stage)
print "Label List width: %s" % self.get_width() #Set the up/down images
#This assumes images go in the bottom right corner, will add flexibility later
img_element_up = themeMgr.find_element(img_element, "id", "image_up")
img_element_down = themeMgr.find_element(img_element, "id", "image_down")
if not img_element_up is None:
img_element_up = img_element_up.childNodes
self.image_up = themeMgr.get_texture("image_up", self, element = img_element_up)
self.image_up.set_opacity(180)
self.image_up.set_position( self.width-self.image_up.get_width(), self.height+1)
self.image_up.show()
self.add(self.image_up)
if not img_element_down is None:
img_element_down = img_element_down.childNodes
self.image_down = themeMgr.get_texture("image_up", self, element = img_element_down)
self.image_down.set_opacity(180)
self.image_down.set_position( self.width-self.image_down.get_width()-self.image_up.get_width(), self.height+1)
self.image_down.show()
self.add(self.image_down)
img_element = themeMgr.search_docs("label_list", id).getElementsByTagName("texture")
img_element = themeMgr.find_element(img_element, "id", "inactive_background") self.item_group.set_clip(0, 0, self.width, self.height)
if not img_element is None: self.background_group.set_clip(0, 0, self.width, self.height)
img_element = img_element.childNodes
self.inactive_item_background = themeMgr.get_texture("inactive_background", self, element = img_element) #Get the item background img
img_element_item = themeMgr.find_element(img_element, "id", "inactive_background")
if not img_element_item is None:
img_element_item = img_element_item.childNodes
self.inactive_item_background = themeMgr.get_texture("inactive_background", self, element = img_element_item)
def on_key_press_event (self, event): def on_key_press_event (self, event):
self.input_queue.input(event) self.input_queue.input(event)
@ -87,32 +112,42 @@ class LabelList(clutter.Group):
tempLabel.set_text("S") tempLabel.set_text("S")
self.label_height = tempLabel.get_height() self.label_height = tempLabel.get_height()
self.item_height = int(self.label_height * self.item_height_percent)
self.displayMax = self.height / self.label_height
label_width = 0 label_width = 0
label_y = len(self.items) * (self.label_height + self.item_gap) #This has to go hear for layering purposes
if self.item_group.get_parent() is None:
self.add(self.item_group)
item_y = len(self.items) * self.item_height
label_y = item_y + ((self.item_height - self.label_height)/2)
label_y = int(label_y)
#If a background pic is specified in the theme, clone it and add #If a background pic is specified in the theme, clone it and add
if not self.inactive_item_background is None: if not self.inactive_item_background is None:
bg_img = clutter.CloneTexture(self.inactive_item_background) bg_img = clutter.CloneTexture(self.inactive_item_background)
bg_img.set_height(self.label_height) bg_img.set_height(self.item_height)
bg_img.set_width(self.width) bg_img.set_width(self.width)
bg_img.set_position(0, label_y) bg_img.set_position(0, item_y)
bg_img.show()
self.background_group.add(bg_img) self.background_group.add(bg_img)
newItem = ListItem(self.font_string, itemLabel, label_list = self, max_width = self.width) newItem = ListItem(self.font_string, itemLabel, label_list = self, max_width = self.width)
newItem.set_position(0, label_y) newItem.set_position(0, label_y)
if len(self.items) < self.displaySize:
newItem.show() newItem.show()
if not self.image_down is None: self.image_down.set_opacity(255)
if not self.inactive_item_background is None: bg_img.show()
self.items.append(newItem) self.items.append(newItem)
self.add(newItem) self.item_group.add(newItem)
return newItem return newItem
#Removes all items from the list #Removes all items from the list
def clear(self): def clear(self):
for item in self.items: for item in self.items:
self.remove(item) self.item_group.remove(item)
item = None item = None
self.items = [] self.items = []
self.selected = 0 self.selected = 0
@ -121,7 +156,7 @@ class LabelList(clutter.Group):
def display(self): def display(self):
if self.displayMax > len(self.items): if self.displayMax > len(self.items):
self.displayMax = len(self.items) self.displayMax = len(self.items)
self.displaySize = self.displayMax - self.displayMin #self.displaySize = self.displayMax - self.displayMin
#for i in range(self.displaySize): #for i in range(self.displaySize):
# self.menuItems[i].show() # self.menuItems[i].show()
@ -249,14 +284,14 @@ class LabelList(clutter.Group):
(group_x, new_y )\ (group_x, new_y )\
) )
alpha = clutter.Alpha(timeline, clutter.ramp_inc_func) alpha = clutter.Alpha(timeline, clutter.ramp_inc_func)
self.behaviour1 = clutter.BehaviourPath(alpha, knots) self.behaviour_path = clutter.BehaviourPath(alpha, knots)
self.behaviour2 = clutter.BehaviourOpacity(opacity_start=outgoingMenuItem.get_opacity(), opacity_end=0, alpha=alpha) self.behaviour_opacity = clutter.BehaviourOpacity(opacity_start=outgoingMenuItem.get_opacity(), opacity_end=0, alpha=alpha)
#print "Going to: "+ str(new_y) #print "Going to: "+ str(new_y)
#print behaviour1.get_knots() #print behaviour1.get_knots()
self.behaviour1.apply(self) self.behaviour_path.apply(self.item_group)
self.behaviour2.apply(outgoingMenuItem) self.behaviour_opacity.apply(outgoingMenuItem)
import gobject import gobject
class ListItem(clutter.Group): class ListItem(clutter.Group):