X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/2dc13ab463d67b1255ec31cbe2b27cafef318dbe..0f2685f4c5daa1ced4fc9454ddb467e1396bcb91:/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py diff --git a/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py b/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py index 48a75544..112a221e 100644 --- a/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py +++ b/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py @@ -1,23 +1,53 @@ -from Tools.Directories import resolveFilename, fileExists, SCOPE_FONTS, SCOPE_PLUGINS, SCOPE_SKIN +from Tools.Directories import fileExists +from Components.config import config, ConfigSubsection, ConfigInteger, ConfigText, ConfigSelection, getConfigListEntry, ConfigSequence + +class ConfigColor(ConfigSequence): + def __init__(self): + ConfigSequence.__init__(self, seperator = "#", limits = [(0,255),(0,255),(0,255)]) + +class ConfigPixelvals(ConfigSequence): + def __init__(self): + ConfigSequence.__init__(self, seperator = ",", limits = [(0,200),(0,200),(0,200)]) + +class ConfigPixelvals(ConfigSequence): + def __init__(self): + ConfigSequence.__init__(self, seperator = ",", limits = [(0,200),(0,200),(0,200)]) + +class ConfigFilename(ConfigText): + def __init__(self): + ConfigText.__init__(self, default = "", fixed_size = True, visible_width = False) + + def getMulti(self, selected): + filename = (self.text.rstrip("/").rsplit("/",1))[1].encode("utf-8")[:40] + " " + if self.allmarked: + mark = range(0, len(filename)) + else: + mark = [filename] + return ("mtext"[1-selected:], filename, mark) + class DVDProject: def __init__(self): self.titles = [ ] self.target = None - self.name = _("Dreambox DVD record") - self.vmgm = resolveFilename(SCOPE_PLUGINS,"Extensions/DVDBurn/dreamvmgm.mpg") - self.menuaudio = resolveFilename(SCOPE_PLUGINS,"Extensions/DVDBurn/silence.mp2") - self.menubg = resolveFilename(SCOPE_SKIN, "dreamdvd_02.jpg") - # tuples with R, G, B values - self.color_button = ( 0x08, 0x00, 0x00 ) - self.color_highlight = ( 0x00, 0xC0, 0xC0 ) - self.color_headline = ( 0x00, 0x00, 0x80 ) - self.font_face = resolveFilename(SCOPE_FONTS, "nmsbd.ttf") - # tuple with three pixel values ( headline, title, subtitle ) - self.font_size = ( 48, 28, 16 ) - # please supply even numbers for all dimensions - self.space_left = 30 - self.space_top = 120 - self.space_rows = 36 + self.settings = ConfigSubsection() + self.settings.name = ConfigText(fixed_size = False, visible_width = 40) + self.settings.authormode = ConfigSelection(choices = [("menu_linked", _("Linked titles with a DVD menu")), ("just_linked", _("Direct playback of linked titles without menu")), ("menu_seperate", _("Seperate titles with a main menu")), ("data_ts", _("Dreambox format data DVD (HDTV compatible)"))]) + self.settings.titlesetmode = ConfigSelection(choices = [("single", _("Simple titleset (compatibility for legacy players)")), ("multi", _("Complex (allows mixing audio tracks and aspects)"))], default="multi") + self.settings.output = ConfigSelection(choices = [("iso", _("Create DVD-ISO")), ("dvd", _("Burn DVD"))]) + self.settings.isopath = ConfigText(fixed_size = False, visible_width = 40) + self.settings.dataformat = ConfigSelection(choices = [("iso9660_1", ("ISO9660 Level 1")), ("iso9660_4", ("ISO9660 version 2")), ("udf", ("UDF"))]) + self.settings.menubg = ConfigFilename() + self.settings.menuaudio = ConfigFilename() + self.settings.titleformat = ConfigText(fixed_size = False, visible_width = 40) + self.settings.subtitleformat = ConfigText(fixed_size = False, visible_width = 40) + self.settings.color_headline = ConfigColor() + self.settings.color_highlight = ConfigColor() + self.settings.color_button = ConfigColor() + self.settings.font_face = ConfigFilename() + self.settings.font_size = ConfigPixelvals() + self.settings.space = ConfigPixelvals() + self.settings.vmgm = ConfigFilename() + self.filekeys = ["vmgm", "menubg", "menuaudio", "font_face", "isopath"] def addService(self, service): import DVDTitle @@ -25,29 +55,17 @@ class DVDProject: title.addService(service) self.titles.append(title) return title - + def saveProject(self, path): import xml.dom.minidom from Tools.XMLTools import elementsWithTag, mergeText, stringToXML list = [] list.append('\n') list.append('\n') - list.append('\t\n') - list.append('\t\n') + list.append('\t\n') list.append('\t\n') for title in self.titles: list.append('\t\t') @@ -56,13 +74,60 @@ class DVDProject: list.append('\t\n') list.append('\n') + name = self.settings.name.getValue() i = 0 - filename = path + "/" + self.name + ".ddvdp.xml" + filename = path + name + ".ddvdp.xml" while fileExists(filename): i = i+1 - filename = path + "/" + self.name + str(i).zfill(3) + ".ddvdp.xml" - - file = open(filename, "w") - for x in list: - file.write(x) - file.close() \ No newline at end of file + filename = path + name + str(i).zfill(3) + ".ddvdp.xml" + try: + file = open(filename, "w") + for x in list: + file.write(x) + file.close() + except: + return False + return filename + + def loadProject(self, filename): + import xml.dom.minidom + try: + if not fileExists(filename): + self.error = "xml file not found!" + raise AttributeError + else: + self.error = "" + file = open(filename, "r") + data = file.read().decode("utf-8").replace('&',"&").encode("ascii",'xmlcharrefreplace') + file.close() + projectfiledom = xml.dom.minidom.parseString(data) + for project in projectfiledom.childNodes[0].childNodes: + if project.nodeType == xml.dom.minidom.Element.nodeType: + if project.tagName == 'settings': + i = 0 + if project.attributes.length < 11: + self.error = "project attributes missing" + raise AttributeError + while i < project.attributes.length: + item = project.attributes.item(i) + key = item.name.encode("utf-8") + try: + val = eval(item.nodeValue) + except (NameError, SyntaxError): + val = item.nodeValue.encode("utf-8") + try: + self.settings.dict()[key].setValue(val) + except (KeyError): + self.error = "unknown attribute '%s'" % (key) + raise AttributeError + i += 1 + for key in self.filekeys: + val = self.settings.dict()[key].getValue() + if not fileExists(val): + self.error += "\n%s '%s' not found" % (key, val) + if len(self.error): + raise AttributeError + except AttributeError: + self.error += (" in project '%s'") % (filename) + return False + return True