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

How can I retrieve information about the latest segment loadded to an HLS live stream? #2032

Open
ELCHULI190 opened this issue Jan 10, 2025 · 1 comment
Assignees
Labels

Comments

@ELCHULI190
Copy link

ExoPlayer Version

1.3.1


Question

I am working with a live HLS stream and need to obtain information about the last segment that has been added to the playlist (m3u8) without directly reading the manifest from ExoPlayer.

Context

Here is an example of an HLS manifest (m3u8) I am working with:

#EXTM3U
#EXT-X-VERSION:3
#EXT-X-TARGETDURATION:6
#EXT-X-MEDIA-SEQUENCE:22569
#EXT-X-DISCONTINUITY-SEQUENCE:209
#EXTINF:6.000,
index_1_22569.ts?m=1734004082
#EXTINF:6.000,
index_1_22570.ts?m=1734004082
#EXTINF:6.000,
index_1_22571.ts?m=1734004082
#EXTINF:6.000,
index_1_22572.ts?m=1734004082
#EXTINF:6.000,
index_1_22573.ts?m=1734004082
#EXTINF:6.000,
index_1_22574.ts?m=1734004082
#EXTINF:5.617,
index_1_22575.ts?m=1734004082

Problem

I need to detect when a new segment has been loaded into the playlist and get information about it, but without directly analyzing the manifest from the code. In other words, I want to know when ExoPlayer detects and loads a new segment during real-time playback.

Specific Questions:

  • Does ExoPlayer have any method or listener that allows you to identify when a new segment is loaded in a live HLS stream?
  • If no specific method exists, what would be the best way to achieve this behavior with ExoPlayer?

Any guidance or examples would be greatly appreciated. Thanks in advance!

@marcbaechinger
Copy link
Contributor

marcbaechinger commented Jan 10, 2025

Thanks for your question

without directly reading the manifest from ExoPlayer.

I understand with this you mean reading the text HLS playlist. Because the information you are asking for is actually in the playlist and you have to read the HLS playlist for that (aka. manifest). However, ExoPlayer parses it for you and provides you with an object that contains the information ExoPlayer extracts from the playlist. The segments are part of that.

If that's ok, the you can add a Player.Listener and listen for onTimelineChanged(Timeline, ...) events.
You can then get the Timeline.Window of the stream you are interested in. For HLS, there is a field window.manifest that gives you an object that for HLS can be casted to a HlsManifest from where you can get the mediaPlaylist field which is of type HlsMediaPlaylist. This object contains all the information ExoPlayer parses from the media playlist which includes the segments:

    int   windowIndexOfInterest = player.getCurrentMediaItemIndex();
    Window window = timeline.getWindow(windowIndexOfInterest, new Window());
    if (window.manifest instanceof HlsManifest) {
      HlsMediaPlaylist mediaPlaylist = ((HlsManifest) window.manifest).mediaPlaylist;
      HlsMediaPlaylist.Segment lastSegment =
          mediaPlaylist.segments.get(mediaPlaylist.segments.size() - 1);
    }

The interval for refreshing depends on the stream. You can use mediaPlaylist.mediaSequence to see whether the playlist has dropped a segment at the beginning of the live window. Each time a segment is removed from the start of the live window, that sequence is incremented. So together with the mediaSequence and the size of the list of segements, you can figure out whether a new segment has been added. There may be other ways for this as well, just saying. :)

Please note that the mediaPlaylist.manifest fields is null until you receive the first timeline change with TIMELINE_CHANGE_REASON_SOURCE_REFRESH for the window of interest.

Please also note that the above snippet uses windowIndexOfInterest to express that this may vary depending on what's in the global timeline and when you execute this code. For a player that always plays a single item only (which is likely if you are playing a live HLS stream) you can use 0 or the current media item index to make that simple. The example above uses the currentMediaItemIndex to get the window of the media item currently being played.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants