-
Notifications
You must be signed in to change notification settings - Fork 37
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
Allow selection of the active stream #49
Comments
After some study I found out it's not possible to correctly implement stream selection without seeking support. See this page if interested :) |
It is still helpful to support stream selection before playback begins, even if it is not possible (without seeking) to support changing streams on-the-fly. This can be helpful for videos that contain audio streams in different languages, and the general configuration of the calling program can determine which language audio stream is desired before playback occurs. Subtitles could be rendered on a separate surface and simply shown or hidden by a toggle if desired. This has the serious disadvantage of needing a separate ffmpeg instance to render it to a surface with alpha. Of course if you plan to add in proper seeking support then this is all rather moot. |
Ah yes good point! I didn't thought of this case. And selecting the good stream before starting indeed doesn't require seeking support, which makes it much easier to support :) It'll be studied once work on this task resumes. As for subtitle, it's not supported yet so… but do you mean rendering all found subtitles from all streams then choose which one to display eventually? Why do you say a separate ffmpeg instance would be needed? |
Oh I mean if you wanted to support subtitles without supporting seeking, you could render them alongside the video on a separate surface and overlay that surface on top of the video when subtitles are desired or move the surface offscreen (or otherwise hide it) when they are not. Then you would just need to tie all streams into the same "playback" controls. With how ffmpeg handles subtitles, though, there is no way to render subtitles separate from the video without treating it like an entirely separate video (which means instantiating much of ffmpeg AGAIN, even though you are probably working from the same source file). So what you would have (overly-simplified) is:
Again this last part is moot if you plan to support proper seeking eventually, as the work put into this setup would be wasted. |
We already have a semi-working subtitle implementation which you can look in the "subtitle" branch. It's still WIP and i need to fix some issues |
@bluekirby0 I'm really having a hard time understanding your solution :( What is currently being done and what @feliwir uses on the subtitle branch is the following:
So no separate FFmpeg instance or source filters here, I don't exactly know what you mean with them. |
Yeah, don't worry about what I was saying then. I was looking at it from a different approach (and not a very suitable one). It would be a work-around at best. |
Haha ok fine then :) |
Support for stream selection when the movie is stopped has been merged into master. Support for selection during playback will be done when seeking is ready. I've tested with multiple audio streams only, it's supposed to work with multiple video streams too, but I've no such media file to give it a try. If you've one I would be interested! |
I don't have a short clip handy but I know of a perfect source I can use to make one. I think Matroska and VOB are the only containers that actually support multiple video tracks though (and VOB does it in a really roundabout way) so I'll prepare something in mkv. |
What I also wonder is what is the interest of such medias? For network streams it allows using the one adapted to your network speed. But for files… what's the point? |
It was actually commonly used on DVDs (by abusing the "multi-angle" and "playlist" features of the format) to change the title screen (or other on-screen text that subtitles were not suitable for) for multi-language releases, particularly in western Europe. You could probably accomplish something similar by using the matroska "ordered chapters" feature, or by using splitters that support selecting tracks based on language codes. |
Hmm I don't think we want to go that far with sfeMovie (especially for DVDs that are not meant to carry on). So if it's the only usage, this support won't be provided. |
It is of considerably less use than proper soft-sub support, considering libass provides enough functionality to generate nice, language-specific titles/signboards/etc... without the compression artifacts involved with hard-subbed video with sharp text. Granted, some hard-core Adobe AFX users will disagree with how useful libass is for rendering fancy effects in real-time and that only hard-coded typesetting can produce the results they want without grinding playback speed to a slow crawl. Overall the usefulness of this greatly hinges on whether this library will be used for multi-lingual releases that will take advantage of advanced typesetting techniques to support several languages without massively inflating the release size by creating video-per-language files for playback. Again, you can probably still manipulate the matroska "ordered chapters" feature for this to some extent without modifying your library by creating "dummy" videos for each language that just define the proper chain of videos to play for that language. I am assuming that ffmpeg's internal splitter handles ordered chapters correctly, though, and that it does not require special handling on the playback side. |
Do you know where I can find such matroska file? |
I can probably generate something as a sample for you to test...the tools are readily available if you are familiar enough with them to use them. |
Do you mean the tools to create such files? |
Yes. MKVToolnix provides both command-line and gui tools to produce and edit matroska containers and valid chapter files (which are XML). From some initial testing it looks like ffmpeg does not support ordered chapters that load segments from external files, but it may still be possible to use segments based on keyframes within the same file, for example: File layout: Playback branching via chapters (which in mkv can also be language coded): So basically you can create a "super" clip that contains every scene for every language and then use the chapter file to determine which scenes will be played and in what order. |
Ok I got it :)
These are several reasons which make me think it won't be supported in the short term. Which brings us with the fact that we don't care if stream selection for video streams actually does work. |
Fair enough. If this was a general purpose video player it would be slightly more important, but as simple library where video can be tailored to meet the requirements of the program it is far less important. |
A media can have several audio, video or subtitle streams.
CA:
The text was updated successfully, but these errors were encountered: