--- misc/xbmc/plugin.video.todic/default.py 2012/05/06 16:21:11 1799 +++ misc/xbmc/plugin.video.todic/default.py 2015/06/29 11:34:00 2592 @@ -3,7 +3,7 @@ ''' Todic plugin for XBMC - Version 0.0.2 + Version 0.0.13 ''' import sys @@ -24,6 +24,46 @@ __key__ = __addon__.getSetting('xbmckey').lower() __backend__ = "http://todic.dk/xbmc.php?xbmckey=" + __key__ fanartImage = os.path.join(__addon__.getAddonInfo('path'), 'fanart.jpg') +datapath = xbmc.translatePath('special://profile/addon_data/plugin.video.todic/') + +ADDON_PATH = __addon__.getAddonInfo('path') +SkinMasterPath = os.path.join(ADDON_PATH, 'skins' ) + '/' +MySkinPath = (os.path.join(SkinMasterPath, '720p')) + '/' +MySkin = 'main.xml' + + +class TodicMovieDialog(xbmcgui.WindowXMLDialog): + def __new__(cls): + return super(TodicMovieDialog, cls).__new__(cls, "main.xml", ADDON_PATH) + + def __init__(self): + super(TodicMovieDialog, self).__init__() + + def onClick( self, controlId ): + print "OnClick: " + str(controlId) + + if (controlId == 50): + self.close() + play_real_video(self.url, self.name) + + if ( controlId == 98 ): + self.close() + + + def onInit(self): + + print "ONINIT" + self.getControl( 1 ).setLabel( self.name); + self.getControl( 2 ).setLabel( self.description ); + + def setUrl( self, url): + self.url = url + + def setName( self, name ): + self.name = name + + def setDescription( self, description ): + self.description = description class TodicPlayer(xbmc.Player): @@ -74,6 +114,11 @@ else: return nodelist[0].childNodes[0].nodeValue +def SaveFile(path, data): + file = open(path,'w') + file.write(data) + file.close() + def open_url(url): req = urllib2.Request(url) @@ -100,11 +145,18 @@ u = sys.argv[0] + "?mode=10&name=" ok = xbmcplugin.addDirectoryItem(handle = int(sys.argv[1]), url = u, listitem = listitem, isFolder = True) + #add search series + listitem = xbmcgui.ListItem(label = "Søg Serier ...", iconImage = 'DefaultFolder.png', thumbnailImage = 'DefaultFolder.png') + listitem.setProperty('Fanart_Image', fanartImage) + + u = sys.argv[0] + "?mode=11&name=" + ok = xbmcplugin.addDirectoryItem(handle = int(sys.argv[1]), url = u, listitem = listitem, isFolder = True) + xbmcplugin.endOfDirectory(int(sys.argv[1])) def buildList(url,title, endlist=True): - print '[TODIC]:'+str(url) + print '[TODIC]:'+str(url) link = open_url(url) doc = parseString(link) @@ -118,6 +170,7 @@ mode = '1' folder = True + entries = doc.getElementsByTagName("entry") l=len(entries) description = '' @@ -126,9 +179,12 @@ url = getText( entry.getElementsByTagName("url") ) thumb = getText( entry.getElementsByTagName("cover") ) description = getText( entry.getElementsByTagName("description") ) + playcount = getText( entry.getElementsByTagName("playcount") ) + + if playcount == '': + playcount = '0' + playcount = int(playcount) - name = name.encode('latin-1') - description = description.encode('latin-1') ## print "name:" + name # print "url:" + url @@ -141,10 +197,15 @@ if mode == '50': infoLabels = {} infoLabels['title'] = name - infoLabels['plot'] = description + infoLabels['plot'] = description + infoLabels['playcount'] = playcount listitem.setInfo('video', infoLabels) - u = sys.argv[0] + "?mode=" + urllib.quote(mode) + "&name=" + urllib.quote(name) + "&url=" + urllib.quote(url) + name = name.encode('UTF-8') + description = description.encode('UTF-8') + + + u = sys.argv[0] + "?mode=" + urllib.quote(mode) + "&name=" + urllib.quote(name) + "&url=" + urllib.quote(url) + "&description=" + urllib.quote(description) ok = xbmcplugin.addDirectoryItem(handle = int(sys.argv[1]), url = u, listitem = listitem, isFolder = folder, totalItems = l) if (endlist == True): @@ -153,19 +214,64 @@ -def play_video(url, name): - xml = open_url(url) +def play_video(url, name,description): + if (description == None or description == ""): + play_real_video(url,name) + else: + d = TodicMovieDialog() + d.setUrl( url) + d.setName( name ) + d.setDescription( description ) + + d.doModal() + + +def play_real_video(url, name): + xml = open_url(url) + print 'TODIC url: ' + str(url) + print 'TODIC xml: '+ xml doc = parseString(xml) url = getText( doc.getElementsByTagName("url") ) - print '[TODIC]:'+str(url) + subtitleurl = getText( doc.getElementsByTagName("subtitles") ) + subtitlesfile = os.path.join(datapath,'temp.srt') + + #if old srt file exists delete it first + if os.path.isfile(subtitlesfile): + os.unlink(subtitlesfile) + + print '[TODIC] subs: '+str(subtitleurl) + if len(subtitleurl) > 0: + subtitles = open_url(subtitleurl) + SaveFile(subtitlesfile, subtitles) + print 'TODIC downloaded subtitles' + + + image = xbmc.getInfoImage( 'ListItem.Thumb' ) listitem = xbmcgui.ListItem(label = name , iconImage = 'DefaultVideo.png', thumbnailImage = image) listitem.setInfo( type = "Video", infoLabels={ "Title": name } ) player = TodicPlayer(xbmc.PLAYER_CORE_AUTO) player.play(str(url), listitem) + + #kan ikke loade subtitles hvis foerend playeren koerer + count = 0 + while not xbmc.Player().isPlaying(): + xbmc.sleep(500) + count += 1 + if count > 10: + break + + + if xbmc.Player().isPlaying(): + if os.path.isfile(subtitlesfile): + player.setSubtitles(subtitlesfile) + print 'TODIC started subtitles' + else: + player.disableSubtitles() + # player.callbackLoop() @@ -181,6 +287,17 @@ buildList(url, "søgning") +def searchSeries(): + search = getUserInput("Todic Serie Søgning") + + if (search != None and search != ""): + url = __backend__ + "&action=searchseries&search=" + urllib.quote_plus(search) + + #print "[TODIC] Search start: " + search + #print "[TODIC] Search url: " + url + + buildList(url, "serie søgning") + @@ -232,6 +349,7 @@ url = None name = None mode = None +description = None try: url = urllib.unquote_plus(params["url"]) @@ -245,9 +363,24 @@ mode = int(params["mode"]) except: pass +try: + description = urllib.unquote_plus(params["description"]) +except: + pass +try: + open_url("http://todic.dk") +except: + showMessage("Fejl", "Kunne ikke forbinde til todic.dk") + exit() + -if mode == None: +if url == 'refresh': + #xbmc.output("[tvserver] Container.Refresh") #20130418 xbmc.output virker ikke med XBMC12 + xbmc.executebuiltin("Container.Refresh") + + +elif mode == None: #build main menu rootMenu() @@ -257,10 +390,13 @@ elif mode == 10: search() + +elif mode == 11: + searchSeries() elif mode == 50: - play_video(url, name) + play_video(url, name, description)