Infobar toggleable with OK key and remember last file browser directory
authorAndreas Frisch <andreas.frisch@multimedia-labs.de>
Wed, 16 Apr 2008 20:11:25 +0000 (20:11 +0000)
committerAndreas Frisch <andreas.frisch@multimedia-labs.de>
Wed, 16 Apr 2008 20:11:25 +0000 (20:11 +0000)
lib/python/Plugins/Extensions/DVDPlayer/plugin.py

index bab64ce12faa404dfffb08baa456cce5b5349d5b..3ecd9f8a6dea5c545cf9729b6a8a16ecc53e17aa 100644 (file)
@@ -19,6 +19,8 @@ from Tools.Directories import pathExists, fileExists
 import random
 import servicedvd # load c++ part of dvd player plugin
 
 import random
 import servicedvd # load c++ part of dvd player plugin
 
+lastpath = ""
+
 class FileBrowser(Screen):
        skin = """
        <screen name="FileBrowser" position="100,100" size="520,376" title="DVD File Browser" >
 class FileBrowser(Screen):
        skin = """
        <screen name="FileBrowser" position="100,100" size="520,376" title="DVD File Browser" >
@@ -26,7 +28,11 @@ class FileBrowser(Screen):
        </screen>"""
        def __init__(self, session):
                Screen.__init__(self, session)
        </screen>"""
        def __init__(self, session):
                Screen.__init__(self, session)
-               currDir = "/media/dvd/"
+               global lastpath
+               if lastpath is not None:
+                       currDir = lastpath + "/"
+               else:
+                       currDir = "/media/dvd/"
                if not pathExists(currDir):
                        currDir = "/"
                #else:
                if not pathExists(currDir):
                        currDir = "/"
                #else:
@@ -41,15 +47,18 @@ class FileBrowser(Screen):
                        })
 
        def ok(self):
                        })
 
        def ok(self):
+               global lastpath
                filename = self["filelist"].getFilename()
                filename = self["filelist"].getFilename()
-               if filename is not None and filename.upper().endswith("VIDEO_TS/"):
-                       print "dvd structure found, trying to open..."
-                       self.close(filename[0:-9])
-               elif self["filelist"].canDescent(): # isDir
+               if filename is not None:
+                       lastpath = filename[0:filename.rfind("/")]
+                       if filename.upper().endswith("VIDEO_TS/"):
+                               print "dvd structure found, trying to open..."
+                               self.close(filename[0:-9])
+               if self["filelist"].canDescent(): # isDir
                        self["filelist"].descent()
                else:
                        self.close(filename)
                        self["filelist"].descent()
                else:
                        self.close(filename)
-                       
+
        def exit(self):
                self.close(None)
                
        def exit(self):
                self.close(None)
                
@@ -474,6 +483,8 @@ class DVDPlayer(Screen, InfoBarNotifications, InfoBarSeek, InfoBarCueSheetSuppor
 
        def keyOk(self):
                if self.service:
 
        def keyOk(self):
                if self.service:
+                       if not self.in_menu:
+                               self.toggleInfo()
                        self.service.keys().keyPressed(iServiceKeys.keyOk)
 
        def keyCancel(self):
                        self.service.keys().keyPressed(iServiceKeys.keyOk)
 
        def keyCancel(self):