--- misc/xbmc/plugin.video.todic/default.py 2016/11/23 09:44:02 3146 +++ misc/xbmc/plugin.video.todic/default.py 2016/11/23 20:10:15 3147 @@ -3,7 +3,7 @@ ''' Todic plugin for XBMC - Version 0.0.18 + Version 0.0.19 ''' import sys @@ -42,35 +42,55 @@ def __init__(self): super(TodicMovieDialog, self).__init__() + self.position = 0 def onClick(self, controlId): - print "OnClick: " + str(controlId) + print "[Todic] MovieDialog OnClick: " + str(controlId) if (controlId == 50): self.close() - play_real_video(self.url, self.name) + play_real_video(self.url, self.name, 0) + + if (controlId == 51): + self.close() + play_real_video(self.url, self.name, self.position) if (controlId == 98): self.close() def onInit(self): - print "ONINIT" + print "[Todic] MovieDialog ONINIT" self.getControl(1).setLabel(self.name) self.getControl(2).setLabel(self.moviegroups) self.getControl(3).setLabel(self.description) self.getControl(10).setLabel(self.playlength) self.getControl(11).setLabel(self.codecdetails) - orig_img_width = self.getControl(40).getWidth() - self.starwidth = (float(self.imdbrating) / 10.0) * orig_img_width - self.getControl(40).setWidth(int(self.starwidth)) + if (self.position > 0): + self.getControl(51).setVisible(True) + self.getControl(50).setPosition(100, 570) + self.getControl(51).setPosition(450, 570) + self.getControl(50).controlLeft( self.getControl(51) ) + self.getControl(50).controlRight( self.getControl(51) ) + else: + self.getControl(51).setVisible(False) + + #orig_img_width = self.getControl(40).getWidth() + #self.starwidth = (float(self.imdbrating) / 10.0) * orig_img_width + #self.getControl(40).setWidth(int(self.starwidth)) def setUrl(self, url): - print "SETURL:" + url + print "[Todic] MovieDialog SETURL:" + url self.url = url self.fetchClipDetails() + def setPosition(self, pos): + print "[Todic] MovieDialog setPosition:" + str(pos) + self.position = pos + + + def fetchClipDetails(self): param1 = parse_parameter_string(self.url) @@ -130,8 +150,9 @@ now = time() #print "[Todic] tick " + str(now) + " " + str(self.lastReport) + " : " +str(now - self.lastReport) if ( (now - self.lastReport) > 60.0): - self.reportPlaytime() self.lastReport = now + self.reportPlaytime() + @@ -184,7 +205,7 @@ try: return open_url(url) except: - print "Some error during open_url call to ", url + print "[Todic ]Some error during open_url call to ", url @@ -277,20 +298,22 @@ def play_video(url, name, description): if (description == None or description == ""): - play_real_video(url, name) + play_real_video(url, name, 0) else: d = TodicMovieDialog() d.setUrl(url) d.setName(name) d.setDescription(description) + d.setPosition(pos) #tager pos fra global scope d.doModal() -def play_real_video(url, name): +def play_real_video(url, name, position): xml = open_url(url) - print 'TODIC url: ' + str(url) - print 'TODIC xml: ' + xml + print '[Todic] url: ' + str(url) + print '[Todic] xml: ' + xml + print '[Todic] pos: ' + str(position) doc = parseString(xml) url = getText(doc.getElementsByTagName("url")) @@ -312,6 +335,8 @@ listitem = xbmcgui.ListItem( label=name, iconImage='DefaultVideo.png', thumbnailImage=image) listitem.setInfo(type="Video", infoLabels={"Title": name}) + listitem.setProperty('ResumeTime', '300') + listitem.setProperty('TotalTime', '3000') player = TodicPlayer(xbmc.PLAYER_CORE_AUTO) player.play(str(url), listitem) @@ -324,6 +349,8 @@ if count > 10: break + + if xbmc.Player().isPlaying(): if os.path.isfile(subtitlesfile): player.setSubtitles(subtitlesfile) @@ -331,14 +358,20 @@ else: player.disableSubtitles() - #Holder python kørernde indtil at det bliver bedt om at stoppe - while (not xbmc.abortRequested): - player.tick() - xbmc.sleep(250) + if (position > 0): + while (player.getTotalTime() == 0.0): #Vent indtil vi har beregnet hvor langt klippet er + xbmc.sleep(250) + + print "[Todic] totalTime " + str( player.getTotalTime() ) + player.seekTime(position) -# player.callbackLoop() + #Holder python kørernde indtil at det bliver bedt om at stoppe + while (not xbmc.abortRequested): + player.tick() + xbmc.sleep(500) + def search(): @@ -419,6 +452,7 @@ name = None mode = None description = None +pos = 0 try: url = urllib.unquote_plus(params["url"]) @@ -438,6 +472,12 @@ pass try: + pos = int(params["pos"]) +except: + pass + + +try: open_url("http://todic.dk") except: showMessage("Fejl", "Kunne ikke forbinde til todic.dk")