- Further theme work (This time on the modeuls)
- Setup transition mechanism for menu_item_textures
This commit is contained in:
parent
98f88f34d8
commit
9535006ac1
11
GlossMgr.py
11
GlossMgr.py
|
@ -15,12 +15,13 @@ class GlossMgr:
|
||||||
self.currentMenu = None
|
self.currentMenu = None
|
||||||
self.uiMsg = message(stage)
|
self.uiMsg = message(stage)
|
||||||
|
|
||||||
|
self.themeMgr = ThemeMgr(self)
|
||||||
|
|
||||||
#Setup the menu transition
|
#Setup the menu transition
|
||||||
self.transition = "slide"
|
self.transition = "slide"
|
||||||
transition_path = "transitions/menus/" + self.transition
|
transition_path = "transitions/menus/" + self.transition
|
||||||
self.transition = __import__(transition_path).Transition(self)
|
self.transition = __import__(transition_path).Transition(self)
|
||||||
|
|
||||||
self.themeMgr = ThemeMgr(self.stage)
|
|
||||||
background = self.themeMgr.get_texture("background", None, None)
|
background = self.themeMgr.get_texture("background", None, None)
|
||||||
#background.set_depth(-500)
|
#background.set_depth(-500)
|
||||||
#background.set_scale(1, 1)
|
#background.set_scale(1, 1)
|
||||||
|
@ -33,7 +34,7 @@ class GlossMgr:
|
||||||
|
|
||||||
self.selector_bar = MenuSelector(self)
|
self.selector_bar = MenuSelector(self)
|
||||||
self.stage.add(self.selector_bar)#Load the theme manager
|
self.stage.add(self.selector_bar)#Load the theme manager
|
||||||
self.themeMgr = ThemeMgr(self.stage)
|
#self.themeMgr = ThemeMgr(self.stage)
|
||||||
|
|
||||||
self.selector_bar.show_all()
|
self.selector_bar.show_all()
|
||||||
self.currentPlugin = None
|
self.currentPlugin = None
|
||||||
|
@ -78,6 +79,7 @@ class GlossMgr:
|
||||||
if event.keyval == clutter.keysyms.Down: #Down button pressed
|
if event.keyval == clutter.keysyms.Down: #Down button pressed
|
||||||
self.currentMenu.selectNext()
|
self.currentMenu.selectNext()
|
||||||
if event.keyval == clutter.keysyms.q:
|
if event.keyval == clutter.keysyms.q:
|
||||||
|
self.stage.hide_cursor()
|
||||||
clutter.main_quit()
|
clutter.main_quit()
|
||||||
if event.keyval == clutter.keysyms.Return:
|
if event.keyval == clutter.keysyms.Return:
|
||||||
# Need to decide what action to take
|
# Need to decide what action to take
|
||||||
|
@ -94,6 +96,10 @@ class GlossMgr:
|
||||||
if action is None:
|
if action is None:
|
||||||
self.display_msg("Error", "Could not start " + self.currentMenu.get_current_item().get_text())
|
self.display_msg("Error", "Could not start " + self.currentMenu.get_current_item().get_text())
|
||||||
else:
|
else:
|
||||||
|
#hide any unnecesary actors
|
||||||
|
self.currentMenu.hide()
|
||||||
|
|
||||||
|
#And begin the plugin
|
||||||
action.begin( self )
|
action.begin( self )
|
||||||
# This is tres bodge
|
# This is tres bodge
|
||||||
if event.keyval == clutter.keysyms.Escape:
|
if event.keyval == clutter.keysyms.Escape:
|
||||||
|
@ -103,6 +109,7 @@ class GlossMgr:
|
||||||
if self.currentPlugin.on_key_press_event(stage, event):
|
if self.currentPlugin.on_key_press_event(stage, event):
|
||||||
self.currentPlugin.stop()
|
self.currentPlugin.stop()
|
||||||
self.currentPlugin = None
|
self.currentPlugin = None
|
||||||
|
self.currentMenu.show()
|
||||||
#If there's no plugin running, go back one in the menu list (Providing we're not already at the first item.
|
#If there's no plugin running, go back one in the menu list (Providing we're not already at the first item.
|
||||||
else:
|
else:
|
||||||
if len(self.menuHistory)>1:
|
if len(self.menuHistory)>1:
|
||||||
|
|
24
Menu.py
24
Menu.py
|
@ -7,6 +7,7 @@ from ReflectionTexture import Texture_Reflection
|
||||||
|
|
||||||
class Menu(clutter.Group):
|
class Menu(clutter.Group):
|
||||||
font = ""
|
font = ""
|
||||||
|
menu_item_transition = None
|
||||||
zoomLevel = 0.5
|
zoomLevel = 0.5
|
||||||
opacityStep = 120
|
opacityStep = 120
|
||||||
|
|
||||||
|
@ -135,6 +136,13 @@ class Menu(clutter.Group):
|
||||||
else:
|
else:
|
||||||
self.menuItems[i].scaleLabel(2, self.timeline)
|
self.menuItems[i].scaleLabel(2, self.timeline)
|
||||||
|
|
||||||
|
#Do the transition of the menu graphic
|
||||||
|
#If there's no transition set (Would have been set in the theme) then the item is simply show
|
||||||
|
if not self.menu_item_transition is None:
|
||||||
|
self.menu_item_transition.forward(self.timeline, self.menuItems[self.selected-1].itemTexturesGroup, self.menuItems[self.selected].itemTexturesGroup)
|
||||||
|
else:
|
||||||
|
self.menuItems[self.selected].itemTexturesGroup.show()
|
||||||
|
|
||||||
#Check we're at the bottom of the viewable list
|
#Check we're at the bottom of the viewable list
|
||||||
if self.selected >= (self.displayMax):
|
if self.selected >= (self.displayMax):
|
||||||
#If yes, move the menu, leave the selection bar where is
|
#If yes, move the menu, leave the selection bar where is
|
||||||
|
@ -183,6 +191,13 @@ class Menu(clutter.Group):
|
||||||
else:
|
else:
|
||||||
self.menuItems[i].scaleLabel(2, self.timeline)
|
self.menuItems[i].scaleLabel(2, self.timeline)
|
||||||
|
|
||||||
|
#Do the transition of the menu graphic
|
||||||
|
#If there's no transition set (Would have been set in the theme) then the item is simply show
|
||||||
|
if not self.menu_item_transition is None:
|
||||||
|
self.menu_item_transition.backward(self.timeline, self.menuItems[self.selected+1].itemTexturesGroup, self.menuItems[self.selected].itemTexturesGroup)
|
||||||
|
else:
|
||||||
|
self.menuItems[self.selected].itemTexturesGroup.show()
|
||||||
|
|
||||||
#Check we're at the top of the viewable list
|
#Check we're at the top of the viewable list
|
||||||
if self.selected < (self.displayMin):
|
if self.selected < (self.displayMin):
|
||||||
#If yes, move the menu, leave the selection bar where is
|
#If yes, move the menu, leave the selection bar where is
|
||||||
|
@ -221,6 +236,9 @@ class Menu(clutter.Group):
|
||||||
else:
|
else:
|
||||||
self.menuItems[i].scaleLabel(2, self.timeline)
|
self.menuItems[i].scaleLabel(2, self.timeline)
|
||||||
|
|
||||||
|
#Show the current menu item's graphic
|
||||||
|
self.menuItems[self.selected].itemTexturesGroup.show()
|
||||||
|
|
||||||
if moveBar:
|
if moveBar:
|
||||||
self.glossMgr.get_selector_bar().selectItem(self.menuItems[self.selected], self.timeline)
|
self.glossMgr.get_selector_bar().selectItem(self.menuItems[self.selected], self.timeline)
|
||||||
|
|
||||||
|
@ -320,9 +338,11 @@ class ListItem (clutter.Label):
|
||||||
#Determine the zooming level
|
#Determine the zooming level
|
||||||
zoomTo=0
|
zoomTo=0
|
||||||
opacityTo = 255
|
opacityTo = 255
|
||||||
|
|
||||||
if level==0:
|
if level==0:
|
||||||
zoomTo = self.menu.zoomStep0 #self.zoomLevel * 1.5
|
zoomTo = self.menu.zoomStep0 #self.zoomLevel * 1.5
|
||||||
opacityTo = self.menu.opacityStep0
|
opacityTo = self.menu.opacityStep0
|
||||||
|
self.itemTexturesGroup.hide()
|
||||||
self.menu.add(self.itemTexturesGroup)
|
self.menu.add(self.itemTexturesGroup)
|
||||||
self.onStage = True
|
self.onStage = True
|
||||||
#self.itemTexturesGroup.show_all()
|
#self.itemTexturesGroup.show_all()
|
||||||
|
@ -330,14 +350,14 @@ class ListItem (clutter.Label):
|
||||||
zoomTo = self.menu.zoomStep1
|
zoomTo = self.menu.zoomStep1
|
||||||
opacityTo = self.menu.opacityStep1
|
opacityTo = self.menu.opacityStep1
|
||||||
if self.onStage:
|
if self.onStage:
|
||||||
self.menu.remove(self.itemTexturesGroup)
|
#self.menu.remove(self.itemTexturesGroup)
|
||||||
self.onStage = False
|
self.onStage = False
|
||||||
#self.itemTexturesGroup.hide_all()
|
#self.itemTexturesGroup.hide_all()
|
||||||
if level==2:
|
if level==2:
|
||||||
zoomTo = self.menu.zoomStep2
|
zoomTo = self.menu.zoomStep2
|
||||||
opacityTo = self.menu.opacityStep2
|
opacityTo = self.menu.opacityStep2
|
||||||
if self.onStage:
|
if self.onStage:
|
||||||
self.menu.remove(self.itemTexturesGroup)
|
#self.menu.remove(self.itemTexturesGroup)
|
||||||
self.onStage = False
|
self.onStage = False
|
||||||
#self.itemTexturesGroup.hide_all()
|
#self.itemTexturesGroup.hide_all()
|
||||||
|
|
||||||
|
|
4
gloss.py
4
gloss.py
|
@ -70,10 +70,10 @@ class MainApp:
|
||||||
|
|
||||||
#Update splash status msg
|
#Update splash status msg
|
||||||
for mods in modules:
|
for mods in modules:
|
||||||
print "Loading mod..."
|
#print "Loading mod..."
|
||||||
tempMod = mods.Module(self.glossMgr, self.dbMgr)
|
tempMod = mods.Module(self.glossMgr, self.dbMgr)
|
||||||
title = tempMod.title
|
title = tempMod.title
|
||||||
print title
|
#print title
|
||||||
self.splashScreen.set_msg("Loading "+title)
|
self.splashScreen.set_msg("Loading "+title)
|
||||||
temp_menu_item = MainMenu.addItem(title)
|
temp_menu_item = MainMenu.addItem(title)
|
||||||
temp_menu_item.add_image_from_texture(tempMod.menu_image)
|
temp_menu_item.add_image_from_texture(tempMod.menu_image)
|
||||||
|
|
|
@ -40,6 +40,7 @@ class coverViewer(clutter.Group):
|
||||||
self.bgImg.set_pixbuf(pixbuf)
|
self.bgImg.set_pixbuf(pixbuf)
|
||||||
bgImg_height = height - ((height - (self.cover_size * rows)) / 2) + self.detailBox_height
|
bgImg_height = height - ((height - (self.cover_size * rows)) / 2) + self.detailBox_height
|
||||||
self.bgImg.set_size(width, bgImg_height)
|
self.bgImg.set_size(width, bgImg_height)
|
||||||
|
#self.bgImg.set_depth(1)
|
||||||
self.bgImg.show()
|
self.bgImg.show()
|
||||||
self.add(self.bgImg)
|
self.add(self.bgImg)
|
||||||
|
|
||||||
|
@ -54,6 +55,7 @@ class coverViewer(clutter.Group):
|
||||||
covers_x = int(width * (1-self.covers_size_percent)/2)
|
covers_x = int(width * (1-self.covers_size_percent)/2)
|
||||||
covers_y = int(height * (1-self.covers_size_percent)/2)
|
covers_y = int(height * (1-self.covers_size_percent)/2)
|
||||||
self.covers_group.set_position(covers_x, covers_y)
|
self.covers_group.set_position(covers_x, covers_y)
|
||||||
|
#self.covers_group.set_depth(1) #self.cover_size)
|
||||||
self.covers_group.show()
|
self.covers_group.show()
|
||||||
|
|
||||||
#self.stage.add(self.current_video_description)
|
#self.stage.add(self.current_video_description)
|
||||||
|
@ -140,7 +142,7 @@ class coverViewer(clutter.Group):
|
||||||
self.behaviourNew_opacity = clutter.BehaviourOpacity(opacity_start=self.inactiveOpacity, opacity_end=255, alpha=alpha)
|
self.behaviourNew_opacity = clutter.BehaviourOpacity(opacity_start=self.inactiveOpacity, opacity_end=255, alpha=alpha)
|
||||||
|
|
||||||
self.behaviourOld_scale = clutter.BehaviourScale(scale_start=self.scaleFactor, scale_end=1, alpha=alpha)
|
self.behaviourOld_scale = clutter.BehaviourScale(scale_start=self.scaleFactor, scale_end=1, alpha=alpha)
|
||||||
self.behaviourOld_scale.set_property("scale=gravity", clutter.GRAVITY_CENTER)
|
#self.behaviourOld_scale.set_property("scale=gravity", clutter.GRAVITY_CENTER)
|
||||||
self.behaviourOld_z = clutter.BehaviourDepth(depth_start=2, depth_end=1, alpha=alpha)
|
self.behaviourOld_z = clutter.BehaviourDepth(depth_start=2, depth_end=1, alpha=alpha)
|
||||||
self.behaviourOld_opacity = clutter.BehaviourOpacity(opacity_start=255, opacity_end=self.inactiveOpacity, alpha=alpha)
|
self.behaviourOld_opacity = clutter.BehaviourOpacity(opacity_start=255, opacity_end=self.inactiveOpacity, alpha=alpha)
|
||||||
|
|
||||||
|
@ -151,6 +153,20 @@ class coverViewer(clutter.Group):
|
||||||
self.behaviourOld_z.apply(outgoingTexture)
|
self.behaviourOld_z.apply(outgoingTexture)
|
||||||
self.behaviourOld_opacity.apply(outgoingTexture)
|
self.behaviourOld_opacity.apply(outgoingTexture)
|
||||||
|
|
||||||
|
#Set gravities
|
||||||
|
"""
|
||||||
|
(x, y) = incomingTexture.get_position()
|
||||||
|
anchor_x = x + incomingTexture.get_width()/2
|
||||||
|
anchor_y = y + incomingTexture.get_height()/2
|
||||||
|
incomingTexture.set_anchor_point(anchor_x, anchor_y)
|
||||||
|
(x, y) = outgoingTexture.get_position()
|
||||||
|
anchor_x = x + outgoingTexture.get_width()/2
|
||||||
|
anchor_y = y + outgoingTexture.get_height()/2
|
||||||
|
outgoingTexture.set_anchor_point(anchor_x, anchor_y)
|
||||||
|
#incomingTexture.set_anchor_point_from_gravity(clutter.GRAVITY_CENTER)
|
||||||
|
#outgoingTexture.set_anchor_point_from_gravity(clutter.GRAVITY_CENTER)
|
||||||
|
"""
|
||||||
|
|
||||||
self.currentSelection = incomingItem
|
self.currentSelection = incomingItem
|
||||||
|
|
||||||
self.timeline.start()
|
self.timeline.start()
|
||||||
|
|
|
@ -102,8 +102,9 @@ class folderMenu(clutter.Group):
|
||||||
|
|
||||||
self.behaviour_opacity_outgoing.apply(current_viewer)
|
self.behaviour_opacity_outgoing.apply(current_viewer)
|
||||||
for cover in current_viewer.get_item_library():
|
for cover in current_viewer.get_item_library():
|
||||||
#cover.set_depth(cover.get_height())
|
#cover.set_depth(cover.get_height()/2)
|
||||||
self.behaviour_rotate_outgoing.apply(cover)
|
self.behaviour_rotate_outgoing.apply(cover)
|
||||||
|
#pass
|
||||||
|
|
||||||
|
|
||||||
#Apply the incoming behaviour
|
#Apply the incoming behaviour
|
||||||
|
|
|
@ -190,6 +190,8 @@ class Module():
|
||||||
|
|
||||||
#Create a backdrop for the player. In this case we just use the same background as the menus
|
#Create a backdrop for the player. In this case we just use the same background as the menus
|
||||||
self.backdrop = glossMgr.get_themeMgr().get_texture("background", None, None) #clutter.CloneTexture(glossMgr.get_skinMgr().get_Background())
|
self.backdrop = glossMgr.get_themeMgr().get_texture("background", None, None) #clutter.CloneTexture(glossMgr.get_skinMgr().get_Background())
|
||||||
|
#self.backdrop = clutter.Rectangle()
|
||||||
|
#self.backdrop.set_color(clutter.color_parse('Black'))
|
||||||
self.backdrop.set_size(self.stage.get_width(), self.stage.get_height())
|
self.backdrop.set_size(self.stage.get_width(), self.stage.get_height())
|
||||||
self.backdrop.set_opacity(0)
|
self.backdrop.set_opacity(0)
|
||||||
self.backdrop.show()
|
self.backdrop.show()
|
||||||
|
|
14
themeMgr.py
14
themeMgr.py
|
@ -8,8 +8,9 @@ class ThemeMgr:
|
||||||
defaultTheme = "default"
|
defaultTheme = "default"
|
||||||
currentTheme = "default"
|
currentTheme = "default"
|
||||||
|
|
||||||
def __init__(self, stage):
|
def __init__(self, glossMgr):
|
||||||
self.stage = stage
|
self.stage = glossMgr.stage
|
||||||
|
self.glossMgr = glossMgr
|
||||||
self.docs = []
|
self.docs = []
|
||||||
self.default_docs = []
|
self.default_docs = []
|
||||||
|
|
||||||
|
@ -296,5 +297,14 @@ class ThemeMgr:
|
||||||
menu.opacityStep1 = int(self.find_child_value(element, "opacity_step1"))
|
menu.opacityStep1 = int(self.find_child_value(element, "opacity_step1"))
|
||||||
menu.opacityStep2 = int(self.find_child_value(element, "opacity_step2"))
|
menu.opacityStep2 = int(self.find_child_value(element, "opacity_step2"))
|
||||||
|
|
||||||
|
#Setup the menu transition
|
||||||
|
image_transition = "fade"
|
||||||
|
transition_path = "transitions/menu_items/" + image_transition
|
||||||
|
try:
|
||||||
|
menu.menu_item_transition = __import__(transition_path).Transition(self.glossMgr)
|
||||||
|
except ImportError:
|
||||||
|
print "Theme Error: No menu_item transition titled '" + str(image_transition) + "'"
|
||||||
|
menu.menu_item_transition = None
|
||||||
|
|
||||||
#Finally set general actor properties (position etc)
|
#Finally set general actor properties (position etc)
|
||||||
self.setup_actor(menu.getItemGroup(), element, self.stage)
|
self.setup_actor(menu.getItemGroup(), element, self.stage)
|
|
@ -0,0 +1,35 @@
|
||||||
|
import clutter
|
||||||
|
|
||||||
|
class Transition:
|
||||||
|
|
||||||
|
def __init__(self, GlossMgr):
|
||||||
|
self.stage = GlossMgr.stage
|
||||||
|
self.glossMgr = GlossMgr
|
||||||
|
|
||||||
|
def forward(self, timeline, oldGroup, newGroup):
|
||||||
|
self.do_transition(timeline, oldGroup, newGroup)
|
||||||
|
newGroup.show()
|
||||||
|
|
||||||
|
def backward(self, timeline, oldGroup, newGroup):
|
||||||
|
self.do_transition(timeline, oldGroup, newGroup)
|
||||||
|
newGroup.show()
|
||||||
|
|
||||||
|
def do_transition(self, timeline, oldGroup, newGroup):
|
||||||
|
timeline.connect('completed', self.on_transition_complete, oldGroup)
|
||||||
|
|
||||||
|
newGroup.set_opacity(0)
|
||||||
|
(x, y) = oldGroup.get_position()
|
||||||
|
newGroup.set_position(x, y)
|
||||||
|
|
||||||
|
#self.exit_behaviour_scale = clutter.BehaviourScale(self.alpha, 1, 0.5, clutter.GRAVITY_CENTER)
|
||||||
|
self.alpha = clutter.Alpha(timeline, clutter.ramp_inc_func)
|
||||||
|
self.new_behaviour_opacity = clutter.BehaviourOpacity(opacity_start=0, opacity_end=oldGroup.get_opacity(), alpha=self.alpha)
|
||||||
|
self.old_behaviour_opacity = clutter.BehaviourOpacity(opacity_start=oldGroup.get_opacity(), opacity_end=0, alpha=self.alpha)
|
||||||
|
|
||||||
|
#self.exit_behaviour_scale.apply(oldGroup)
|
||||||
|
self.new_behaviour_opacity.apply(newGroup)
|
||||||
|
self.old_behaviour_opacity.apply(oldGroup)
|
||||||
|
|
||||||
|
def on_transition_complete(self, data, oldGroup):
|
||||||
|
oldGroup.get_parent().remove(oldGroup)
|
||||||
|
pass
|
|
@ -0,0 +1,13 @@
|
||||||
|
<gloss-theme>
|
||||||
|
<texture id="dvd_menu_image">
|
||||||
|
<image>dvd/dvd.png</image>
|
||||||
|
<dimensions type="relativeToStage">
|
||||||
|
<width>30%</width>
|
||||||
|
<height>30%</height>
|
||||||
|
</dimensions>
|
||||||
|
<position type="relativeToParent">
|
||||||
|
<x>0</x>
|
||||||
|
<y>0</y>
|
||||||
|
</position>
|
||||||
|
</texture>
|
||||||
|
</gloss-theme>
|
Binary file not shown.
After Width: | Height: | Size: 150 KiB |
|
@ -20,6 +20,7 @@
|
||||||
<item_gap>0</item_gap>
|
<item_gap>0</item_gap>
|
||||||
<num_visible_elements>6</num_visible_elements>
|
<num_visible_elements>6</num_visible_elements>
|
||||||
<use_image_reflections>True</use_image_reflections>
|
<use_image_reflections>True</use_image_reflections>
|
||||||
|
<image_transition>fade</image_transition>
|
||||||
|
|
||||||
<!-- 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 -->
|
||||||
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
<gloss-theme>
|
||||||
|
<texture id="music_menu_image">
|
||||||
|
<image>music/music.png</image>
|
||||||
|
<dimensions type="relativeToStage">
|
||||||
|
<width>30%</width>
|
||||||
|
<height>30%</height>
|
||||||
|
</dimensions>
|
||||||
|
<position type="relativeToParent">
|
||||||
|
<x>0</x>
|
||||||
|
<y>0</y>
|
||||||
|
</position>
|
||||||
|
</texture>
|
||||||
|
</gloss-theme>
|
Binary file not shown.
After Width: | Height: | Size: 71 KiB |
|
@ -0,0 +1,13 @@
|
||||||
|
<gloss-theme>
|
||||||
|
<texture id="slideshow_menu_image">
|
||||||
|
<image>slideshow/gallery.png</image>
|
||||||
|
<dimensions type="relativeToStage">
|
||||||
|
<width>30%</width>
|
||||||
|
<height>30%</height>
|
||||||
|
</dimensions>
|
||||||
|
<position type="relativeToParent">
|
||||||
|
<x>0</x>
|
||||||
|
<y>0</y>
|
||||||
|
</position>
|
||||||
|
</texture>
|
||||||
|
</gloss-theme>
|
Binary file not shown.
After Width: | Height: | Size: 147 KiB |
|
@ -0,0 +1,13 @@
|
||||||
|
<gloss-theme>
|
||||||
|
<texture id="mythtv_menu_image">
|
||||||
|
<image>tv/gallery.png</image>
|
||||||
|
<dimensions type="relativeToStage">
|
||||||
|
<width>30%</width>
|
||||||
|
<height>30%</height>
|
||||||
|
</dimensions>
|
||||||
|
<position type="relativeToParent">
|
||||||
|
<x>0</x>
|
||||||
|
<y>0</y>
|
||||||
|
</position>
|
||||||
|
</texture>
|
||||||
|
</gloss-theme>
|
Binary file not shown.
After Width: | Height: | Size: 147 KiB |
Binary file not shown.
After Width: | Height: | Size: 71 KiB |
Loading…
Reference in New Issue