Take into account item type for direct stream
Video and audio
This commit is contained in:
parent
e24d982c36
commit
53fbbffa75
3 changed files with 11 additions and 14 deletions
|
@ -204,7 +204,7 @@ def getThemeMedia():
|
|||
if playback == "DirectPlay":
|
||||
playurl = playUtils.directPlay(theme)
|
||||
else:
|
||||
playurl = playUtils.directStream(result, server, theme[u'Id'], "ThemeVideo")
|
||||
playurl = playUtils.directStream(result, server, theme[u'Id'], "Video")
|
||||
pathstowrite += ('<file>%s</file>' % playurl.encode('utf-8'))
|
||||
|
||||
# Check if the item has theme songs and add them
|
||||
|
|
|
@ -31,12 +31,17 @@ class PlayUtils():
|
|||
className = self.__class__.__name__
|
||||
utils.logMsg("%s %s" % (self.addonName, className), msg, int(lvl))
|
||||
|
||||
def getPlayUrl(self, server, id, result):
|
||||
def getPlayUrl(self, server, id, result, type):
|
||||
|
||||
WINDOW = self.WINDOW
|
||||
username = WINDOW.getProperty('currUser')
|
||||
server = WINDOW.getProperty('server%s' % username)
|
||||
|
||||
if "Audio" in type:
|
||||
type = "Audio"
|
||||
else:
|
||||
type = "Video"
|
||||
|
||||
if self.isDirectPlay(result,True):
|
||||
# Try direct play
|
||||
playurl = self.directPlay(result)
|
||||
|
@ -46,7 +51,7 @@ class PlayUtils():
|
|||
|
||||
elif self.isDirectStream(result):
|
||||
# Try direct stream
|
||||
playurl = self.directStream(result, server, id)
|
||||
playurl = self.directStream(result, server, id, type)
|
||||
if playurl:
|
||||
self.logMsg("File is direct streaming.", 1)
|
||||
WINDOW.setProperty("%splaymethod" % playurl, "DirectStream")
|
||||
|
@ -161,17 +166,8 @@ class PlayUtils():
|
|||
def directStream(self, result, server, id, type = "Video"):
|
||||
|
||||
try:
|
||||
if "ThemeVideo" in type:
|
||||
if "Video" in type:
|
||||
playurl ="%s/mediabrowser/Videos/%s/stream?static=true" % (server, id)
|
||||
|
||||
elif "Video" in type:
|
||||
playurl = "%s/mediabrowser/Videos/%s/stream?static=true" % (server, id)
|
||||
# Verify audio and subtitles
|
||||
mediaSources = result[u'MediaSources']
|
||||
if mediaSources[0].get('DefaultAudioStreamIndex') != None:
|
||||
playurl = "%s&AudioStreamIndex=%s" % (playurl, mediaSources[0].get('DefaultAudioStreamIndex'))
|
||||
if mediaSources[0].get('DefaultSubtitleStreamIndex') != None:
|
||||
playurl = "%s&SubtitleStreamIndex=%s" % (playurl, mediaSources[0].get('DefaultSubtitleStreamIndex'))
|
||||
|
||||
elif "Audio" in type:
|
||||
playurl = "%s/mediabrowser/Audio/%s/stream.mp3" % (server, id)
|
||||
|
|
|
@ -46,6 +46,7 @@ class PlaybackUtils():
|
|||
|
||||
try:
|
||||
id = result["Id"]
|
||||
type = result['Type']
|
||||
except:
|
||||
return
|
||||
|
||||
|
@ -90,7 +91,7 @@ class PlaybackUtils():
|
|||
# Let's play the playlist
|
||||
return self.AddToPlaylist(itemsToPlay)
|
||||
|
||||
playurl = PlayUtils().getPlayUrl(server, id, result)
|
||||
playurl = PlayUtils().getPlayUrl(server, id, result, type)
|
||||
if playurl == False or WINDOW.getProperty('playurlFalse') == "true":
|
||||
WINDOW.clearProperty('playurlFalse')
|
||||
xbmc.log("Failed to retrieve the playback path/url.")
|
||||
|
|
Loading…
Add table
Reference in a new issue