git.cweiske.de
/
enigma2.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
89b8546
)
pvr: add inductors
author
Felix Domke
<tmbinc@elitedvb.net>
Thu, 8 Dec 2005 14:30:14 +0000
(14:30 +0000)
committer
Felix Domke
<tmbinc@elitedvb.net>
Thu, 8 Dec 2005 14:30:14 +0000
(14:30 +0000)
lib/python/Screens/InfoBarGenerics.py
patch
|
blob
|
history
diff --git
a/lib/python/Screens/InfoBarGenerics.py
b/lib/python/Screens/InfoBarGenerics.py
index da648d13f6e200da9d6fb67e4a7ad6d504f1849f..58abce152b81e7b03d3a9ba1daa2822c02872649 100644
(file)
--- a/
lib/python/Screens/InfoBarGenerics.py
+++ b/
lib/python/Screens/InfoBarGenerics.py
@@
-445,6
+445,20
@@
class InfoBarServiceName:
self["ServiceName"] = ServiceName(self.session.nav)
class InfoBarPVR:
self["ServiceName"] = ServiceName(self.session.nav)
class InfoBarPVR:
+
+ # ispause, isff, issm, skip
+ SEEK_STATE_PLAY = (0, 0, 0, 0)
+ SEEK_STATE_PAUSE = (1, 0, 0, 0)
+ SEEK_STATE_FF_2X = (0, 2, 0, 0)
+ SEEK_STATE_FF_4X = (0, 4, 0, 0)
+ SEEK_STATE_FF_8X = (0, 8, 0, 0)
+ SEEK_STATE_FF_32X = (0, 0, 0, 32)
+ SEEK_STATE_FF_64X = (0, 0, 0, 64)
+
+ SEEK_STATE_BACK_4X = (0, 0, 0, -4)
+ SEEK_STATE_BACK_32X = (0, 0, 0, -32)
+ SEEK_STATE_BACK_64X = (0, 0, 0, -64)
+
"""handles PVR specific actions like seeking, pause"""
def __init__(self):
self["PVRActions"] = HelpableActionMap(self, "InfobarPVRActions",
"""handles PVR specific actions like seeking, pause"""
def __init__(self):
self["PVRActions"] = HelpableActionMap(self, "InfobarPVRActions",
@@
-455,12
+469,47
@@
class InfoBarPVR:
"seekFwd": (self.seekFwd, "skip forward"),
"seekBack": (self.seekBack, "skip backward"),
})
"seekFwd": (self.seekFwd, "skip forward"),
"seekBack": (self.seekBack, "skip backward"),
})
+
+ self.seekstate = self.SEEK_STATE_PLAY
+ self.seekTimer = eTimer()
+ self.seekTimer.timeout.get().append(self.seekTimerFired)
+ self.skipinterval = 500 # 500ms skip interval
+
+ def seekTimerFired(self):
+ print "skip", self.skipmode
+ if self.skipmode > 0:
+ self.doSeek(+1, self.skipmode * self.skipinterval)
+ else:
+ self.doSeek(-1, -self.skipmode * self.skipinterval)
+
+ def setSeekState(self, state):
+ oldstate = self.seekstate
+
+ self.seekstate = state
+
+ service = self.session.nav.getCurrentService()
+ if service is None:
+ return
+ pauseable = service.pause()
+ print "newstate: ", self.seekstate
+
+ for i in range(4):
+ if oldstate[i] != self.seekstate[i]:
+ (self.session.nav.pause, pauseable.setFastForward, pauseable.setSlowMotion, self.setSkipMode)[i](self.seekstate[i])
+
+ def setSkipMode(self, skipmode):
+ self.skipmode = skipmode
+ if skipmode == 0:
+ self.seekTimer.stop()
+ else:
+ self.seekTimer.start(500)
+
def pauseService(self):
def pauseService(self):
- self.se
ssion.nav.pause(1)
+ self.se
tSeekState(self.SEEK_STATE_PAUSE);
def unPauseService(self):
def unPauseService(self):
- self.se
ssion.nav.pause(0)
+ self.se
tSeekState(self.SEEK_STATE_PLAY);
def doSeek(self, dir, seektime):
service = self.session.nav.getCurrentService()
def doSeek(self, dir, seektime):
service = self.session.nav.getCurrentService()
@@
-473,10
+522,34
@@
class InfoBarPVR:
seekable.seekRelative(dir, 90 * seektime)
def seekFwd(self):
seekable.seekRelative(dir, 90 * seektime)
def seekFwd(self):
- self.doSeek(+1, 60000)
+ lookup = {
+ self.SEEK_STATE_PLAY: self.SEEK_STATE_FF_2X,
+ self.SEEK_STATE_PAUSE: self.SEEK_STATE_PLAY,
+ self.SEEK_STATE_FF_2X: self.SEEK_STATE_FF_4X,
+ self.SEEK_STATE_FF_4X: self.SEEK_STATE_FF_8X,
+ self.SEEK_STATE_FF_8X: self.SEEK_STATE_FF_32X,
+ self.SEEK_STATE_FF_32X: self.SEEK_STATE_FF_64X,
+ self.SEEK_STATE_FF_64X: self.SEEK_STATE_FF_64X,
+ self.SEEK_STATE_BACK_4X: self.SEEK_STATE_PLAY,
+ self.SEEK_STATE_BACK_32X: self.SEEK_STATE_BACK_4X,
+ self.SEEK_STATE_BACK_64X: self.SEEK_STATE_BACK_32X
+ }
+ self.setSeekState(lookup[self.seekstate]);
def seekBack(self):
def seekBack(self):
- self.doSeek(-1, 60000)
+ lookup = {
+ self.SEEK_STATE_PLAY: self.SEEK_STATE_BACK_4X,
+ self.SEEK_STATE_PAUSE: self.SEEK_STATE_BACK_4X,
+ self.SEEK_STATE_FF_2X: self.SEEK_STATE_PLAY,
+ self.SEEK_STATE_FF_4X: self.SEEK_STATE_FF_2X,
+ self.SEEK_STATE_FF_8X: self.SEEK_STATE_FF_4X,
+ self.SEEK_STATE_FF_32X: self.SEEK_STATE_FF_8X,
+ self.SEEK_STATE_FF_64X: self.SEEK_STATE_FF_32X,
+ self.SEEK_STATE_BACK_4X: self.SEEK_STATE_BACK_32X,
+ self.SEEK_STATE_BACK_32X: self.SEEK_STATE_BACK_64X,
+ self.SEEK_STATE_BACK_64X: self.SEEK_STATE_BACK_64X
+ }
+ self.setSeekState(lookup[self.seekstate]);
class InfoBarInstantRecord:
"""Instant Record - handles the instantRecord action in order to
class InfoBarInstantRecord:
"""Instant Record - handles the instantRecord action in order to