aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-01-05 20:28:04 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-01-05 20:28:04 +0000
commita7bc9fd319677465f0561773401ff0390ae3af9c (patch)
tree974cb834a2ffc42a6cb70b5411161adff15b570c
parenteef9f3c2100087c15e1a007194f556aea4d3905e (diff)
downloadenigma2-a7bc9fd319677465f0561773401ff0390ae3af9c.tar.gz
enigma2-a7bc9fd319677465f0561773401ff0390ae3af9c.zip
add radio player
TODO: change layout in skin.xml (ChannelSelectionRadio ... add nice pixmap ? ! ?) TODO: add infobar infos (now/next starttime, title, duration to player) TODO: add nice background pic ? ! ?
-rw-r--r--data/keymap.xml13
-rw-r--r--data/skin.xml7
-rw-r--r--lib/python/Screens/ChannelSelection.py151
-rw-r--r--lib/python/Screens/InfoBar.py11
4 files changed, 160 insertions, 22 deletions
diff --git a/data/keymap.xml b/data/keymap.xml
index 46e80c09..24c36a8f 100644
--- a/data/keymap.xml
+++ b/data/keymap.xml
@@ -97,6 +97,7 @@
<map context="InfobarActions">
<key id="KEY_VIDEO" mapto="showMovies" flags="m" />
+ <key id="KEY_RADIO" mapto="showRadio" flags="m" />
</map>
<map context="InfobarAudioSelectionActions">
@@ -199,6 +200,15 @@
<key id="KEY_0" mapto="0" flags="m" />
</map>
+ <map context="ContextMenuActions">
+ <key id="KEY_MENU" mapto="contextMenu" flags="m" />
+ </map>
+
+ <map context="TvRadioActions">
+ <key id="KEY_TV" mapto="keyTV" flags="m" />
+ <key id="KEY_RADIO" mapto="keyRadio" flags="m" />
+ </map>
+
<map context="EPGSelectActions">
<key id="KEY_GREEN" mapto="timerAdd" flags="m" />
<key id="KEY_YELLOW" mapto="yellow" flags="m" />
@@ -256,7 +266,4 @@
<map context="StandbyActions">
<key id="KEY_POWER" mapto="power" flags="m" />
</map>
- <map context="ContextMenuActions">
- <key id="KEY_MENU" mapto="contextMenu" flags="m" />
- </map>
</keymap>
diff --git a/data/skin.xml b/data/skin.xml
index 95ff48eb..9ce0bb7c 100644
--- a/data/skin.xml
+++ b/data/skin.xml
@@ -234,6 +234,13 @@
<widget name="key_yellow" position="280,0" size="140,40" backgroundColor="yellow" font="Regular;21" />
<widget name="key_blue" position="420,0" size="140,40" backgroundColor="blue" font="Regular;21" />
</screen>
+ <screen name="ChannelSelectionRadio" position="90,98" size="560,417" title="Channel Selection">
+ <widget name="list" position="00,45" size="560,304" scrollbarMode="showOnDemand" />
+ <widget name="key_red" position="0,0" size="140,40" backgroundColor="red" font="Regular;21" />
+ <widget name="key_green" position="140,0" size="140,40" backgroundColor="green" font="Regular;21" />
+ <widget name="key_yellow" position="280,0" size="140,40" backgroundColor="yellow" font="Regular;21" />
+ <widget name="key_blue" position="420,0" size="140,40" backgroundColor="blue" font="Regular;21" />
+ </screen>
<screen name="SimpleChannelSelection" position="90,98" size="560,417" title="Channel Selection">
<widget name="list" position="00,45" size="560,364" scrollbarMode="showOnDemand" />
<widget name="key_red" position="0,0" size="140,40" backgroundColor="red" font="Regular;21" />
diff --git a/lib/python/Screens/ChannelSelection.py b/lib/python/Screens/ChannelSelection.py
index adc68945..cad99616 100644
--- a/lib/python/Screens/ChannelSelection.py
+++ b/lib/python/Screens/ChannelSelection.py
@@ -235,19 +235,16 @@ class ChannelSelectionEdit:
USE_MULTIBOUQUETS = False
+MODE_TV = 0
+MODE_RADIO = 1
+
class ChannelSelectionBase(Screen):
def __init__(self, session):
Screen.__init__(self, session)
# this makes it much simple to implement a selectable radio or tv mode :)
self.service_types_tv = '1:7:1:0:0:0:0:0:0:0:(type == 1) || (type == 17)'
-# self.service_types_radio = '1:7:1:0:0:0:0:0:0:0:(type == 2)'
-
- self.service_types = self.service_types_tv
- if USE_MULTIBOUQUETS:
- self.bouquet_root = eServiceReference('1:7:1:0:0:0:0:0:0:0:(type == 1) FROM BOUQUET "bouquets.tv" ORDER BY bouquet')
- else:
- self.bouquet_root = eServiceReference('%s FROM BOUQUET "userbouquet.favourites.tv" ORDER BY bouquet'%(self.service_types))
+ self.service_types_radio = '1:7:1:0:0:0:0:0:0:0:(type == 2)'
self["key_red"] = Button(_("All"))
self["key_green"] = Button(_("Satellites"))
@@ -257,8 +254,6 @@ class ChannelSelectionBase(Screen):
self["list"] = ServiceList()
self.servicelist = self["list"]
- #self["okbutton"] = Button("ok", [self.channelSelected])
-
self.numericalTextInput = NumericalTextInput()
def appendDVBTypes(self, ref):
@@ -293,6 +288,34 @@ class ChannelSelectionBase(Screen):
offsetCount += 1
return offsetCount
+ def setTvMode(self):
+ self.service_types = self.service_types_tv
+ if USE_MULTIBOUQUETS:
+ self.bouquet_root = eServiceReference('1:7:1:0:0:0:0:0:0:0:(type == 1) FROM BOUQUET "bouquets.tv" ORDER BY bouquet')
+ else:
+ self.bouquet_root = eServiceReference('%s FROM BOUQUET "userbouquet.favourites.tv" ORDER BY bouquet'%(self.service_types))
+ title = self.instance.getTitle()
+ pos = title.find(" (")
+ if pos != -1:
+ title = title[:pos]
+ title += " (TV)"
+ self.instance.setTitle(title)
+ self.mode = MODE_TV
+
+ def setRadioMode(self):
+ self.service_types = self.service_types_radio
+ if USE_MULTIBOUQUETS:
+ self.bouquet_root = eServiceReference('1:7:1:0:0:0:0:0:0:0:(type == 1) FROM BOUQUET "bouquets.radio" ORDER BY bouquet')
+ else:
+ self.bouquet_root = eServiceReference('%s FROM BOUQUET "userbouquet.favourites.radio" ORDER BY bouquet'%(self.service_types))
+ title = self.instance.getTitle()
+ pos = title.find(" (")
+ if pos != -1:
+ title = title[:pos]
+ title += " (Radio)"
+ self.instance.setTitle(title)
+ self.mode = MODE_RADIO
+
def setRootBase(self, root, justSet=False):
path = root.getPath()
inBouquetRootList = path.find('FROM BOUQUET "bouquets.') != -1 #FIXME HACK
@@ -441,22 +464,23 @@ class ChannelSelection(ChannelSelectionBase, ChannelSelectionEdit):
self["actions"].csel = self
self.onShown.append(self.onShow)
-# self.onLayoutFinish.append(self.onCreate)
self.lastChannelRootTimer = eTimer()
self.lastChannelRootTimer.timeout.get().append(self.onCreate)
self.lastChannelRootTimer.start(100,True)
def onCreate(self):
+ self.setTvMode()
lastroot=eServiceReference(config.tv.lastroot.value)
if lastroot.valid():
self.setRoot(lastroot)
else:
self.showFavourites()
self.saveRoot(self.getRoot())
+
lastservice=eServiceReference(config.tv.lastservice.value)
if lastservice.valid():
- self.session.nav.playService(lastservice)
self.servicelist.setCurrent(lastservice)
+ self.session.nav.playService(lastservice)
def onShow(self):
ref = self.session.nav.getCurrentlyPlayingServiceReference()
@@ -518,6 +542,87 @@ class ChannelSelection(ChannelSelectionBase, ChannelSelectionEdit):
if lastservice.valid() and self.getCurrentSelection() != lastservice:
self.servicelist.setCurrent(lastservice)
+class ChannelSelectionRadio(ChannelSelectionBase, ChannelSelectionEdit):
+ def __init__(self, session):
+ ChannelSelectionBase.__init__(self, session)
+ ChannelSelectionEdit.__init__(self)
+
+ config.radio = ConfigSubsection();
+ config.radio.lastservice = configElement("config.radio.lastservice", configText, "", 0);
+ config.radio.lastroot = configElement("config.radio.lastroot", configText, "", 0);
+ self.onLayoutFinish.append(self.onCreate)
+
+ class ChannelActionMap(NumberActionMap):
+ def action(self, contexts, action):
+ if not self.csel.enterBouquet(action):
+ NumberActionMap.action(self, contexts, action)
+ self["actions"] = ChannelActionMap(["ChannelSelectActions", "OkCancelActions", "ContextMenuActions", "TvRadioActions"],
+ {
+ "keyTV": self.closeRadio,
+ "keyRadio": self.closeRadio,
+ "contextMenu": self.doContext,
+ "cancel": self.closeRadio,
+ "ok": self.channelSelected,
+ "showFavourites": self.showFavourites,
+ "showAllServices": self.showAllServices,
+ "showProviders": self.showProviders,
+ "showSatellites": self.showSatellites,
+ "1": self.keyNumberGlobal,
+ "2": self.keyNumberGlobal,
+ "3": self.keyNumberGlobal,
+ "4": self.keyNumberGlobal,
+ "5": self.keyNumberGlobal,
+ "6": self.keyNumberGlobal,
+ "7": self.keyNumberGlobal,
+ "8": self.keyNumberGlobal,
+ "9": self.keyNumberGlobal,
+ "0": self.keyNumberGlobal
+ })
+ self["actions"].csel = self
+
+ def onCreate(self):
+ self.setRadioMode()
+ lastroot=eServiceReference(config.radio.lastroot.value)
+ if lastroot.valid():
+ self.setRoot(lastroot)
+ else:
+ self.showFavourites()
+ self.saveRoot(self.getRoot())
+ lastservice=eServiceReference(config.radio.lastservice.value)
+ if lastservice.valid():
+ self.servicelist.setCurrent(lastservice)
+ self.session.nav.playService(lastservice)
+ self.servicelist.setPlayableIgnoreService(lastservice)
+
+ def channelSelected(self): # just return selected service
+ ref = self.getCurrentSelection()
+ if self.movemode:
+ self.toggleMoveMarked()
+ elif (ref.flags & 7) == 7:
+ self.setRoot(ref)
+ elif self.bouquet_mark_edit:
+ self.doMark()
+ else:
+ self.session.nav.playService(ref)
+ self.servicelist.setPlayableIgnoreService(ref)
+ config.radio.lastservice.value = ref.toString()
+ config.radio.lastservice.save()
+
+ def setRoot(self, root, justSet=False):
+ self.setRootBase(root, justSet)
+
+ def closeRadio(self):
+ lastroot=eServiceReference(config.radio.lastroot.value)
+ lastservice=eServiceReference(config.radio.lastservice.value)
+ if lastroot.valid() and self.getRoot() != lastroot:
+ self.setRoot(lastroot)
+ if lastservice.valid() and self.getCurrentSelection() != lastservice:
+ self.servicelist.setCurrent(lastservice)
+ #set previous tv service
+ lastservice=eServiceReference(config.tv.lastservice.value)
+ self.session.nav.playService(lastservice)
+ self.close(None)
+
class SimpleChannelSelection(ChannelSelectionBase):
def __init__(self, session, title):
ChannelSelectionBase.__init__(self, session)
@@ -528,7 +633,7 @@ class SimpleChannelSelection(ChannelSelectionBase):
def action(self, contexts, action):
if not self.csel.enterBouquet(action):
NumberActionMap.action(self, contexts, action)
- self["actions"] = ChannelActionMap(["ChannelSelectActions", "OkCancelActions", "ContextMenuActions"],
+ self["actions"] = ChannelActionMap(["ChannelSelectActions", "OkCancelActions", "ContextMenuActions", "TvRadioActions"],
{
"cancel": self.cancel,
"ok": self.channelSelected,
@@ -536,6 +641,8 @@ class SimpleChannelSelection(ChannelSelectionBase):
"showAllServices": self.showAllServices,
"showProviders": self.showProviders,
"showSatellites": self.showSatellites,
+ "keyRadio": self.setModeRadio,
+ "keyTV": self.setModeTv,
"1": self.keyNumberGlobal,
"2": self.keyNumberGlobal,
"3": self.keyNumberGlobal,
@@ -550,14 +657,24 @@ class SimpleChannelSelection(ChannelSelectionBase):
self["actions"].csel = self
def onExecCallback(self):
- print "onExecCallback"
- self.showFavourites()
self.session.currentDialog.instance.setTitle(self.title)
+ self.setModeTv()
def channelSelected(self): # just return selected service
ref = self.getCurrentSelection()
- self.close(ref)
+ if (ref.flags & 7) == 7:
+ self.setRoot(ref)
+ else:
+ ref = self.getCurrentSelection()
+ self.close(ref)
- def setRoot(self, root):
- self.setRootBase(root)
+ def setRoot(self, root, justSet=False):
+ self.setRootBase(root, justSet)
+ def setModeTv(self):
+ self.setTvMode()
+ self.showFavourites()
+
+ def setModeRadio(self):
+ self.setRadioMode()
+ self.showFavourites()
diff --git a/lib/python/Screens/InfoBar.py b/lib/python/Screens/InfoBar.py
index aaa3deba..c2616dab 100644
--- a/lib/python/Screens/InfoBar.py
+++ b/lib/python/Screens/InfoBar.py
@@ -1,6 +1,7 @@
from Screen import Screen
from Screens.MovieSelection import MovieSelection
+from Screens.ChannelSelection import ChannelSelectionRadio
from Screens.MessageBox import MessageBox
from ServiceReference import ServiceReference
@@ -33,20 +34,26 @@ class InfoBar(Screen, InfoBarVolumeControl, InfoBarShowHide, InfoBarPowerKey,
self["actions"] = HelpableActionMap(self, "InfobarActions",
{
- "showMovies": (self.showMovies, _("Play recorded movies..."))
+ "showMovies": (self.showMovies, _("Play recorded movies...")),
+ "showRadio": (self.showRadio, _("Show the radio player..."))
})
for x in HelpableScreen, \
InfoBarVolumeControl, InfoBarShowHide, InfoBarPowerKey, \
InfoBarNumberZap, InfoBarChannelSelection, InfoBarMenu, InfoBarEPG, \
InfoBarEvent, InfoBarServiceName, InfoBarInstantRecord, InfoBarAudioSelection, \
- InfoBarAdditionalInfo, InfoBarNotifications, InfoBarDish, InfoBarSubserviceSelection, InfoBarTuner:
+ InfoBarAdditionalInfo, InfoBarNotifications, InfoBarDish, InfoBarSubserviceSelection, \
+ InfoBarTuner:
x.__init__(self)
self.helpList.append((self["actions"], "InfobarActions", [("showMovies", "Watch a Movie...")]))
+ self.helpList.append((self["actions"], "InfobarActions", [("showRadio", "Hear Radio...")]))
self["CurrentTime"] = Clock()
+ def showRadio(self):
+ self.session.open(ChannelSelectionRadio)
+
def showMovies(self):
self.session.openWithCallback(self.movieSelected, MovieSelection)