-
Notifications
You must be signed in to change notification settings - Fork 66
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for multi-part files #230
Comments
Yeah, currently the app doesn't support multi-part files. I'll look at doing this, probably by adding both parts to the internal queue, so that when one part stops the next one starts up. |
That ocurred to me as well - without looking at the code, I'll take a wild guess and say it should be as simple as getting a list of files inside the current folder, order by the last characters in the filename ascending (extension excluded, considering only the video files are taken) and enqueue them all... with some validation rules in place to avoid it taking unrelated files - like, numerically validating the last n-characters of the file name. A future refinement could be to make these be actually accounted for in the final timeline calculation (the total time remaining that appears on the player's hud) - or maybe the player will do that on its own when it sees there's more than one file in the queue? |
The API does provide Multiple Parts, right now I just grab the first one and ignore the others. So the basic code is there to handle it, just need to implement it. I also need to see what the entries look like. One thing that would help is to have an XML dump of such an entry. You can find out how to do that at the following url: https://github.com/NineWorlds/serenity-android/wiki/Serenity-for-Android#bugreports In general I need the information under the section that corresponds to your library where the Movies or Episodes are stored that are multi-part configs. |
Ok got it. Accessing it via browser like this: http://192.168.0.108:32400/library/sections/1/all I've got a lot of different places with multi-part files named differently (depends on if it's only a multi-part movie or a series). |
Hi, sorry for the belated reply.
...and here comes a large one:
Based on this info, I learned a good deal - Me thinks if at some point you're reading the contents of the XML, what you need to do next is iterate through each [Part] subnodes and storing each value of "id", and/or "file" and/or "key" into the player's queue? It doesn't even seem like you actually need to know in which way the files were named, as the multiple [Part] nodes under [Media] will tell you there's a multi-part video under there. If you just loop through whatever's under [Media], you should get everything you need for enqueueing, even for a single-part video - no need for treating single/multi part videos differently, me guesses. |
Thanks. This is exactly what I needed. Some additional information, I don't really even need the id, as long as Plex always returns them in the order. All I need is the values from the "key" attribute, which contains the URL that is needed to access and play that multipart file. So to access a part and start playback, I just use plexserver-url + multip-part-node-key-value. There is some additional meta information that is helpful but the keyvalue is the critical part for playback. I'll see what I can do to get this in the next release, but not sure on time frame. |
That sounds terrific. I spent some time looking at MX Player's API and it seems pretty straightforward to add multiple file support to it from a network stream (your last reply motivated me to play a little bit with it manually, I could see how it works the way you explained, by manually crafting the URI from http://[server's_ip_addr]:[port]/[value_of_key_attr] and I could see it play my parts (oops, pun unintended!) individually). I couldn't find a way to manually enter multiple URI's as a queue - guess this can only be done programatically via the API's android.intent.action.VIEW action and supplying an array of type android.net.Uri[] as the video_list argument. I eagerly look forward for this release! =) |
Moving to 1.8.0. |
Awesome. Can't wait to grab it. |
Unfortunately having to move this to 2.0.0 as I'm running out of time to implement. Will definitely try and get multipart support in for 2.0 though. |
Yea, I noticed this milestone never made M1 or M2.. ;o( |
Yeah sorry. I just haven't had a chance do dive into it. I do have a set of videos I can try it out with, so hopefully sooner rather than later. |
Haven't forgotten about this, just trying to get to it. Having to push it out again to 2.0.0. |
Plex no longer support, but Emby has similar functionality. |
Hi!
First of all, congratulations! This is the first client that really works well on my small android box.
I have plex client and xbmc with plex addon, both suck in various different aspects - mostly, my videos being streamed over wifi have to be transcoded to 2M 720p in order to play fluidly (at the cost of loss of resolution).
I downloaded and installed Serenity beta M1 today and it was a breath of fresh air!! Not only it plays all of my videos streamed over a lousy 150mpbs dlink wifi router directly and gaplessly (not even a stutter - why even bother to add transcoding?!), but it has a nice ui with options to stretch, zoom and pan the picture. And best of ALL, you can use your player of choice (I had set the preferred player as MX Player as it plays my movies rock-solid!)
Really, I am impressed by your app - Why can't Plex be like that is beyond me. You guys are close to perfection with this app already imho.
The only small fault I found is that it seems not capable of 'seeing' when a movie is broken down to several parts, e. g.:
Movie_Folder
-- movie_file-pt1.mkv
-- movie_file-pt2.mkv
-- movie_file-pt3.mkv
In plex, these are recognized properly as one movie and played seamlessly as one file.
That would be a necessary feature me thinks. So, following the plex naming guide, all files that are multi-part (-pt1|2|3|n or -disc1|2|3|n, etc) under the same folder should be read as one single part.
Cheerio and keep up the good work, keep adding nice features and do not drop the existing ones, because then you'll have a KILLER client app for plex (these guys should learn from you). If the multi-part file support is added to the next version, I'm definately a buyer!
The text was updated successfully, but these errors were encountered: