Skip to content
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

TTML: Support referential styling #2953

Closed
evandipietro opened this issue Jun 14, 2017 · 19 comments
Closed

TTML: Support referential styling #2953

evandipietro opened this issue Jun 14, 2017 · 19 comments
Assignees

Comments

@evandipietro
Copy link

evandipietro commented Jun 14, 2017

Issue description

Observed: MP4-Encapsulated TTML subtitles default to top position (with positionAnchor defaulting to Float.MIN_VALUE)
Expected: Subtitles appear at the bottom of the screen with a valid position

Reproduction steps

Using a dash steam w/ MP4-Encapsulated TTML subtitles, enable subtitles. Subtitles appear at the top.

Link to test content

Cannot provide (legal reasons)

Version of ExoPlayer being used

2.4.1 (Was not an issue in 2.4.0)

Device(s) and version(s) of Android being used

Device: FireTV
OS: Fire OS v5.2.4.1 (Android v5.1.1)

@ojw28
Copy link
Contributor

ojw28 commented Jun 14, 2017

Are you sure they're not TTML captions? I don't think we made any changes to WebVTT captioning between 2.4.0 and 2.4.1.

@evandipietro
Copy link
Author

@ojw28 My mistake, it is TTML. Updating the issue.

@ojw28
Copy link
Contributor

ojw28 commented Jun 14, 2017

We fixed TTML positioning in 2.4.1 (at least in theory). It's quite possible that your TTML caption files are actually specifying that the captions should be rendered at the top of the screen (or that the implicitly specify this by not specifying something else), and that what the previous behavior was incorrect.

There's nothing we can do to look at this without test content (or at least the TTML part of it).

@soutua
Copy link

soutua commented Jun 15, 2017

We also encountered this problem with the ExoPlayer 2.4.1/2.4.2. The subtitles we use do not define the alignment so the subtitles are displayed at the top of the screen. Would it be possible to add a way to change the default position from top to bottom, in case the position isn't defined in the subtitles?

@ojw28
Copy link
Contributor

ojw28 commented Jun 15, 2017

We need to see sample TTML files to investigate this properly.

@zharf
Copy link

zharf commented Jun 15, 2017

I extracted a snippet from our ttml stream (and swapped out the texts just in case) and attached it here. My initial investigation suggests that ExoPlayer doesn't support (chained?) referential styling as described by TTML

sidenote: I work with @soutua

ttml.zip

@ojw28 ojw28 changed the title Subtitles appearing at top TTML subtitles appearing at top Jun 15, 2017
@ojw28
Copy link
Contributor

ojw28 commented Jun 15, 2017

@zharf - Yes, that looks like the problem for your case. Thanks for the sample. We should fix that, after which you'll get proper positioning as is defined in your TTML file.
@evandipietro - There's no way we can verify whether your case is the same or different without a sample TTML file, so we'll use this issue to track supporting referential styling as in @zharf 's case unless we learn more.

Thanks!

@ojw28
Copy link
Contributor

ojw28 commented Jun 15, 2017

The best short term fix for this is probably to ignore regions that don't directly define origin and extent, which will cause the the captions to go back to being displayed at the bottom again. We currently set default origin and extent in this case, but that results in unexpected behavior when the origin and extent are actually defined in the chained styles that we're not currently resolving. Does that sound sensible?

@zharf
Copy link

zharf commented Jun 16, 2017

I'm not fully familiar with how this thing works as of right now but from what I understand it sounds like it could work for now. We can also test any suggested fixes.

@jonhan
Copy link

jonhan commented Jun 22, 2017

I have the same issue so +1

ojw28 added a commit that referenced this issue Jun 22, 2017
Issue: #2953

-------------
Created by MOE: https://github.com/google/moe
MOE_MIGRATED_REVID=159218386
@ojw28
Copy link
Contributor

ojw28 commented Jun 22, 2017

Please could you verify that the above change resolves the issue, up until the point at which we can properly support resolving of chained styles. You can either try on the dev-v2 branch, or cherry-pick the change into release-v2 if you want everything else to stay the same. We may cut a small release picking up a few bug fixes, including this one, if verification is received. Thanks!

@jonhan
Copy link

jonhan commented Jun 29, 2017

@ojw28 I can verify that the fix works in dev-v2! Will this be released soon?

@ojw28 ojw28 changed the title TTML subtitles appearing at top TTML: Support referential styling Jun 30, 2017
@ojw28
Copy link
Contributor

ojw28 commented Jun 30, 2017

The fix will be in 2.4.3, which will be released today or early next week. Renaming this issue to track the enhancement of properly supporting referential styling.

ojw28 added a commit that referenced this issue Jun 30, 2017
Issue: #2953

-------------
Created by MOE: https://github.com/google/moe
MOE_MIGRATED_REVID=159218386
@atkGit

This comment has been minimized.

@AquilesCanta

This comment has been minimized.

@atkGit

This comment has been minimized.

@ojw28

This comment has been minimized.

@ojw28

This comment has been minimized.

@google google locked as resolved and limited conversation to collaborators May 9, 2018
@icbaker icbaker assigned icbaker and unassigned ojw28 Oct 30, 2019
@icbaker
Copy link
Collaborator

icbaker commented Jan 6, 2025

androidx/media@8fe0b7a adds support for extent and origin inherited from referred styles. I'm going to mark this as fixed. Please open a new issue with specific info if there's additional support needed here: https://github.com/androidx/media/issues

@icbaker icbaker closed this as completed Jan 6, 2025
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

8 participants