Media3
| Latest Update | Stable Release | Release Candidate | Beta Release | Alpha Release |
|---|---|---|---|---|
| October 22, 2025 | 1.8.0 | - | - | 1.9.0-alpha01 |
Declaring dependencies
To add a dependency on Media3, you must add the Google Maven repository to your project. Read Google's Maven repository for more information.
Add the dependencies for the artifacts you need in the build.gradle file for
your app or module:
Groovy
dependencies { def media3_version = "1.8.0" // For media playback using ExoPlayer implementation "androidx.media3:media3-exoplayer:$media3_version" // For DASH playback support with ExoPlayer implementation "androidx.media3:media3-exoplayer-dash:$media3_version" // For HLS playback support with ExoPlayer implementation "androidx.media3:media3-exoplayer-hls:$media3_version" // For SmoothStreaming playback support with ExoPlayer implementation "androidx.media3:media3-exoplayer-smoothstreaming:$media3_version" // For RTSP playback support with ExoPlayer implementation "androidx.media3:media3-exoplayer-rtsp:$media3_version" // For MIDI playback support with ExoPlayer (see additional dependency requirements in // https://github.com/androidx/media/blob/release/libraries/decoder_midi/README.md) implementation "androidx.media3:media3-exoplayer-midi:$media3_version" // For ad insertion using the Interactive Media Ads SDK with ExoPlayer implementation "androidx.media3:media3-exoplayer-ima:$media3_version" // For loading data using the Cronet network stack implementation "androidx.media3:media3-datasource-cronet:$media3_version" // For loading data using the OkHttp network stack implementation "androidx.media3:media3-datasource-okhttp:$media3_version" // For loading data using librtmp implementation "androidx.media3:media3-datasource-rtmp:$media3_version" // For building media playback UIs using Compose implementation "androidx.media3:media3-ui-compose:$media3_version" // For building media playback UIs using Views implementation "androidx.media3:media3-ui:$media3_version" // For building media playback UIs using Jetpack Compose implementation "androidx.media3:media3-ui-compose:$media3_version" // For building media playback UIs for Android TV using the Jetpack Leanback library implementation "androidx.media3:media3-ui-leanback:$media3_version" // For exposing and controlling media sessions implementation "androidx.media3:media3-session:$media3_version" // For extracting data from media containers implementation "androidx.media3:media3-extractor:$media3_version" // For integrating with Cast implementation "androidx.media3:media3-cast:$media3_version" // For scheduling background operations using Jetpack Work's WorkManager with ExoPlayer implementation "androidx.media3:media3-exoplayer-workmanager:$media3_version" // For transforming media files implementation "androidx.media3:media3-transformer:$media3_version" // For applying effects on video frames implementation "androidx.media3:media3-effect:$media3_version" // For muxing media files implementation "androidx.media3:media3-muxer:$media3_version" // Utilities for testing media components (including ExoPlayer components) implementation "androidx.media3:media3-test-utils:$media3_version" // Utilities for testing media components (including ExoPlayer components) via Robolectric implementation "androidx.media3:media3-test-utils-robolectric:$media3_version" // Common functionality for reading and writing media containers implementation "androidx.media3:media3-container:$media3_version" // Common functionality for media database components implementation "androidx.media3:media3-database:$media3_version" // Common functionality for media decoders implementation "androidx.media3:media3-decoder:$media3_version" // Common functionality for loading data implementation "androidx.media3:media3-datasource:$media3_version" // Common functionality used across multiple media libraries implementation "androidx.media3:media3-common:$media3_version" // Common Kotlin-specific functionality implementation "androidx.media3:media3-common-ktx:$media3_version" }
Kotlin
dependencies { val media3_version = "1.8.0" // For media playback using ExoPlayer implementation("androidx.media3:media3-exoplayer:$media3_version") // For DASH playback support with ExoPlayer implementation("androidx.media3:media3-exoplayer-dash:$media3_version") // For HLS playback support with ExoPlayer implementation("androidx.media3:media3-exoplayer-hls:$media3_version") // For SmoothStreaming playback support with ExoPlayer implementation("androidx.media3:media3-exoplayer-smoothstreaming:$media3_version") // For RTSP playback support with ExoPlayer implementation("androidx.media3:media3-exoplayer-rtsp:$media3_version") // For MIDI playback support with ExoPlayer (see additional dependency requirements in // https://github.com/androidx/media/blob/release/libraries/decoder_midi/README.md) implementation("androidx.media3:media3-exoplayer-midi:$media3_version") // For ad insertion using the Interactive Media Ads SDK with ExoPlayer implementation("androidx.media3:media3-exoplayer-ima:$media3_version") // For loading data using the Cronet network stack implementation("androidx.media3:media3-datasource-cronet:$media3_version") // For loading data using the OkHttp network stack implementation("androidx.media3:media3-datasource-okhttp:$media3_version") // For loading data using librtmp implementation("androidx.media3:media3-datasource-rtmp:$media3_version") // For building media playback UIs using Compose implementation("androidx.media3:media3-ui-compose:$media3_version") // For building media playback UIs using Views implementation("androidx.media3:media3-ui:$media3_version") // For building media playback UIs using Jetpack Compose implementation("androidx.media3:media3-ui-compose:$media3_version") // For building media playback UIs for Android TV using the Jetpack Leanback library implementation("androidx.media3:media3-ui-leanback:$media3_version") // For exposing and controlling media sessions implementation("androidx.media3:media3-session:$media3_version") // For extracting data from media containers implementation("androidx.media3:media3-extractor:$media3_version") // For integrating with Cast implementation("androidx.media3:media3-cast:$media3_version") // For scheduling background operations using Jetpack Work's WorkManager with ExoPlayer implementation("androidx.media3:media3-exoplayer-workmanager:$media3_version") // For transforming media files implementation("androidx.media3:media3-transformer:$media3_version") // For applying effects on video frames implementation("androidx.media3:media3-effect:$media3_version") // For muxing media files implementation("androidx.media3:media3-muxer:$media3_version") // Utilities for testing media components (including ExoPlayer components) implementation("androidx.media3:media3-test-utils:$media3_version") // Utilities for testing media components (including ExoPlayer components) via Robolectric implementation("androidx.media3:media3-test-utils-robolectric:$media3_version") // Common functionality for reading and writing media containers implementation("androidx.media3:media3-container:$media3_version") // Common functionality for media database components implementation("androidx.media3:media3-database:$media3_version") // Common functionality for media decoders implementation("androidx.media3:media3-decoder:$media3_version") // Common functionality for loading data implementation("androidx.media3:media3-datasource:$media3_version") // Common functionality used across multiple media libraries implementation("androidx.media3:media3-common:$media3_version") // Common Kotlin-specific functionality implementation("androidx.media3:media3-common-ktx:$media3_version") }
For more information about dependencies, see Add Build Dependencies.
Feedback
Your feedback helps make Jetpack better. You can use the Media3 issue tracker to find answers to questions, known issues and feature requests, and to file new issues.
Version 1.9.0
Version 1.9.0-alpha01
October 22, 2025
androidx.media3:media3-*:1.9.0-alpha01 is released.
Version 1.9.0-alpha01 contains these commits.
- Common Library:
- Update
minSdkto23in line with other AndroidX libraries. - Add
PlayerTransferState, which facilitates transferring the playback state acrossPlayerinstances. - Add
void mute()andvoid unmute()methods to Player that preserve and consequently restore Player's volume before and after setting it to zero. - Publish utility classes
WakeLockManager,WifiLockManager,AudioFocusManager,AudioBecomingNoisyManagerandStuckPlayerDetectorpreviously used byExoPlayerinternally to allow reuse for other players (#1893). - Fix
ForwardingPlayerlistener handling when the underlying delegate player uses reference equality for comparing listener instances (#2675). - Add a
Player.listenTosuspending extension function in themedia3-common-ktxlibrary that specifies the particularPlayer.Eventsthat should be acted upon. - Fix a crash in
BasePlayer.getBufferedPercentageresulting from integer overflow when the reported buffered position is implausibly much larger than the reported duration (#2750).
- Update
- ExoPlayer:
- Add a stuck player detection that triggers a
StuckPlayerExceptionplayer error if the player seems stuck. This happens in the following cases, where each default timeout can be configured inExoPlayer.Builderif required:- After 10 minutes of
STATE_BUFFERINGwhile trying to play and no buffering progress. - After 10 seconds of
STATE_READYwhile trying to play and no playback progress. - After 1 minute of
STATE_READYbeyond the declared duration without reaching the end of the item. - After 10 minutes with a playback suppression reason while trying to play.
- After 10 minutes of
- Enable wake lock handling by default to fix issues with buffering during
background playback. This is equivalent to setting
ExoPlayer.Builder.setWakeModetoC.WAKE_MODE_LOCAL. - Add listening logic to automatically update the virtual device ID when a
change is reported to the
Contextoriginally passed toExoPlayer.Builder. - Add
ExoPlayer.setVirtualDeviceIdto manually update the virtual device ID obtained from theContextpassed toExoPlayer.Builder. - Ensure renderers don't consume data from the next playlist item more than 10 seconds before the end of the current item.
- Add
setSeekBackIncrementMs,setSeekForwardIncrementMsandsetMaxSeekToPreviousPositionMstoExoPlayerto update these settings after construction (#2736). - Add pre-caching functionality in
DefaultPreloadManager. Apps now can returnDefaultPreloadManager.PreloadStatus.specifiedRangeCached(startPositionMs, durationMs)orDefaultPreloadManager.PreloadStatus.specifiedRangeCached(durationMs)viaTargetPreloadStatusControl.getTargetPreloadStatus(T rankingData)to indicate that a media item needs to be pre-cached. - Use pre-caching functionality of
DefaultPreloadManagerin shortform demo app. - Add
DefaultLoadControl.Buildersetters for local playback and adjust default values ofDefaultLoadControlto work well with a wide range of local files. - Fix bug where setting an empty playlist can leave the player in
STATE_READYorSTATE_BUFFERING. - Enhance the preload manager APIs:
- Add
addMediaItems(List<MediaItem>, List<T>)andaddMediaSources(List<MediaSource>, List<T>)that add the media items or media sources in batch, and automatically callinvalidate()afterwards. - Add
removeMediaItems((List<MediaItem>)andremoveMediaSources(List<MediaSource>)that remove the media items or media sources in batch, and make sure that preload manager does not start to preload or continue preloading any of them after removal. - Allow
DefaultPreloadManager.setCurrentPlayingIndex(int)to invalidate itself automatically. Apps don't need to callinvalidate()explicitly anymore after updating the current playing index.
- Add
- Add capability to skip keyframe reset for forward seeks within the same group of pictures while in scrubbing mode.
- Add
DefaultLoadControl.Builder.setPlayerTargetBufferBytes(String, int)for apps to set a value of target buffer bytes for a player with the specifiedplayerName. TheDefaultLoadControlcan now make decisions of each player separately based on its own allocated bytes and target buffer bytes. - Add
SkipInfoto theAdPlaybackState.AdGroupto carry skip information for each ad in the ad group. - Fix bug where calling
removeMediaItems(List)during playing a post-roll created a crash (#2746). - Fix some stuttering in playlist playback where frames were mistakenly always set as the last sample and rendered.
- Enable retry path if player fails to generate audio session ID (#2382, #2678).
- Add support to control the total buffer bytes for the sources in
DefaultPreloadManagerto avoid total buffer bytes for preloading from growing arbitrarily. To use the default control logic, Apps can set the target buffer bytes for preloading viaDefaultLoadControl.Builder.setPlayerTargetBufferBytes(String, int)for aplayerNameofPlayerId.Preload.name("preload"), and inject the createdDefaultLoadControlviaDefaultPreloadManager.Builder.setLoadControl(LoadControl).
- Add a stuck player detection that triggers a
- CompositionPlayer:
- Publish
CompositionPlayerunder a new@ExperimentalApiannotation to indicate it is available for experimentation, but is still under development. Some APIs are likely to change significantly in future releases, and there are known issues and limitations with some use-cases (some undocumented). - Add support for
COMMAND_SET_AUDIO_ATTRIBUTESand audio focus handling inCompositionPlayer. - Add support for speed changing in secondary sequences in
CompositionPlayer.
- Publish
- Transformer:
- Use
InAppMp4Muxeras default muxer. - Add
EditedMediaItem.Builder#setSpeed()and deprecateEffects#createExperimentalSpeedChangingEffects(). - Replace
forceAudioTrackandforceVideoTrackwithtrackTypesinEditedMediaItemSequence.
- Use
- Track Selection:
- Add
TrackSelectionParameters.selectTextByDefaultto prefer the selection of any text track without specifying other more specific preferences. - Add
preferredVideoLabels,preferredAudioLabelsandpreferredTextLabelsinTrackSelectionParametersto specify a preference for tracks with a specific label, for example those read from HLS NAME tags (#1666).
- Add
- Extractors:
- FLAC: Tighten header detection to reduce the chance of finding spurious headers in the encoded FLAC data, resulting in decoding errors (#558).
- MP3: Allow gaps between (and before) ID3 tags at the beginning of MP3 files (#811, #5718).
- MP4: Disambiguate between
audio/mpeg(MP3),audio/mpeg-L1andaudio/mpeg-L2MIME types by peeking the layer value of the first sample before emitting a track format from the extractor (#2683). - MP4: Improve sniffing efficiency of very large files by assuming a
stblbox larger than 1MB implies the file must be non-fragmented (#2650). - Matroska: Add support for DTS-HD detection (#6225).
- Fix an issue in
MatroskaExtractorwhere seeking could be inaccurate for files with multiple tracks. Cue points are now correctly associated with their respective tracks, leading to more precise seeking. - MP4: Add support for
©mvn(movement name) and©mvi(movement index) metadata, these are now emitted asTextInformationFrameobjects inFormat.metadatawith IDs ofMVNMandMVINrespectively (#2754). - MPEG-TS: Fix
IllegalArgumentExceptionfromReorderingBufferQueuecaused by PES packets with no timestamp (#2764). - MP4: Ignore tracks with missing
stsdbox (instead of failing to parse the whole file). - Add support for extracting HEIC Motion Photos. The
HeifExtractorcan now parse HEIC files containing embedded video and audio tracks. - MP3: Change
FLAG_ENABLE_INDEX_SEEKINGto prefer seeking information from metadata headers (like Xing and VBRI) when available, falling back to index-based seeking if no other seeking information is present. This improves performance for files with seeking metadata (#2839).
- Inspector:
- Introduced a new
:media3-inspectormodule to serve as the dedicated home for media inspection utilities. This module now houses a newandroidx.media3.inspector.MetadataRetriever, which will provide a unified API for both metadata and frame extraction. The existingandroidx.media3.exoplayer.MetadataRetrieveris now deprecated in favor of this new version. - Introduced
androidx.media3.inspector.FrameExtractor, a new public API for frame extraction. ThisAutoCloseableclass provides a way to extract frames with support for HDR video, video effects, and custom decoder selection. It should be created via itsBuilderfor a specificMediaItem. - FrameExtractor: Add
getThumbnail()to extract a representative thumbnail frame from a media file without requiring a specific timestamp.
- Introduced a new
- Audio:
- Make
AudioProcessorinstances aware of seeking. - Allow injecting the new
AudioOutputProviderinterface intoDefaultAudioSink.Builderto support custom audio output paths. The default isAudioTrackAudioOutputProvider. - Handle seeks in
GainProcessor. - Utilize AC-4 decoder profile and level capabilities in track format support assessment (#2580).
- Avoid potential delays caused by handling routing change callbacks at the beginning of playback (#2646).
- Allow codec reuse for EAC3, EAC3-JOC and AC-4 formats (#1346).
- Add support for float PCM samples in
Sonic. - Add support for 16 bit PCM samples in
ToFloatPcmAudioProcessor.
- Make
- Video:
- Disable codec reuse for Dolby-Vision content with different profiles.
- Text:
- Fix parsing of CEA-6/708 subtitles in Dolby Vision content (#2775).
- Image:
- Fix ScrubbingMode issue where player gets stuck while scrubbing a DASH thumbnail track (#2815).
- DRM:
- Change the return type of
MediaDrmCallbackmethods frombyte[]to a newMediaDrmCallback.Responsetype, to allow returning extra optional information. This is a source breaking change, but breakages can be easily resolved by wrapping the previousbyte[]return value withnew Responsebefore returning. - Add key request info like URL and latency to
AnalyticsListener.onDrmKeysLoaded(#1001). - Move provisioning request data from a URL parameter to the POST body.
- Change the return type of
- Muxers:
- Add
MediaMuxerCompat, a drop-in replacement for frameworkMediaMuxer. - Add
MuxerUtil.createMotionPhotoFromJpegImageAndBmffVideo()to allow Motion Photo creation. - Add
WebmMuxerto allow muxing ofOPUS,VORBIS,VP8andVP9media streams into awebmfile format.
- Add
- IMA extension:
- Removal of custom proguard rules, so that apps can use those released in IMA android archive instead.
- Add
ImaServerSideAdInsertionUriBuilder.setNetworkCode, a new API for setting the Google Ad Manager network code for the IMA SDK to handle ads identifiers as specified in Google Ad Manager settings. Network codes are optional but recommended for Full service stream requests. To find the network code, see this article. - Bump IMA dependency to 3.37.0 which requires enabling core library desugaring. This must also be enabled by dependent apps too. See IMA's config notes.
- Support IMA DAI custom UI options in SSAI URI builder. Custom UI options for server side ad insertion include "Skippable" and "About This Ad" rendering support. The feature is currently available for selected publishers behind an allow list. This change also upgrades the IMA SDK version to 3.38.0 (release notes) to access the custom UI options API.
- Session:
- Add new parameter to
MediaSession.Callback.onPlaybackResumptionto indicate if the call happens to gather information only or to start playback (#1764). - Update
MediaSession.ControllerInfo.isTrustedto also declare controllers from the own app as trusted (#2542). - Add
MediaSessionService.triggerNotificationUpdateto manually trigger a notification update (#1833). - Add
ProgressListenerto custom command methods. - Change the default value for
MediaLibrarySession.Builder.setLibraryErrorReplicationModeto non fatal. - Add a
Contextparameter toMediaButtonReceiver.onForegroundServiceStartNotAllowedException(#2625). - Read the volume control ID from the platform
PlaybackInfoinstead of fetching it via binder. This ensures that playback type and volume control ID are read atomically and do match to each other. - Fix bug where
ACTION_UPkey events were filtered out before passing them to the callback for custom handling. This brings parity with what media1 did and the platform does (#2637). - Fix bug where
getCurrentTimeline()was called byPlayerWrappereven when the command isn't available (#2665). - Fix bug where a message was left in the message queue of the main looper which caused a memory leak after the service terminated (#2692).
- When connected to a legacy session app with a
MediaBrowser, custom commands are sent to the session only if the custom action is advertised as a custom action inPlaybackStateCompatof the legacy session. All other custom actions are sent to the service. - Implemented
onAudioSessionIdChangedto notify media controllers when an audio session ID is set by the session (#244). - Fix bug where
KEYCODE_HEADSETHOOKdid not start the player upon and media key eventIntentarriving inonStartCommand(). This is fixed by handling 'KEYCODE_HEADSETHOOK' just likeKEYCODE_MEDIA_PLAY_PAUSE(#2816). - Fix a bug where Surface size was not communicated between the session
and the controller, resulting in the failure to apply video effects in
demo-session. If you are using a controller, this might be a breaking
change if your player cannot handle a
setVideoSurfaceHoldercall. - Fix propagation of non-
StringCharSequencemetadata values like span-styled strings (#2853).
- Add new parameter to
- UI:
- Add
ProgressStateWithTickIntervalclass and the correspondingrememberProgressStateWithTickIntervalComposable tomedia3-ui-composemodule. This state holder is used indemo-composeto display the current position and duration in text form. - Add
MuteButtonStatetoui-composethat handles muting of thePlayervolume. This state holder is used indemo-composeto display mute/unmute toggle button. - Add
ProgressStateWithTickCountclasses and the correspondingrememberProgressStateWithTickCountComposable tomedia3-ui-composemodule. This state holder is used indemo-composeto display progress as a horizontal read-only progress bar. - Add
ContentFrameComposable tomedia3-ui-composewhich combinesPlayerSurfacemanagement with aspect ratio resizing and covering with a shutter. - Work around a known API 34 platform bug causing stretched/cropped videos
when using
SurfaceViewinside a ComposeAndroidViewand hence affectingContentFrameandPlayerSurfaceComposables withSURFACE_TYPE_SURFACE_VIEW(#1237, #2811). - Create a new
media3-ui-compose-material3module and add Material3-themed Composables (PlayPauseButton, NextButton, PreviousButton, SeekBackButton, SeekForwardButton, RepeatButton, ShuffleButton, MuteButton) to it. - Add support for placing a media route button in the
PlayerView.
- Add
- HLS extension:
- Parse HLS interstitial skip attributes.
- Map skip control attributes from the HLS playlist and the asset list
document into the
AdPlaybackStatefor public access. - Fix bug where the start time of the playlist was dropped when the EXT-X-PROGRAM-START-DATE tag defining the start time was removed from a playlist (#2760).
- Use binary search to find the segment index of a given position in the playlist (#2826.
- DASH extension:
- Fix
UnsupportedOperationExceptionwhen playing DASH streams with a non-hierarchicaldata:URI manifest (#2688). - Reset
LiveConfigurationto the value provided by theMediaItemof theDashMediaSourcewhen released and when the media item is updated by the user (#2606). - Avoid crashes caused by invalid manifest updates that were not reported as player errors (#2805).
- Fix
- RTSP extension:
- Handle error of missing RTP packets when processing fragmented NAL units for H264 and H265 (#2613).
- Decoder extensions (FFmpeg, VP9, AV1, etc.):
- AV1 Extension: The AV1 software decoder now uses the high-performance
dav1dlibrary, replacing the previouslibgav1implementation for improved decoding speed.
- AV1 Extension: The AV1 software decoder now uses the high-performance
- Cast extension:
- Add
CastPlayer.Builder, which enablesCastPlayerto do both local and Cast playback. To keep the oldCastPlayerbehavior of supporting only Cast playback, you can useRemoteCastPlayer. The pre-existingCastPlayerconstructors keep their old behavior, but are deprecated in favour of using theCastPlayerorRemoteCastPlayerbuilders instead. - Stop enforcing a non-null mime type in
DefaultMediaItemConverter. - Use
MediaItem.mediaMetadata.mediaTypeto infer the Cast MEDIA_TYPE to use inDefaultCastOptionsProvider#toMediaQueueItem, when available. - Enable remote to local transfers in
DefaultCastOptionsProvider. - Add support for Cast in the Session demo.
- Add support for displaying a media route button on a Composable UI.
- Add support for displaying a media route button on an action bar menu.
- Add support for displaying a media route button as a View UI.
- Add
- Test Utilities:
- Add maximum time diff for the auto-advancing behavior of
FakeClock. It defaults to 1 second, but is configurable viaFakeClock.Builder. - Add maximum time diff between messages for
RobolectricUtil.runMainLooperUntil(andrunLooperUntil). It defaults to 1 second, but is configurable via new overloads of these methods. - Move
CapturingRenderersFactoryfromtest-utilstotest-utils-robolectric.
- Add maximum time diff for the auto-advancing behavior of
- Remove deprecated symbols:
- Remove deprecated
DefaultPreloadManagerconstructor. UseDefaultPreloadManager.Builderinstead. - Removed deprecated
EditedMediaItemSequenceconstructors. UseEditedMediaItemSequence.Builderinstead.
- Remove deprecated
Version 1.8.0
Version 1.8.0
July 30, 2025
Version 1.8.0 contains these commits.
- Common Library:
- Add support for replacing the player in
ForwardingSimpleBasePlayer.
- Add support for replacing the player in
- ExoPlayer:
- Add getter for shuffle mode to the
ExoPlayerinterface (#2522). - More clearly throw an exception if
DefaultAudioSinkis accessed from multiple threads. If this happens due to a call toRendererCapabilities.getFormatSupportoutside of the player, make sure to call this method on the same thread as ExoPlayer's playback thread or use a different instance than the one used for playback (#1191). - Fix bug where non-stereo audio formats on TVs may be marked as
unsupported by
DefaultTrackSelector. - Ensure the last frame is correctly rendered when using MediaCodec's
DECODE_ONLYflag (which is enabled by default in scrubbing mode). - Add support for using the virtual device ID from the
Contextpassed toExoPlayer.Builder. - Enable dynamic scheduling by default in scrubbing mode.
- Avoid unnecessary reload of a source when seeking to the end of an item.
- Use
MediaCodec.BUFFER_FLAG_DECODE_ONLYby default in scrubbing mode. - Throw
IllegalStateExceptionwhenPreloadMediaSourceis played by anExoPlayerwith a playback thread that is different than the preload thread (#2495). - Add
cloneAndMovetoShuffleModewith a default implementation (#2226). - Change default behavior of
Renderer.getMinDurationToProgressUsto return a larger value if no call torenderis required. - Fix bug where internal scheduling delayed last frame when seeking to the
end while paused. For now, the bug fix only takes effect if
ExoPlayer.Builder.experimentalSetDynamicSchedulingEnabledis enabled. - Add
ExoPlayer.setScrubbingModeEnabled(boolean)method. This optimizes the player for many frequent seeks (for example, from a user dragging a scrubber bar around). The behavior of scrubbing mode can be customized withsetScrubbingModeParameters(..)onExoPlayerandExoPlayer.Builder. - Allow customizing fractional seek tolerance in scrubbing mode.
- Increase codec operating rate in scrubbing mode.
- Fix bug where prepare errors in the content of
AdsMediaSourcemay be never reported (#2337). - Fix memory leak in
MergingMediaSource, for example used when sideloading subtitles (#2338). - Allow
CmcdConfiguration.Factoryto returnnullto disable CMCD logging for specific media items (#2386). - Increase default image buffer size from 128kB (copy-paste mistake from text tracks) to 26MB, which is large enough for 50MP Ultra HDR images (#2417).
- Add
PreCacheHelperthat allows apps to pre-cache a single media with specified start position and duration. - Add support of preloading from specified position in
DefaultPreloadManager.
- Add getter for shuffle mode to the
- Transformer:
- Add
CodecDbLitethat enables chipset specific optimizations of video encoding settings. - Add
setEnableCodecDbLiteflag to theDefaultEncoderFactoryto enable CodecDB Lite settings optimization. By default, this flag is set to false. - Filling an initial gap (added via
addGap()) with silent audio now requires explicitly settingexperimentalSetForceAudioTrack(true)inEditedMediaItemSequence.Builder. If the gap is in the middle of the sequence, then this flag is not required. - Move
Muxerinterface frommedia3-transformertomedia3-muxer. - Make setting
MediaItem.Builder().setImageDuration(long)mandatory to import a media item as an image. - Add
Transformer.Builder().experimentalSetMp4EditListTrimEnabled(boolean)which includes an MP4 edit list when trimming to instruct players to ignore samples between the key frame before the trim start point, and the trim start point. - Update Composition Demo app to use Kotlin and Jetpack Compose, and add a
custom
VideoCompositorSettingsto arrange sequences into a 2x2 or PiP layout.
- Add
- Extractors:
- Parse metadata from fragmented MP4 files (#2084).
- JPEG: Support motion photos that don't have an Exif segment at the start (#2552).
- Add support for seeking in fragmented MP4 with multiple
sidxatoms. This behavior can be enabled using theFLAG_MERGE_FRAGMENTED_SIDXflag onFragmentedMp4Extractor(#9373). - Ignore empty seek tables in FLAC files (including those containing only placeholder seek points), and fall back to binary search seeking if the duration of the file is known (#2327).
- Fix parsing of H.265 SEI units to fully skip unrecognized SEI types (#2456).
- Update
WavExtractorto use the header extension's SubFormat data for the audio format when parsing aWAVE_FORMAT_EXTENSIBLEtype file. - MP4: Add support for
ipcmandfpcmboxes defining raw PCM audio tracks (64-bit floating point PCM is not supported). - MP4: Handle the rotation part of
tkhdtransformation matrices that both rotate and reflect the video. This ensures that reflected videos taken by the iPhone front facing camera display the right way up, but incorrectly reflected in the y-axis (#2012). - MP3: Use duration and data size from unseekable Xing, VBRI and similar
variable bitrate metadata when falling back to constant bitrate seeking
due to
FLAG_ENABLE_CONSTANT_BITRATE_SEEKING(_ALWAYS)(#2194).
- Audio:
- Fix bug where
AnalyticsListener.onAudioPositionAdvancingis not called when the audio playback is started very close to the end of the media. - Add support for all linear PCM sample formats in
ChannelMappingAudioProcessorandTrimmingAudioProcessor. - Add support for audio gaps in
CompositionPlayer. - Remove spurious call to
BaseAudioProcessor#flush()fromBaseAudioProcessor#reset(). - Allow constant power upmixing/downmixing in DefaultAudioMixer.
- Make
ChannelMappingAudioProcessor,TrimmingAudioProcessorandToFloatPcmAudioProcessorpublic (#2339). - Use
AudioTrack#getUnderrunCount()inAudioTrackPositionTrackerto detect underruns inDefaultAudioSinkinstead of best-effort estimation. - Improve audio timestamp smoothing for unexpected position drift from the audio output device.
- Fix bug where A/V sync is broken for the first 10 seconds after resuming from pause when connected to Bluetooth devices.
- Fix bug that
AnalyticsListener.onAudioPositionAdvancingwas not reporting the time when the audio started advancing but the time of the first measurement. - Fix recovery to multichannel audio after fallback to stereo audio on some devices (#2258).
- Fix bug where
- Video:
- Extend detached surface workaround to "lenovo" and "motorola" devices (#2059).
- Improve smooth video frame release at startup when audio samples don't start at exactly the requested position.
- Extend detached surface workaround to "realme" devices (#2059).
- Add experimental
ExoPlayerAPI to include theMediaCodec.BUFFER_FLAG_DECODE_ONLYflag when queuing decode-only input buffers. This flag will signal the decoder to skip the decode-only buffers thereby resulting in faster seeking. Enable it withDefaultRenderersFactory.experimentalSetEnableMediaCodecBufferDecodeOnlyFlag. - Improve codec performance checks for software video codecs. This may
lead to some additional tracks being marked as
EXCEEDS_CAPABILITIES. - Fix VP9 Widevine playback errors on some devices (#2408).
- Text:
- Add support for VobSub tracks in MP4 files (#2510).
- Fix a playback stall when a subtitle segment initially fails to load and later loads successfully, followed by several empty subtitle segments (#2517).
- Fix SSA and SubRip to display an in-progress cue when enabling subtitles (#2309).
- Fix playback getting stuck when switching from a stream with a subtitle error to a live stream with an empty subtitle track (#2328).
- Fix garbled CEA-608 subtitles when playing H.262 streams containing B-frames (#2372).
- Add support for SSA subtitles with
CodecId = S_TEXT/SSAin Matroska files. PreviouslyMatroskaExtractoronly supportedCodecId = S_TEXT/ASSwhich is meant to represent the 'advanced' (v4+) variant of SubStation Alpha subtitles (but ExoPlayer's parsing logic is the same for both variants) (#2384). - Add support for the
layerproperty in SubStation Alpha (SSA) subtitle files which is used to define the z-order of cues when more than one is shown on screen at the same time (#2124).
- Metadata:
- Added support for retrieving media duration and
TimelinetoMetadataRetrieverand migrated it to an instance-based,AutoCloseableAPI. Use the newBuilderto create an instance for aMediaItem, then callretrieveTrackGroups(),retrieveTimeline(), andretrieveDurationUs()to getListenableFutures for the metadata. The previous static methods are now deprecated (#2462).
- Added support for retrieving media duration and
- Image:
- Limit decoded bitmaps to the display size in
BitmapFactoryImageDecoder, to avoid an app crashing withCanvas: trying to draw too large bitmap.fromPlayerViewwhen trying to display very large (e.g. 50MP) images. - Change the signature of
DefaultRenderersFactory.getImageDecoderFactory()to take aContextparameter. - Align the max bitmap output size used in
CompositionPlayerwith that already used inTransformer(meaningCompositionPlayerdoes not consider the display size when decoding bitmaps, unlikeExoPlayer).
- Limit decoded bitmaps to the display size in
- DRM:
- Add new overload of
OfflineLicenseHelper.newWidevineInstanceaccepting aMediaItem.DrmConfigurationso that HTTP request headers can be applied correctly (#2169).
- Add new overload of
- Effect:
- Add
Presentation.createForShortSide(int)that creates aPresentationthat ensures the shortest side always matches the given value, regardless of input orientation.
- Add
- Muxers:
- Fix a bug where correct sample flags were not set for audio samples in fragmented MP4.
writeSampleData()API now uses muxer specificBufferInfoclass instead ofMediaCodec.BufferInfo.- Add
Muxer.Factory#supportsWritingNegativeTimestampsInEditListwhich defaults to false.
- IMA extension:
- Fix a bug where a load error in one ad may accidentally invalidate another ad group.
- Fix bug where ad groups after the end of a VOD window stalled playback.
Ads groups with a start time after the window are not enqueued into the
MediaPeriodQueueanymore (#2215).
- Session:
- Fix bug where connections from third-party non-privileged Media3 controllers are ignored.
- Remove check for available commands when sending custom commands to a
legacy
MediaBrowserServiceCompat. This is in parity with the behavior of legacy controllers/browsers when connected to a legacy app. - Fix a bug that causes a player's first playback error to be incorrectly treated as a persistent custom exception. This prevents the application from recovering.
- Fix bug where some controller changes that are not handled by the
session may cause
IllegalStateExceptions. - Fix bug where controller actions that are not handled by the session may leave the controller in an invalid state.
- Fix StrictMode unsafe launch violation warning (#2330).
- Fix bug where calling
setSessionExtrasfrom the main thread when running the player from a different application thread then the main thread caused anIllegalStateException(#2265). - Don't automatically show a notification if a player is set up with media
items without preparing or playing them
(#2423https://github.com/androidx/media/issues/2423). This behavior
is configurable via
MediaSessionService.setShowNotificationForIdlePlayer. - Add custom
PlaybackExceptionfor all or selected controllers. - Fix bug where seeking in a live stream on a
MediaControllercan cause anIllegalArgumentException. - For live streams, stop publishing a playback position and the ability to seek in the current item for platform media controllers, to avoid position artefacts in the Android Auto UI (and other controllers using this information from the platform media session) (#1758).
- Fix a bug where passing null into
getLibraryRootof aMediaBrowserconnected to a legacyMediaBrowserServiceCompatproduced aNullPointerException. - Fix a bug where sending custom actions, a search result or a getItem
request crashed the legacy session app with a
ClassNotFoundException. - Fix a bug where
MediaItem.LocalConfiguration.uriwas shared to the platform sessions'sMediaMetadata. To intentionally share a URI to allow controllers to re-request the media, setMediaItem.RequestMetadata.mediaUriinstead.
- UI:
- Fix bug where
PlayerSurfaceinside re-usable components likeLazyColumndidn't work correctly (#2493). - Fix a Compose bug which resulted in a gap between setting the initial button states and observing the change in state (e.g. icon shapes or being enabled). Any changes made to the Player outside of the observation period are now picked up (#2313).
- Add state holders and composables to the
media3-ui-composemodule forSeekBackButtonStateandSeekForwardButtonState. - Add support for ExoPlayer's scrubbing mode to
PlayerControlView. When enabled, this puts the player into scrubbing mode when the user starts dragging the scrubber bar, issues aplayer.seekTocall for every movement, and then exits scrubbing mode when the touch is lifted from the screen. This integration can be enabled with eithertime_bar_scrubbing_enabled = truein XML or thesetTimeBarScrubbingEnabled(boolean)method from Java/Kotlin. - Make
PlayerSurfaceaccept a nullablePlayerargument.
- Fix bug where
- Downloads:
- Add partial download support for progressive streams. Apps can prepare a
progressive stream with
DownloadHelper, and request aDownloadRequestfrom the helper with specifying the time-based media start and end positions that the download should cover. The returnedDownloadRequestcarries the resolved byte range, with which aProgressiveDownloadercan be created and download the content correspondingly. - Add
DownloadHelper.Factorywith which the staticDownloadHelper.forMediaItem()methods are replaced. - Add
FactoryforSegmentDownloaderimplementations. - Add partial download support for adaptive streams. Apps can prepare an
adaptive stream with
DownloadHelper, and request aDownloadRequestfrom the helper with specifying the time-based media start and end positions that the download should cover. The returnedDownloadRequestcarries the resolved time range, with which a concreteSegmentDownloadercan be created and download the content correspondingly.
- Add partial download support for progressive streams. Apps can prepare a
progressive stream with
- Cronet extension:
- Add automatic cookie handling (#5975).
- HLS extension:
- Fix bug where
HlsSampleStreamWrapperattempts to seek inside buffer when there are no chunks available in the buffer #2598. - Fix bug where track selection changes after loading low-latency parts and preload hints can cause playback to get stuck or freeze (#2299).
- Prevent excessive reloads by waiting for half the target duration when
CAN-BLOCK-RELOAD=YESis not honored by the server (#2317). - Fix bug where playback was stalled when starting an interstitials stream before a mid roll and asset list resolution was attempted for the wrong ad (#2558).
- Fix playlist parsing to accept
\f(form feed) in quoted string attribute values (#2420). - Support updating interstitials with the same ID (#2427).
- Fix bug where playlist load errors are sometimes not propagated once a live stream runs out of segments to load (#2401https://github.com/androidx/media/issues/2401).
- Group subtitle renditions by NAME tag, similar to how audio renditions are grouped already (#1666).
- Support X-ASSET-LIST and live streams with
HlsInterstitialsAdsLoader.
- Fix bug where
- DASH extension:
- Fix issue where trick-play adaptation set is merged with its main
adaptation set to form an invalid
TrackGroup(#2148). - Fix bug where shortening a DASH period duration can throw an exception when samples beyond the new duration have already been read by the rendering pipeline (#2440).
- Fix bug where redirect wasn't followed when using CMCD query parameters (#2475).
- Fix issue where trick-play adaptation set is merged with its main
adaptation set to form an invalid
- RTSP extension:
- Decoder extensions (FFmpeg, VP9, AV1, etc.):
- Fix bug where
DefaultTrackSelector.setAllowInvalidateSelectionsOnRendererCapabilitiesChangehas no effect for audio decoder extensions (#2258).
- Fix bug where
- Cast extension:
- Test Utilities:
- Add
advance(player).untilPositionAtLeastanduntilMediaItemIndextoTestPlayerRunHelperin order to advance the player until a specified position is reached. In most cases, these methods are more reliable than the existinguntilPositionanduntilStartOfMediaItemmethods. - Move
FakeDownloadertotest-utils-robolectricmodule for reuse in other tests. - Removed
transformer.TestUtil.addAudioDecoders(String...),transformer.TestUtil.addAudioEncoders(String...), andtransformer.TestUtil.addAudioEncoders(ShadowMediaCodec.CodecConfig, String...). UseShadowMediaCodecConfigto configure shadow encoders and decoders instead. - Replaced the "exotest" prefix with "media3" in codec names reported by
ShadowMediaCodecConfig.
- Add
- Remove deprecated symbols:
- Removed deprecated
SegmentDownloaderconstructorSegmentDownloader(MediaItem, Parser<M>, CacheDataSource.Factory, Executor)and the corresponding constructors in its subclassesDashDownloader,HlsDownloaderandSsDownloader. - Removed deprecated
Player.hasNext(),Player.hasNextWindow(). UsePlayer.hasNextMediaItem()instead. - Removed deprecated
Player.next(). UsePlayer.seekToNextMediaItem()instead. - Removed deprecated
Player.seekToPreviousWindow(). UsePlayer.seekToPreviousMediaItem()instead. - Removed deprecated
Player.seekToNextWindow(). UsePlayer.seekToNextMediaItem()instead. - Removed deprecated
BaseAudioProcessorinexoplayermodule. UseBaseAudioProcessorundercommonmodule. - Remove deprecated
MediaCodecVideoRendererconstructorMediaCodecVideoRenderer(Context, MediaCodecAdapter.Factor, MediaCodecSelector, long, boolean, @Nullable Handler, @Nullable VideoRendererEventListener, int, float, @Nullable VideoSinkProvider).
- Removed deprecated
Version 1.8.0-rc02
July 24, 2025
Use the 1.8.0 stable version.
Version 1.8.0-rc01
July 16, 2025
Use the 1.8.0 stable version.
Version 1.8.0-beta01
July 2, 2025
Use the 1.8.0 stable version.
Version 1.8.0-alpha01
May 19th, 2025
Use the 1.8.0 stable version.
Version 1.7.0
Version 1.7.1
May 16th, 2025
This release has the same code as 1.6.1 and is being released to ensure it appears as a 'newer' release than 1.7.0, which was an alpha release accidentally tagged as stable (see below).
Version 1.7.0
May 16th, 2025
This release should have been 1.7.0-alpha01, but was accidentally tagged
1.7.0 (i.e. stable) on maven.google.com. Please do not use it. Stay on
1.6.1 or upgrade to 1.7.1 (which has the same code as 1.6.1).
Version 1.6.0
1.6.1
April 14th, 2025
androidx.media3:media3-*:1.6.1 is released.
Version 1.6.1 contains
these commits.
- Common Library:
- Add
PlaybackParameters.withPitch(float)method for easily copying aPlaybackParameterswith a newpitchvalue (#2257).
- Add
- ExoPlayer:
- Fix issue where media item transition fails due to recoverable renderer error during initialization of the next media item (#2229).
- Fix issue where
ProgressiveMediaPeriodthrows anIllegalStateExceptionasPreloadMediaSourceattempts to call itsgetBufferedDurationUs()before it is prepared (#2315). - Fix sending
CmcdDatain manifest requests for DASH, HLS, and SmoothStreaming (#2253). - Ensure
AdPlaybackState.withAdDurationsUs(long[][])can be used after ad groups have been removed. The user still needs to pass in an array of durations for removed ad groups which can be empty or null (#2267).
- Extractors:
- MP4: Parse
alternate_groupfrom thetkhdbox and expose it as anMp4AlternateGroupDataentry in each track'sFormat.metadata(#2242).
- MP4: Parse
- Audio:
- Fix offload issue where the position might get stuck when playing a playlist of short content (#1920).
- Session:
- Lower aggregation timeout for platform
MediaSessioncallbacks from 500 to 100 milliseconds and add an experimental setter to allow apps to configure this value. - Fix issue where notifications reappear after they have been dismissed by the user (#2302).
- Fix a bug where the session returned a single-item timeline when the
wrapped player is actually empty. This happened when the wrapped player
doesn't have
COMMAND_GET_TIMELINEavailable whileCOMMAND_GET_CURRENT_MEDIA_ITEMis available and the wrapped player is empty (#2320). - Fix a bug where calling
MediaSessionService.setMediaNotificationProvideris silently ignored after other interactions with the service likesetForegroundServiceTimeoutMs(#2305).
- Lower aggregation timeout for platform
- UI:
- Enable
PlayerSurfaceto work withExoPlayer.setVideoEffectsandCompositionPlayer. - Fix bug where
PlayerSurfacecan't be recomposed with a newPlayer.
- Enable
- HLS extension:
- Fix issue where chunk duration wasn't set in
CmcdDatafor HLS media, causing an assertion failure when processing encrypted media segments (#2312).
- Fix issue where chunk duration wasn't set in
- RTSP extension:
- Add support for URI with RTSPT scheme as a way to configure the RTSP session to use TCP (#1484).
- Cast extension:
- Add support for playlist metadata (#2235).
1.6.0
March 26, 2025
androidx.media3:media3-*:1.6.0 is released.
Version 1.6.0 contains
these commits.
- Common Library:
- Add
AudioManagerCompatandAudioFocusRequestCompatto replace the equivalent classes inandroidx.media. - Upgrade Kotlin from 1.9.20 to 2.0.20 and use Compose Compiler Gradle plugin. Upgrade KotlinX Coroutines library from 1.8.1 to 1.9.0.
- Remove
Format.toBundle(boolean excludeMetadata)method, useFormat.toBundle()instead. - Fix bug in
SimpleBasePlayerwhere setting a newcurrentMediaItemIndexinStateaftersetPlaylistwithnullMediaMetadatadoes not reevaluate the metadata (#1940). - Change
SimpleBasePlayer.Stateaccess from protected to public to make it easier to handle updates in other classes (#2128).
- Add
- ExoPlayer:
- Add
MediaExtractorCompat, a new class that provides equivalent features to platformMediaExtractor. - Add experimental 'ExoPlayer' pre-warming support for playback using
MediaCodecVideoRenderer. You can configureDefaultRenderersFactorythroughexperimentalSetEnableMediaCodecVideoRendererPrewarmingto provide a secondaryMediaCodecVideoRenderertoExoPlayer. If enabled,ExoPlayerpre-processes the video of consecutive media items during playback to reduce media item transition latency. - Reduce default values for
bufferForPlaybackMsandbufferForPlaybackAfterRebufferMsinDefaultLoadControlto 1000 and 2000 ms respectively. - Initialize
DeviceInfoand device volume asynchronously (if enabled usingsetDeviceVolumeControlEnabled). These values aren't available instantly afterExoPlayer.Builder.build(), andPlayer.Listenernotifies changes throughonDeviceInfoChangedandonDeviceVolumeChanged. - Initial audio session ID is no longer immediately available after
creating the player. You can use
AnalyticsListener.onAudioSessionIdChangedto listen to the initial update if required. - Consider language when selecting a video track. By default, select a
'main' video track that matches the language of the selected audio
track, if available. Explicit video language preferences can be
expressed with
TrackSelectionParameters.Builder.setPreferredVideoLanguage(s). - Add
selectedAudioLanguageparameter toDefaultTrackSelector.selectVideoTrack()method. - Add
retryCountparameter toMediaSourceEventListener.onLoadStartedand correspondingMediaSourceEventListener.EventDispatchermethods. - Fix bug where playlist items or periods in multi-period DASH streams with durations that don't match the actual content could cause frame freezes at the end of the item (#1698).
- Move
BasePreloadManager.Listenerto a top-levelPreloadManagerListener. RenderersFactory.createSecondaryRenderercan be implemented to provide secondary renderers for pre-warming. Pre-warming enables quicker media item transitions during playback.- Enable sending
CmcdDatafor manifest requests in adaptive streaming formats DASH, HLS, and SmoothStreaming (#1951). - Provide
MediaCodecInfoof the codec that will be initialized inMediaCodecRenderer.onReadyToInitializeCodec(#1963). - Change
AdsMediaSourceto allow theAdPlaybackStatesto grow by appending ad groups. Invalid modifications are detected and throw an exception. - Fix issue where additional decode-only frames may be displayed in quick succession when transitioning to content media after a mid-roll ad.
- Make
DefaultRenderersFactoryadd twoMetadataRendererinstances to enable apps to receive two different schemes of metadata by default. - Reevaluate whether the ongoing load of a chunk should be cancelled when playback is paused (#1785).
- Add option to
ClippingMediaSourceto allow clipping in unseekable media. - Fix bug where seeking with pre-warming could block following media item transition.
- Fix a bug where
ExoPlayer.isLoading()remainstruewhile it has transitioned toSTATE_IDLEorSTATE_ENDED(#2133). - Add
lastRebufferRealtimeMstoLoadControl.Parameter(#2113).
- Add
- Transformer:
- Add support for transmuxing into alternative backward compatible formats.
- Add support for transcoding and transmuxing Dolby Vision (profile 8) format.
- Update parameters of
VideoFrameProcessor.registerInputStreamandVideoFrameProcessor.Listener.onInputStreamRegisteredto useFormat. - Generate HDR static metadata when using
DefaultEncoderFactory. - Enable support for Android platform diagnostics using
MediaMetricsManager. Transformer forwards editing events and performance data to the platform, which helps to provide system performance and debugging information on the device. This data may also be collected by Google if sharing usage and diagnostics data is enabled by the user of the device. Apps can opt-out of contributing to platform diagnostics for Transformer withTransformer.Builder.setUsePlatformDiagnostics(false). - Split
InAppMuxerintoInAppMp4MuxerandInAppFragmentedMp4Muxer. You useInAppMp4Muxerto produce a non-fragmented MP4 file, whileInAppFragmentedMp4Muxeris for producing a fragmented MP4 file. - Move
Muxerinterface frommedia3-muxertomedia3-transformer. - Add
MediaProjectionAssetLoader, which provides media from aMediaProjectionfor screen recording, and add support for screen recording to the Transformer demo app. - Add
#getInputFormat()toCodecinterface. - Shift the responsibility to release the
GlObjectsProvideronto the caller inDefaultVideoFrameProcessorandDefaultVideoCompositorwhen possible.
- Extractors:
- AVI: Fix handling of files with constant bitrate compressed audio where the stream header stores the number of bytes instead of the number of chunks.
- Fix handling of NAL units with lengths expressed in 1 or 2 bytes (rather than 4).
- Fix
ArrayIndexOutOfBoundsExceptionin MP4 edit lists when the edit list starts at a non-sync frame with no preceding sync frame (#2062). - Fix issue where TS streams can get stuck on some devices (#2069).
- FLAC: Add support for 32-bit FLAC files. Previously these would fail to
play with
IllegalStateException: Playback stuck buffering and not loading(#2197).
- Audio:
- Fix
onAudioPositionAdvancingto be called when playback resumes (previously it was called when playback was paused). - Don't bypass
SonicAudioProcessorwhenSpeedChangingAudioProcessoris configured with default parameters. - Fix underflow in
Sonic#getOutputSize()that could causeDefaultAudioSinkto stall. - Fix
MediaCodecAudioRenderer.getDurationToProgressUs()andDecoderAudioRenderer.getDurationToProgressUs()so that seeks correctly reset the provided durations. - Make
androidx.media3.common.audio.SonicAudioProcessorfinal. - Add support for float PCM to
ChannelMappingAudioProcessorandTrimmingAudioProcessor.
- Fix
- Video:
- Change
MediaCodecVideoRenderer.shouldUsePlaceholderSurfaceto protected so that applications can override to block usage of placeholder surfaces (#1905). - Add experimental
ExoPlayerAV1 sample dependency parsing to speed up seeking. Enable it with the newDefaultRenderersFactory.experimentalSetParseAv1SampleDependenciesAPI. - Add experimental
ExoPlayerAPI to drop lateMediaCodecVideoRendererdecoder input buffers that are not depended on. Enable it withDefaultRenderersFactory.experimentalSetLateThresholdToDropDecoderInputUs. - Fix issue where a player without a surface was ready immediately and very slow decoding any pending frames (#1973).
- Exclude Xiaomi and OPPO devices from detached surface mode to avoid screen flickering (#2059).
- Change
- Text:
- Add support for VobSub subtitles (#8260).
- Stop eagerly loading all subtitle files configured with
MediaItem.Builder.setSubtitleConfigurations, and instead only load one if it is selected by track selection (#1721). - TTML: Add support for referencing
tts:originandtts:extentusingstyle(#2953). - Restrict WebVTT and SubRip timestamps to exactly 3 decimal places. Previously we incorrectly parsed any number of decimal places but always assumed the value was in milliseconds, leading to incorrect timestamps (#1997).
- Fix playback hanging when a playlist contains clipped items with CEA-608 or CEA-708 captions.
- Fix
IllegalStateExceptionwhen an SSA file contains a cue with zero duration (start and end time equal) (#2052). - Suppress (and log) subtitle parsing errors when subtitles are muxed into the same container as audio and video (#2052).
- Fix handling of multi-byte UTF-8 characters in WebVTT files using CR line endings (#2167).
- DRM:
- Fix
MediaCodec$CryptoException: Operation not supported in this configurationerror when playing ClearKey content on API < 27 devices (#1732).
- Fix
- Effect:
- Moved the functionality of
OverlaySettingsintoStaticOverlaySettings.OverlaySettingscan be subclassed to allow dynamic overlay settings.
- Moved the functionality of
- Muxers:
- Moved
MuxerExceptionout ofMuxerinterface to avoid a very long fully qualified name. - Renamed
setSampleCopyEnabled()method tosetSampleCopyingEnabled()in bothMp4Muxer.BuilderandFragmentedMp4Muxer.Builder. Mp4Muxer.addTrack()andFragmentedMp4Muxer.addTrack()now return aninttrack ID instead of aTrackToken.Mp4MuxerandFragmentedMp4Muxerno longer implementMuxerinterface.- Disable
Mp4Muxersample batching and copying by default. - Fix a bug in
FragmentedMp4Muxerthat creates a lot of fragments when only audio track is written.
- Moved
- Session:
- Keep foreground service state for an additional 10 minutes when playback
pauses, stops or fails. This allows users to resume playback within this
timeout without risking foreground service restrictions on various
devices. Note that just calling
player.pause()can no longer be used to stop the foreground service beforestopSelf()when overridingonTaskRemoved, useMediaSessionService.pauseAllPlayersAndStopSelf()instead. - Keep notification visible when playback enters an error or stopped state. The notification is only removed if the playlist is cleared or the player is released.
- Improve handling of Android platform MediaSession actions ACTION_PLAY and ACTION_PAUSE to only set one of them according to the available commands and also accept if only one of them is set.
- Add
Contextas a parameter toMediaButtonReceiver.shouldStartForegroundService(#1887). - Fix bug where calling a
Playermethod on aMediaControllerconnected to a legacy session dropped changes from a pending update. - Make
MediaSession.setSessionActivity(PendingIntent)accept null (#2109). - Fix bug where a stale notification stays visible when the playlist is cleared (#2211).
- Keep foreground service state for an additional 10 minutes when playback
pauses, stops or fails. This allows users to resume playback within this
timeout without risking foreground service restrictions on various
devices. Note that just calling
- UI:
- Add state holders and composables to the
media3-ui-composemodule forPlayerSurface,PresentationState,PlayPauseButtonState,NextButtonState,PreviousButtonState,RepeatButtonState,ShuffleButtonStateandPlaybackSpeedState.
- Add state holders and composables to the
- Downloads:
- Fix bug in
CacheWriterthat leaves data sources open and cache areas locked in case the data source throws anExceptionother thanIOException(#9760).
- Fix bug in
- HLS extension:
- Add a first version of
HlsInterstitialsAdsLoader. The ads loader reads the HLS interstitials of an HLS media playlist and maps them to theAdPlaybackStatethat is passed to theAdsMediaSource. This initial version only supports HLS VOD streams withX-ASSET-URIattributes. - Add
HlsInterstitialsAdsLoader.AdsMediaSourceFactory. Apps can use it to createAdsMediaSourceinstances that use anHlsInterstitialsAdsLoaderin a convenient and safe way. - Parse
SUPPLEMENTAL-CODECStag from HLS playlist to detect Dolby Vision formats (#1785). - Loosen the condition for seeking to sync positions in an HLS stream (#2209).
- Add a first version of
- DASH extension:
- Add AC-4 Level-4 format support for DASH (#1898).
- Fix issue when calculating the update interval for ad insertion in multi-period live streams (#1698).
- Parse
scte214:supplementalCodecsattribute from DASH manifest to detect Dolby Vision formats (#1785). - Improve handling of period transitions in live streams where the period contains media samples beyond the declared period duration (#1698).
- Fix issue where adaptation sets marked with
adaptation-set-switchingbut different languages or role flags are merged together (#2222).
- Decoder extensions (FFmpeg, VP9, AV1, etc.):
- Add the MPEG-H decoder module which uses the built-in MPEG-H decoder to decode MPEG-H audio (#1826).
- MIDI extension:
- Plumb custom
AudioSinkandAudioRendererEventListenerinstances intoMidiRenderer.
- Plumb custom
- Cast extension:
- Bump the
play-services-cast-frameworkdependency to 21.5.0 to fix aFLAG_MUTABLEcrash in apps targeting API 34+ on devices with Google Play services installed but disabled (#2178).
- Bump the
- Demo app:
- Extend
demo-composewith additional buttons and enhancePlayerSurfaceintegration with scaling and shutter support.
- Extend
- Remove deprecated symbols:
- Remove deprecated
AudioMixer.create()method. UseDefaultAudioMixer.Factory().create()instead. - Remove the following deprecated
Transformer.Buildermethods:setTransformationRequest(), usesetAudioMimeType(),setVideoMimeType(), andsetHdrMode()instead.setAudioProcessors(), set the audio processor in anEditedMediaItem.Builder.setEffects(), and pass it toTransformer.start()instead.setVideoEffects(), set video effect in anEditedMediaItem.Builder.setEffects(), and pass it toTransformer.start()instead.setRemoveAudio(), useEditedMediaItem.Builder.setRemoveAudio()to remove the audio from theEditedMediaItempassed toTransformer.start()instead.setRemoveVideo(), useEditedMediaItem.Builder.setRemoveVideo()to remove the video from theEditedMediaItempassed toTransformer.start()instead.setFlattenForSlowMotion(), useEditedMediaItem.Builder.setFlattenForSlowMotion()to flatten theEditedMediaItempassed toTransformer.start()instead.setListener(), useaddListener(),removeListener()orremoveAllListeners()instead.
- Remove the following deprecated
Transformer.Listenermethods:onTransformationCompleted(MediaItem), useonCompleted(Composition, ExportResult)instead.onTransformationCompleted(MediaItem, TransformationResult), useonCompleted(Composition, ExportResult)instead.onTransformationError(MediaItem, Exception), useonError(Composition, ExportResult, ExportException)instead.onTransformationError(MediaItem, TransformationException), useonError(Composition, ExportResult, ExportException)instead.onTransformationError(MediaItem, TransformationResult, TransformationException), useonError(Composition, ExportResult, ExportException)instead.onFallbackApplied(MediaItem, TransformationRequest, TransformationRequest), useonFallbackApplied(Composition, TransformationRequest, TransformationRequest)instead.
- Remove deprecated
TransformationResultclass. UseExportResultinstead. - Remove deprecated
TransformationExceptionclass. UseExportExceptioninstead. - Remove deprecated
Transformer.PROGRESS_STATE_NO_TRANSFORMATION. UseTransformer.PROGRESS_STATE_NOT_STARTEDinstead. - Remove deprecated
Transformer.setListener(). UseTransformer.addListener(),Transformer.removeListener()orTransformer.removeAllListeners()instead. - Remove deprecated
Transformer.startTransformation(). UseTransformer.start(MediaItem, String)instead. - Remove deprecated
SingleFrameGlShaderProgram. UseBaseGlShaderPrograminstead. - Remove
Transformer.flattenForSlowMotion. UseEditedMediaItem.flattenForSlowMotioninstead. - Removed
ExoPlayer.VideoComponent,ExoPlayer.AudioComponent,ExoPlayer.TextComponentandExoPlayer.DeviceComponent. - Removed
androidx.media3.exoplayer.audio.SonicAudioProcessor. - Removed the following deprecated
DownloadHelpermethods:- Constructor
DownloadHelper(MediaItem, @Nullable MediaSource, TrackSelectionParameters, RendererCapabilities[]), useDownloadHelper(MediaItem, @Nullable MediaSource, TrackSelectionParameters, RendererCapabilitiesList)instead. getRendererCapabilities(RenderersFactory), equivalent functionality can be achieved by creating aDefaultRendererCapabilitiesListwith aRenderersFactory, and callingDefaultRendererCapabilitiesList.getRendererCapabilities().
- Constructor
- Removed
PlayerNotificationManager.setMediaSessionToken(MediaSessionCompat)method. UsePlayerNotificationManager.setMediaSessionToken(MediaSession.Token)and pass in(MediaSession.Token) compatToken.getToken()instead.
- Remove deprecated
1.6.0-rc02
March 19, 2025
Use the 1.6.0 stable version.
1.6.0-rc01
March 12, 2025
Use the 1.6.0 stable version.
1.6.0-beta01
February 26, 2025
Use the 1.6.0 stable version.
Version 1.6.0-alpha03
February 06, 2025
Use the 1.6.0 stable version.
Version 1.6.0-alpha02
January 30, 2025
Use the 1.6.0 stable version.
Version 1.6.0-alpha01
December 20, 2024
Use the 1.6.0 stable version.
Version 1.5
Version 1.5.1
December 19, 2024
androidx.media3:media3-*:1.5.1 is released.
Version 1.5.1 contains these commits.
- ExoPlayer:
- Disable use of asynchronous decryption in MediaCodec to avoid reported codec timeout issues with this platform API (#1641).
- Extractors:
- MP3: Don't stop playback early when a
VBRIframe's table of contents doesn't cover all the MP3 data in a file (#1904).
- MP3: Don't stop playback early when a
- Video:
- Rollback of using
MediaCodecAdaptersupplied pixel aspect ratio values when provided while processingonOutputFormatChanged(#1371).
- Rollback of using
- Text:
- Fix bug in
ReplacingCuesResolver.discardCuesBeforeTimeUswhere the cue active attimeUs(started before but not yet ended) was incorrectly discarded (#1939).
- Fix bug in
- Metadata:
- Extract disc/track numbering and genre from Vorbis comments into
MediaMetadata(#1958).
- Extract disc/track numbering and genre from Vorbis comments into
Version 1.5.0
November 27, 2024
androidx.media3:media3-*:1.5.0 is released.
Version 1.5.0 contains these commits.
- Common Library:
- Add
ForwardingSimpleBasePlayerthat allows forwarding to another player with small adjustments while ensuring full consistency and listener handling (#1183). - Replace
SimpleBasePlayer.State.playlistbygetPlaylist()method. - Add override for
SimpleBasePlayer.State.Builder.setPlaylist()to directly specify aTimelineand currentTracksandMetadatainstead of building a playlist structure. - Increase
minSdkto 21 (Android Lollipop). This is aligned with all other AndroidX libraries. - Add
androidx.media3:media3-common-ktxartifact which provides Kotlin-specific functionality built on top of the Common library - Add
Player.listensuspending extension function to spin a coroutine to listen toPlayer.Eventsto themedia3-common-ktxlibrary. - Remove
@DoNotInlineannotations from manually out-of-lined inner classes designed to avoid runtime class verification failures. Recent versions of R8 now automatically out-of-line calls like these to avoid the runtime failures (so the manual out-of-lining is no longer required). All Gradle users of the library must already be a using a version of the Android Gradle Plugin that uses a version of R8 which does this, due tocompileSdk = 35. Users of the library with non-Gradle build systems will need to ensure their R8-equivalent shrinking/obfuscating step does a similar automatic out-of-lining process in order to avoid runtime class verification failures. This change has already been done in other AndroidX libraries.
- Add
- ExoPlayer:
MediaCodecRenderer.onProcessedStreamChange()can now be called for every media item. Previously it was not called for the first one. UseMediaCodecRenderer.experimentalEnableProcessedStreamChangedAtStart()to enable this.- Add
PreloadMediaSource.PreloadControl.onPreloadErrorto allowPreloadMediaSource.PreloadControlimplementations to take actions when error occurs. - Add
BasePreloadManager.Listenerto propagate preload events to apps. - Allow changing SNTP client timeout and retry alternative addresses on timeout (#1540).
- Remove
MediaCodecAdapter.Configuration.flagsas the field was always zero. - Allow the user to select the built-in speaker for playback on Wear OS API 35+ (where the device advertises support for this).
- Defer the blocking call to
Context.getSystemService(Context.AUDIO_SERVICE)until audio focus handling is enabled. This ensures the blocking call isn't done if audio focus handling is not enabled (#1616). - Allow playback regardless of buffered duration when loading fails (#1571).
- Add
AnalyticsListener.onRendererReadyChanged()to signal when individual renderers allow playback to be ready. - Fix
MediaCodec.CryptoExceptionsometimes being reported as an "unexpected runtime error" whenMediaCodecis operated in asynchronous mode (default behaviour on API 31+). - Pass
bufferedDurationUsinstead ofbufferedPositionUswithPreloadMediaSource.PreloadControl.onContinueLoadingRequested(). Also changesDefaultPreloadManager.Status.STAGE_LOADED_TO_POSITION_MStoDefaultPreloadManager.Status.STAGE_LOADED_FOR_DURATION_MS, apps then need to pass a value representing a specific duration from the default start position for which the corresponding media source has to be preloaded with this IntDef, instead of a position. - Add
ForwardingRendererimplementation that forwards all method calls to another renderer (1703). - Add playlist preloading for the next item in the playlist. Apps can
enable preloading by calling
ExoPlayer.setPreloadConfiguration(PreloadConfiguration)accordingly. By default preloading is disabled. When opted-in and to not interfere with playback,DefaultLoadControlrestricts preloading to start and continue only when the player is not loading for playback. Apps can change this behaviour by implementingLoadControl.shouldContinuePreloading()accordingly (like when overriding this method inDefaultLoadControl). The default implementation ofLoadControldisables preloading in case an app is using a custom implementation ofLoadControl. - Add method
MediaSourceEventListener.EventDispatcher.dispatchEvent()to allow invoking events of subclass listeners (1736). - Add
DefaultPreloadManager.Builderthat builds theDefaultPreloadManagerandExoPlayerinstances with consistently shared configurations. - Remove
Renderer[]parameter fromLoadControl.onTracksSelected()asDefaultLoadControlimplementation can retrieve the stream types fromExoTrackSelection[]. - Deprecated
DefaultLoadControl.calculateTargetBufferBytes(Renderer[], ExoTrackSelection[])and marked method as final to prevent overrides. The newDefaultLoadControl.calculateTargetBufferBytes(ExoTrackSelection[])should be used instead. - Report
MediaSourceEventListenerevents from secondary sources inMergingMediaSource. This will result in load start/error/cancelled/completed events being reported for sideloaded subtitles (those added withMediaItem.LocalConfiguration.subtitleConfigurations), which may appear as duplicate load events emitted fromAnalyticsListener. - Prevent subtitle & metadata errors from completely stopping playback.
Instead the problematic track is disabled and playback of the remaining
tracks continues
(#1722).
- In new subtitle handling (during extraction), associated parse (e.g.
invalid subtitle data) and load errors (e.g. HTTP 404) are emitted
via
onLoadErrorcallbacks. - In legacy subtitle handling (during rendering), only associated load
errors are emitted via
onLoadErrorcallbacks while parse errors are silently ignored (this is pre-existing behaviour).
- In new subtitle handling (during extraction), associated parse (e.g.
invalid subtitle data) and load errors (e.g. HTTP 404) are emitted
via
- Fix bug where playlist items or periods in multi-period DASH streams with durations that don't match the actual content could cause frame freezes at the end of the item (#1698).
- Add a setter to
SntpClientto set the max elapsed time since the last update after which the client is re-initialized (#1794).
- Transformer:
- Add
SurfaceAssetLoader, which supports queueing video data to Transformer via aSurface. ImageAssetLoaderreports unsupported input viaAssetLoader.onErrorinstead of throwing anIllegalStateException.- Make setting the image duration using
MediaItem.Builder.setImageDurationMsmandatory for image export. - Add export support for gaps in sequences of audio EditedMediaItems.
- Add
- Track Selection:
DefaultTrackSelector: Prefer object-based audio over channel-based audio when other factors are equal.
- Extractors:
- Allow
Mp4ExtractorandFragmentedMp4Extractorto identify H264 samples that are not used as reference by subsequent samples. - Add option to enable index-based seeking in
AmrExtractor. - Treat MP3 files with more than 128kB between valid frames as truncated
(instead of invalid). This means files with non-MP3 data at the end,
with no other metadata to indicate the length of the MP3 bytes, now stop
playback at the end of the MP3 data instead of failing with
ParserException: Searched too many bytes.{contentIsMalformed=true, dataType=1}(#1563). - Fix preroll sample handling for non-keyframe media start positions when processing edit lists in MP4 files (#1659).
- Improved frame rate calculation by using media duration from the
mdhdbox inMp4ExtractorandFragmentedMp4Extractor(#1531). - Fix incorrect scaling of
media_timein MP4 edit lists. Whilesegment_durationwas already correctly scaled using the movie timescale,media_timeis now properly scaled using the track timescale, as specified by the MP4 format standard (#1792). - Handle out-of-order frames in
endIndicescalculation for MP4 with edit list (#1797). - Fix media duration parsing in
mdhdbox of MP4 files to handle-1values (#1819). - Add support for identifying
h263box in MP4 files for H.263 video (#1821). - Add AC-4 Level-4 ISO base media file format support (#1265).
- Allow
- DataSource:
- Update
HttpEngineDataSourceto allow use starting at version S extension 7 instead of API level 34 (#1262). DataSourceContractTest: Assert thatDataSource.getUri()returns the resolved URI (as documented). Where this is different to the requested URI, tests can indicate this using the newDataSourceContractTest.TestResource.Builder.setResolvedUri()method.DataSourceContractTest: Assert thatDataSource.getUri()andgetResponseHeaders()return their 'open' value after a failed call toopen()(due to a 'not found' resource) and before a subsequentclose()call.- Overriding
DataSourceContractTest.getNotFoundResources()allows test sub-classes to provide multiple 'not found' resources, and to provide any expected headers too. This allows to distinguish between HTTP 404 (with headers) and "server not found" (no headers).
- Overriding
- Update
- Audio:
- Automatically configure CTA-2075 loudness metadata on the codec if present in the media.
- Ensure smooth volume ramp down when seeking.
- Fix pop sounds that may occur during seeks.
- Fix truncation error accumulation for Sonic's time-stretching/pitch-shifting algorithm.
- Fix bug in
SpeedChangingAudioProcessorthat causes dropped output frames.
- Video:
MediaCodecVideoRendereravoids decoding samples that are neither rendered nor used as reference by other samples.- On API 35 and above,
MediaCodecAdaptermay now receive anullSurfaceinconfigureand calls to a new methoddetachOutputSurfaceto remove a previously setSurfaceif the codec supports this (MediaCodecInfo.detachedSurfaceSupported). - Use
MediaCodecAdaptersupplied pixel aspect ratio values if provided when processingonOutputFormatChanged(#1371). - Add workaround for a device issue on Galaxy Tab S7 FE that causes 60fps secure H264 streams to be marked as unsupported (#1619).
- Add workaround for codecs that get stuck after the last sample without returning an end-of-stream signal.
- Text:
- Add a custom
VoiceSpanand populate it for WebVTT voice spans (#1632). - Ensure WebVTT in HLS with very large subtitle timestamps (which overflow
a 64-bit
longwhen represented as microseconds and multiplied by the90,000MPEG timebase) are displayed (#1763). - Support CEA-608 subtitles in Dolby Vision content (#1820).
- Fix playback hanging on DASH multi-period streams when CEA-608 subtitles are enabled (#1863).
- Add a custom
- Metadata:
- Assign the
C.TRACK_TYPE_METADATAtype to tracks containing icy or vnd.dvb.ait content.
- Assign the
- Image:
- Add
ExternallyLoadedImageDecoderfor simplified integration with external image loading libraries like Glide or Coil.
- Add
- DataSource:
- Add
FileDescriptorDataSource, a newDataSourcethat can be used to read from aFileDescriptor(#3757).
- Add
- Effect:
- Add
DefaultVideoFrameProcessorworkaround for minorSurfaceTexturescaling.SurfaceTexturemay include a small scaling that cuts off a 1-texel border around the edge of a cropped buffer. This is now handled such that output is closer to expected. - Speed up
DefaultVideoFrameProcessor.queueInputBitmap(). As a result, exporting images to videos withTransformeris faster.
- Add
- IMA extension:
- Fix bug where clearing the playlist may cause an
ArrayIndexOutOfBoundsExceptioninImaServerSideAdInsertionMediaSource. - Fix bug where server-side inserted DAI streams without a preroll can
result in an
ArrayIndexOutOfBoundsExceptionwhen playing past the last midroll (#1741).
- Fix bug where clearing the playlist may cause an
- Session:
- Add
MediaButtonReceiver.shouldStartForegroundService(Intent)to allow apps to suppress a play command coming in for playback resumption by overriding this method. By default, the service is always started and playback can't be suppressed without the system crashing the service with aForegroundServiceDidNotStartInTimeException(#1528). - Fix bug that caused custom commands sent from a
MediaBrowserbeing dispatched to theMediaSessionCompat.Callbackinstead of theMediaBrowserServiceCompatvariant of the method when connected to a legacy service. This prevented theMediaBrowserto receive the actual return value sent back by the legacy service (#1474). - Handle
IllegalArgumentExceptionthrown by devices of certain manufacturers when setting the broadcast receiver for media button intents (#1730). - Add command buttons for media items. This adds the Media3 API for what
was known as
Custom browse actionswith the legacy library withMediaBrowserCompat. Note that with Media3 command buttons for media items are available for both,MediaBrowserandMediaController. See Implement custom browse actions. - Fix bug where a Media3 controller was sometimes unable to let a session
app start a foreground service after requesting
play(). - Restrict
CommandButton.Builder.setIconUrito only accept content Uris. - Pass connection hints of a Media3 browser to the initial
MediaBrowserCompatwhen connecting to a legacyMediaBrowserCompat. The service can receive the connection hints passed in as root hints with the first call toonGetRoot(). - Fix bug where a
MediaBrowserconnected to a legacy browser service, didn't receive an error sent by the service after the browser has subscribed to aparentid. - Improve interoperability behavior, so that a Media3 browser that is
connected to a legacy
MediaBrowserServicedoesn't request the children of aparentIdtwice when subscribing to a parent.
- Add
- UI:
- Make the stretched/cropped video in
PlayerView-in-Compose-AndroidViewworkaround opt-in, due to issues with XML-based shared transitions. Apps usingPlayerViewinsideAndroidViewneed to callPlayerView.setEnableComposeSurfaceSyncWorkaroundin order to opt-in (#1237, #1594). - Add
setFullscreenButtonStatetoPlayerViewto allow updates of fullscreen button's icon on demand, i.e. out-of-band and not reactively to a click interaction (#1590, #184). - Fix bug where the "None" choice in the text selection is not working if there are app-defined text track selection preferences.
- Make the stretched/cropped video in
- DASH Extension:
- Add support for periods starting in the middle of a segment (#1440).
- Smooth Streaming Extension:
- Fix a
Bad magic number for Bundleerror when playing SmoothStreaming streams with text tracks (#1779).
- Fix a
- RTSP Extension:
- Decoder Extensions (FFmpeg, VP9, AV1, etc.):
- Add the IAMF decoder module, which provides support for playback of MP4
files containing IAMF tracks using the libiamf native library to
synthesize audio.
- Playback is enabled with a stereo layout as well as 5.1 with spatialization together with optional head tracking enabled, but binaural playback support is currently not available.
- Add 16 KB page support for decoder extensions on Android 15 (#1685).
- Add the IAMF decoder module, which provides support for playback of MP4
files containing IAMF tracks using the libiamf native library to
synthesize audio.
- Cast Extension:
- Stop cleaning the timeline after the CastSession disconnects, which enables the sender app to resume playback locally after a disconnection.
- Populate CastPlayer's
DeviceInfowhen aContextis provided. This enables linking theMediaSessionto aRoutingSession, which is necessary for integrating Output Switcher (#1056).
- Test Utilities:
DataSourceContractTestnow includes tests to verify:- Input stream
read positionis updated. - Output buffer
offsetis applied correctly.
- Input stream
- Demo app
- Resolve the memory leaks in demo short-form app (#1839).
- Remove deprecated symbols:
- Remove deprecated
Player.hasPrevious,Player.hasPreviousWindow(). UsePlayer.hasPreviousMediaItem()instead. - Remove deprecated
Player.previous()method. UsePlayer.seekToPreviousMediaItem()instead. - Remove deprecated
DrmSessionEventListener.onDrmSessionAcquiredmethod. - Remove deprecated
DefaultEncoderFactoryconstructors. UseDefaultEncoderFactory.Builderinstead.
- Remove deprecated
Version 1.5.0-rc02
November 19, 2024
Use the 1.5.0 stable version.
Version 1.5.0-rc01
November 13, 2024
Use the 1.5.0 stable version.
Version 1.5.0-beta01
October 30, 2024
Use the 1.5.0 stable version.
Version 1.5.0-alpha01
September 10, 2024
Use the 1.5.0 stable version.
Version 1.4.0
Version 1.4.1
August 27, 2024
androidx.media3:media3-*:1.4.1 is released.
Version 1.4.1 contains these commits.
- ExoPlayer:
- Extractors:
- MP3: Fix
Searched too many byteserror by correctly ignoring trailing non-MP3 data based on the length field in anInfoframe (#1480).
- MP3: Fix
- Text:
- TTML: Fix handling of percentage
tts:fontSizevalues to ensure they are correctly inherited from parent nodes with percentagetts:fontSizevalues. - Fix
IndexOutOfBoundsExceptioninLegacySubtitleUtildue to incorrectly handling the case of the requested output start time being greater than or equal to the final event time in theSubtitle(#1516).
- TTML: Fix handling of percentage
- DRM:
- Fix
android.media.MediaCodec$CryptoException: Operation not supported in this configuration: ERROR_DRM_CANNOT_HANDLEerror on API 31+ devices playing L1 Widevine content. This error is caused by an incomplete implementation of the frameworkMediaDrm.requiresSecureDecodermethod (#1603).
- Fix
- Effect:
- Add a
release()method toGlObjectsProvider.
- Add a
- Session:
- Transform a double-tap of
KEYCODE_HEADSETHOOKinto a 'seek to next' action, as documented (#1493). - Handle
KEYCODE_HEADSETHOOKas a 'play' command inMediaButtonReceiverwhen deciding whether to ignore it to avoid aForegroundServiceDidNotStartInTimeException(#1581).
- Transform a double-tap of
- RTSP Extension:
- Skip invalid Media Descriptions in SDP parsing (#1087).
Version 1.4.0
July 25, 2024
androidx.media3:media3-*:1.4.0 is released.
Version 1.4.0 contains these commits.
- Common Library:
- Forward presumed no-op seek calls to the protected
BasePlayer.seekTo()andSimpleBasePlayer.handleSeek()methods instead of ignoring them. If you are implementing these methods in a custom player, you may need to handle these additional calls withmediaItemIndex == C.INDEX_UNSET. - Remove compile dependency on enhanced Java 8 desugaring (#1312).
- Ensure the duration passed to
MediaItem.Builder.setImageDurationMs()is ignored for a non-imageMediaItem(as documented). - Add
Format.customDatato store app-provided custom information aboutFormatinstances.
- Forward presumed no-op seek calls to the protected
- ExoPlayer:
- Add
BasePreloadManagerwhich coordinates the preloading for multiple sources based on the priorities defined by theirrankingData. Customization is possible by extending this class. AddDefaultPreloadManagerwhich usesPreloadMediaSourceto preload media samples of the sources into memory, and uses an integerrankingDatathat indicates the index of an item on the UI. - Add
PlayerIdto most methods ofLoadControlto enableLoadControlimplementations to support multiple players. - Remove
Buffer.isDecodeOnly()andC.BUFFER_FLAG_DECODE_ONLY. There is no need to set this flag as renderers and decoders will decide to skip buffers based on timestamp. CustomRendererimplementations should check if the buffer time is at leastBaseRenderer.getLastResetPositionUs()to decide whether a sample should be shown. CustomSimpleDecoderimplementations can checkisAtLeastOutputStartTimeUs()if needed or mark other buffers withDecoderOutputBuffer.shouldBeSkippedto skip them. - Allow a null value to be returned by
TargetPreloadStatusControl.getTargetPreloadStatus(T)to indicate not to preload aMediaSourcewith the givenrankingData. - Add
remove(MediaSource)toBasePreloadManager. - Add
reset()toBasePreloadManagerto release all the holding sources while keep the preload manager instance. - Add
ExoPlayer.setPriority()(andBuilder.setPriority()) to define the priority value used inPriorityTaskManagerand for MediaCodec importance from API 35. - Fix issue with updating the last rebuffer time which resulted in
incorrect
bs(buffer starvation) key in CMCD (#1124). - Add
PreloadMediaSource.PreloadControl.onLoadedToTheEndOfSource(PreloadMediaSource)to indicate that the source has loaded to the end. This allows theDefaultPreloadManagerand the customPreloadMediaSource.PreloadControlimplementations to preload the next source or take other actions. - Fix bug where silence skipping at the end of items can trigger a playback exception.
- Add
cleartoPreloadMediaSourceto discard the preloading period. - Add new error code
PlaybackException.ERROR_CODE_DECODING_RESOURCES_RECLAIMEDthat is used when codec resources are reclaimed for higher priority tasks. - Let
AdsMediaSourceload preroll ads before initial content media preparation completes (#1358). - Fix bug where playback moved to
STATE_ENDEDwhen re-preparing a multi-period DASH live stream after the original period was already removed from the manifest. - Rename
onTimelineRefreshed()toonSourcePrepared()andonPrepared()toonTracksSelected()inPreloadMediaSource.PreloadControl. Also rename the IntDefs inDefaultPreloadManager.Stageaccordingly. - Add experimental support for dynamic scheduling to better align work
with CPU wake-cycles and delay waking up to when renderers can progress.
You can enable this using
experimentalSetDynamicSchedulingEnabled()when setting up your ExoPlayer instance. - Add
Renderer.getDurationToProgressUs(). ARenderercan implement this method to return to ExoPlayer the duration that playback must advance for the renderer to progress. IfExoPlayeris set withexperimentalSetDynamicSchedulingEnabled()thenExoPlayerwill call this method when calculating the time to schedule its work task. - Add
MediaCodecAdapter#OnBufferAvailableListenerto alert when input and output buffers are available for use byMediaCodecRenderer.MediaCodecRendererwill signalExoPlayerwhen receiving these callbacks and ifExoPlayeris set withexperimentalSetDynamicSchedulingEnabled(), thenExoPlayerwill schedule its work loop as renderers can make progress. - Use data class for
LoadControlmethods instead of individual parameters. - Add
ExoPlayer.isReleased()to check whetherExoplayer.release()has been called. - Add
ExoPlayer.Builder.setMaxSeekToPreviousPositionMs()to configure the maximum position for whichseekToPrevious()seeks to the previous item (#1425). - Fix some audio focus inconsistencies, e.g. not reporting full or transient focus loss while the player is paused (#1436).
- Fix potential
IndexOutOfBoundsExceptioncaused by extractors reporting additional tracks after the initial preparation step (#1476). EffectsinExoPlayer.setVideoEffect()will receive the timestamps with the renderer offset removed (#1098).- Fix potential
IllegalArgumentExceptionwhen handling player error that happened while reading ahead into another playlist item (#1483).
- Add
- Transformer:
- Add
audioConversionProcessandvideoConversionProcesstoExportResultindicating how the respective track in the output file was made. - Relax trim optimization H.264 level checks.
- Add support for changing between SDR and HDR input media in a sequence.
- Add support for composition-level audio effects.
- Add support for transcoding Ultra HDR images into HDR videos.
- Fix issue where the
DefaultAudioMixerdoes not output the correct amount of bytes after being reset and reused. - Work around a decoder bug where the number of audio channels was capped at stereo when handling PCM input.
- When selecting tracks in
ExoPlayerAssetLoader, ignore audio channel count constraints as they only apply for playback. - Replace
androidx.media3.transformer.Muxerinterface withandroidx.media3.muxer.Muxerand removeandroidx.media3.transformer.Muxer. - Fix HEIC image loading from content URI schemes. (#1373).
- Adjust audio track duration in
AudioGraphInputto improve AV sync. - Remove
ExportResult.processedInputsfield. If you use this field for codec details, then useDefaultDecoderFactory.listenerinstead. In case of a codec exception, codec details will be available in theExportException.codecInfo.
- Add
- Extractors:
- MPEG-TS: Roll forward the change ensuring the last frame is rendered by passing the last access unit of a stream to the sample queue (#7909). Incorporating fixes to resolve the issues that emerged in I-frame only HLS streams(#1150) and H.262 HLS streams (#1126).
- MP3: Prefer the data size from an
Infoframe over the size reported by the underlying stream (e.g. file size, or HTTPContent-Lengthheader). This helps to exclude non-playable trailer data (e.g. album artwork) from constant bitrate seeking calculations, making seeks more accurate (#1376). - MP3: Use the frame count and other data in an
Infoframe (if present) to compute an average bitrate for constant bitrate seeking, rather than extrapolating from the bitrate of the frame after theInfoframe, which may be artificially small, e.g.PCUTframe (#1376). - Fix PCM audio format extraction in AVI containers.
- Audio:
- Fix DTS:X Profile 2 encoding attributes for passthrough playback (#1299).
- For offloaded playback, reset the tracking field for stream completion
in
DefaultAudioSinkprior to callingAudioTrack.stop()so thatAudioTrack.StreamEventCallback#onPresentationEndedcorrectly identifies when all pending data has been played. - Fix bug in
SilenceSkippingAudioProcessorwhere transitions between different audio formats (for example stereo to mono) can cause the processor to throw an exception (#1352). - Implement
MediaCodecAudioRenderer.getDurationToProgressUs()so that ExoPlayer will dynamically schedule its main work loop to when the MediaCodecAudioRenderer can make progress.
- Video:
- Fix issue where
Listener.onRenderedFirstFrame()arrives too early when switching surfaces mid-playback. - Fix decoder fallback logic for Dolby Vision to use a compatible AV1 decoder if needed (#1389).
- Fix codec exception that may be caused by enabling a video renderer mid-playback.
- Fix issue where
- Text:
- Fix issue where subtitles starting before a seek position are skipped. This issue was only introduced in Media3 1.4.0-alpha01.
- Change default subtitle parsing behavior so it happens during extraction
instead of during rendering (see
ExoPlayer's architecture diagram
for the difference between extraction and rendering).
- This change can be overridden by calling both
MediaSource.Factory.experimentalParseSubtitlesDuringExtraction(false)andTextRenderer.experimentalSetLegacyDecodingEnabled(true). See the docs on customization for how to plumb these components into anExoPlayerinstance. These methods (and all support for legacy subtitle decoding) will be removed in a future release. - Apps with custom
SubtitleDecoderimplementations need to update them to implementSubtitleParserinstead (andSubtitleParser.Factoryinstead ofSubtitleDecoderFactory).
- This change can be overridden by calling both
- PGS: Fix run-length decoding to resolve
0as a color index, instead of a literal color value (#1367). - CEA-708: Ignore
rowLockvalue. The CEA-708-E S-2023 spec states thatrowLockandcolumnLockshould both be assumed to be true, regardless of the values present in the stream (columnLocksupport is not implemented, so it's effectively assumed to always be false).- This was originally included in the
1.3.0-alpha01release notes, but the change was accidentally reverted before the1.3.0-rc01release. This is now fixed, so the change is present again.
- This was originally included in the
- CEA-708: Avoid duplicate newlines being added by ExoPlayer's naive handling of the 'set pen location' command (#1315).
- Fix an
IllegalArgumentExceptionfromLegacySubtitleUtilwhen a WebVTT subtitle sample contains no cues, e.g. as part of a DASH stream (#1516).
- Metadata:
- Fix mapping of MP4 to ID3 sort tags. Previously the 'album sort'
(
soal), 'artist sort' (soar) and 'album artist sort' (soaa) MP4 tags were wrongly mapped to theTSO2,TSOAandTSOPID3 tags (#1302). - Fix reading of MP4 (/iTunes) numeric
gnre(genre) andtmpo(tempo) tags when the value is more than one byte long. - Propagate ID3
TCONframe toMediaMetadata.genre(#1305).
- Fix mapping of MP4 to ID3 sort tags. Previously the 'album sort'
(
- Image:
- Add support for non-square DASH thumbnail grids (#1300).
- Add support for AVIF for API 34+.
- Allow
nullas parameter forExoPlayer.setImageOutput()to clear a previously setImageOutput.
- DataSource:
- Implement support for
android.resource://package/idraw resource URIs wherepackageis different to the package of the current application. This wasn't previously documented to work, but is a more efficient way of accessing resources in another package than by name. - Eagerly check
urlis non-null in theDataSpecconstructors. This parameter was already annotated to be non-null. - Allow
ByteArrayDataSourceto resolve a URI to a byte array duringopen(), instead of being hard-coded at construction (#1405).
- Implement support for
- DRM:
- Allow setting a
LoadErrorHandlingPolicyonDefaultDrmSessionManagerProvider(#1271).
- Allow setting a
- Effect:
- Support multiple speed changes within the same
EditedMediaItemorCompositioninSpeedChangeEffect. - Support for HLG and PQ output from ultra HDR bitmap input.
- Add support for EGL_GL_COLORSPACE_BT2020_HLG_EXT, which improves HLG surface output in ExoPlayer.setVideoEffect and Transformer's Debug SurfaceView.
- Update Overlay matrix implementation to make it consistent with the
documentation by flipping the x and y values applied in
setOverlayFrameAnchor(). If usingOverlaySettings.Builder.setOverlayFrameAnchor(), flip their x and y values by multiplying them by-1. - Fix bug where
TimestampWrappercrashes when used withExoPlayer#setVideoEffects(#821). - Change default SDR color working space from linear colors to electrical BT 709 SDR video. Also provide third option to retain the original colorspace.
- Allow defining indeterminate z-order of EditedMediaItemSequences (#1055).
- Maintain a consistent luminance range across different pieces of HDR content (uses the HLG range).
- Add support for Ultra HDR (bitmap) overlays on HDR content.
- Allow
SeparableConvolutioneffects to be used before API 26. - Remove unused
OverlaySettings.useHdrsince dynamic range of overlay and frame must match. - Add HDR support for
TextOverlay. Luminance of the text overlay can be adjusted withOverlaySettings.Builder.setHdrLuminanceMultiplier().
- Support multiple speed changes within the same
- IMA extension:
- Promote API that is required for apps to play DAI ad streams to stable.
- Add
replaceAdTagParameters(Map <String, String>)toImaServerSideAdInsertionMediaSource.AdLoaderthat allows replacing ad tag parameters at runtime. - Fix bug where
VideoAdPlayer.VideoAdPlayerCallback.onError()was not called when a player error happened during ad playback (#1334). - Bump IMA SDK version to 3.33.0 to fix a
NullPointerExceptionwhen usingdata://ad tag URIs (#700).
- Session:
- Change default of
CommandButton.enabledtotrueand ensure the value can stay false for controllers even if the associated command is available. - Add icon constants for
CommandButtonthat should be used instead of custom icon resources. - Add
MediaSessionService.isPlaybackOngoing()to let apps query whether the service needs to be stopped inonTaskRemoved()(#1219). - Add
MediaSessionService.pauseAllPlayersAndStopSelf()that conveniently allows to pause playback of all sessions and callstopSelf()to terminate the lifecycle of theMediaSessionService. - Override
MediaSessionService.onTaskRemoved(Intent)to provide a safe default implementation that keeps the service running in the foreground if playback is ongoing or stops the service otherwise. - Hide seekbar in the media notification for live streams by not setting the duration into the platform session metadata (#1256).
- Align conversion of
MediaMetadatatoMediaDescriptionCompat, to use the same preferred order and logic when selecting metadata properties as in media1. - Add
MediaSession.sendError()that allows sending non-fatal errors to Media3 controller. When using the notification controller (seeMediaSession.getMediaNotificationControllerInfo()), the custom error is used to update thePlaybackStateof the platform session to an error state with the given error information (#543). - Add
MediaSession.Callback.onPlayerInteractionFinished()to inform sessions when a series of player interactions from a specific controller finished. - Add
SessionErrorand use it inSessionResultandLibraryResultinstead of the error code to provide more information about the error and how to resolve the error if possible. - Publish the code for the media3 controller test app that can be used to test interactions with apps publishing a media session.
- Propagate extras passed to media3's
MediaSession[Builder].setSessionExtras()to a media1 controller'sPlaybackStateCompat.getExtras(). - Map fatal and non-fatal errors to and from the platform session. A
PlaybackExceptionis mapped to a fatal error state of thePlaybackStateCompat. ASessionErrorsent to the media notification controller withMediaSession.sendError(ControllerInfo, SessionError)is mapped to a non-fatal error inPlaybackStateCompatwhich means that error code and message are set but the state of the platform session remains different toSTATE_ERROR. - Allow the session activity to be set per controller to override the
global session activity. The session activity can be defined for a
controller at connection time by creating a
ConnectionResultwithAcceptedResultBuilder.setSessionActivivty(PendingIntent). Once connected, the session activity can be updated withMediaSession.setSessionActivity(ControllerInfo, PendingIntent). - Improve error replication of calls to
MediaLibrarySession.Callback. Error replication can now be configured by usingMediaLibrarySession.Builder.setLibraryErrorReplicationMode()for choosing the error type or opt-ing out of error replication which is on by default.
- Change default of
- UI:
- Add image display support to
PlayerViewwhen connected to anExoPlayer(#1144). - Add customization of various icons in
PlayerControlViewthrough xml attributes to allow different drawables perPlayerViewinstance, rather than global overrides (#1200). - Work around a platform bug causing stretched/cropped video when using
SurfaceViewinside a ComposeAndroidViewon API 34 (#1237).
- Add image display support to
- Downloads:
- Ensure that
DownloadHelperdoes not leak unreleasedRendererinstances, which can eventually result in an app crashing withIllegalStateException: Too many receivers, total of 1000, registered for pid(#1224).
- Ensure that
- Cronet Extension:
- Fix
SocketTimeoutExceptioninCronetDataSource. In some versions of Cronet, the request provided by the callback is not always the same. This leads to callback not completing and request timing out (https://issuetracker.google.com/328442628).
- Fix
- HLS Extension:
- Fix bug where pending EMSG samples waiting for a discontinuity were
delegated in
HlsSampleStreamWrapperwith an incorrect offset causing anIndexOutOfBoundsExceptionor anIllegalArgumentException(#1002). - Fix bug where non-primary playlists keep reloading for LL-HLS streams (#1240).
- Fix bug where enabling CMCD for HLS with initialization segments
resulted in
Source ErrorandIllegalArgumentException. - Fix bug where non-primary playing playlists are not refreshed during live playback (#1240).
- Fix bug where enabling CMCD for HLS live streams causes
ArrayIndexOutOfBoundsException(#1395).
- Fix bug where pending EMSG samples waiting for a discontinuity were
delegated in
- DASH Extension:
- Cast Extension:
- Fix bug that converted the album title of the
MediaQueueItemto the artist in the Media3 media item (#1255).
- Fix bug that converted the album title of the
- Test Utilities:
- Implement
onInit()andonRelease()inFakeRenderer. - Change
TestPlayerRunHelper.runUntil()/playUntil()methods to fail on nonfatal errors (e.g. those reported toAnalyticsListener.onVideoCodecError()). Use the newTestPlayerRunHelper.run(player).ignoringNonFatalErrors().untilXXX()method chain to disable this behavior.
- Implement
- Demo app:
- Use
DefaultPreloadManagerin the short form demo app. - Allow setting repeat mode with
Intentarguments from command line (#1266). - Use
HttpEngineDataSourceas theHttpDataSourcewhen supported by the device.
- Use
- Remove deprecated symbols:
- Remove
CronetDataSourceFactory. UseCronetDataSource.Factoryinstead. - Remove some
DataSpecconstructors. UseDataSpec.Builderinstead. - Remove
setContentTypePredicate(Predicate)method fromDefaultHttpDataSource,OkHttpDataSourceandCronetDataSource. Use the equivalent method on eachXXXDataSource.Factoryinstead. - Remove
OkHttpDataSourceconstructors andOkHttpDataSourceFactory. UseOkHttpDataSource.Factoryinstead. - Remove
PlayerMessage.setHandler(Handler). UsesetLooper(Looper)instead. - Remove
Timeline.Window.isLivefield. Use theisLive()method instead. - Remove
DefaultHttpDataSourceconstructors. UseDefaultHttpDataSource.Factoryinstead. - Remove
DashMediaSource.DEFAULT_LIVE_PRESENTATION_DELAY_MS. UseDashMediaSource.DEFAULT_FALLBACK_TARGET_LIVE_OFFSET_MSinstead. - Remove
MediaCodecInfo.isSeamlessAdaptationSupported(Format, Format, boolean). UseMediaCodecInfo.canReuseCodec(Format, Format)instead. - Remove
DrmSessionManager.DUMMYandgetDummyDrmSessionManager()method. UseDrmSessionManager.DRM_UNSUPPORTEDinstead. - Remove
AnalyticsListener.onAudioInputFormatChanged(EventTime, Format),AnalyticsListener.onVideoInputFormatChanged(EventTime, Format),AudioRendererEventListener.onAudioInputFormatChanged(Format),VideoRendererEventListener.onVideoInputFormatChanged(Format). Use the overloads that take aDecoderReuseEvaluationinstead. - Remove
RendererSupport.FormatSupportIntDef andFORMAT_HANDLED,FORMAT_EXCEEDS_CAPABILITIES,FORMAT_UNSUPPORTED_DRM,FORMAT_UNSUPPORTED_SUBTYPE,FORMAT_UNSUPPORTED_TYPEconstants. Use the equivalent IntDef and constants inandroidx.media3.common.Cinstead (e.g.C.FORMAT_HANDLED). - Remove
Bundleableinterface. This includes removing allBundleable.Creator<Foo> CREATORconstant fields. Callers should use theBundle toBundle()andstatic Foo fromBundle(Bundle)methods on each type instead.
- Remove
Version 1.4.0-rc01
July 10, 2024
Use the 1.4.0 stable version.
Version 1.4.0-beta01
June 26, 2024
Use the 1.4.0 stable version.
Version 1.4.0-alpha02
June 07, 2024
Use the 1.4.0 stable version.
Version 1.4.0-alpha01
April 17, 2024
Use the 1.4.0 stable version.
Version 1.3.0
Version 1.3.1
April 11, 2024
androidx.media3:media3-*:1.3.1 is released.
Version 1.3.1 contains these commits.
- Common Library:
- Add
Format.labelsto allow localized or other alternative labels.
- Add
- ExoPlayer:
- Fix issue where
PreloadMediaPeriodcannot retain the streams when it is preloaded again. - Apply the correct corresponding
TrackSelectionResultto the playing period in track reselection. - Start early-enabled renderers only after advancing the playing period when transitioning between media items (#1017).
- Add missing return type to proguard
-keepclasseswithmembersrule forDefaultVideoFrameProcessor.Factory.Builder.build()(#1187).
- Fix issue where
- Transformer:
- Add workaround for exception thrown due to
MediaMuxernot supporting negative presentation timestamps before API 30.
- Add workaround for exception thrown due to
- Track Selection:
DefaultTrackSelector: Prefer video tracks with a 'reasonable' frame rate (>=10fps) over those with a lower or unset frame rate. This ensures the player selects the 'real' video track in MP4s extracted from motion photos that can contain two HEVC tracks where one has a higher resolution but a very small number of frames (#1051).
- Extractors:
- Fix issue where padding was not skipped when reading odd-sized chunks from WAV files (#1117).
- MP3: Populate
Format.averageBitratefrom metadata frames such asXINGandVBRI. - MPEG-TS: Revert a change that aimed to ensure the last frame is rendered by passing the last access unit of a stream to the sample queue (#7909). This is due to the change causing new problems with I-frame only HLS streams (#1150) and H.262 HLS streams (#1126).
- Audio:
- Allow renderer recovery by disabling offload if audio track fails to initialize in offload mode.
- Video:
- Add workaround for a device issue on Galaxy Tab S7 FE, Chromecast with Google TV, and Lenovo M10 FHD Plus that causes 60fps H265 streams to be marked as unsupported
- Add workaround that ensures the first frame is always rendered while tunneling even if the device does not do this automatically as required by the API (#1169). (#966).
- Fix issue where HDR color info handling causes codec misbehavior and prevents adaptive format switches for SDR video tracks (#1158).
- Text:
- WebVTT: Prevent directly consecutive cues from creating spurious
additional
CuesWithTiminginstances fromWebvttParser.parse(#1177).
- WebVTT: Prevent directly consecutive cues from creating spurious
additional
- DRM:
- Work around a
NoSuchMethodErrorwhich can be thrown by theMediaDrmframework instead ofResourceBusyExceptionorNotProvisionedExceptionon some Android 14 devices (#1145).
- Work around a
- Effect:
- Improved PQ to SDR tone-mapping by converting color spaces.
- Session:
- UI:
- Fallback to include audio track language name if
Localecannot identify a display name (#988).
- Fallback to include audio track language name if
- DASH Extension:
- Populate all
Labelelements from the manifest intoFormat.labels(#1054).
- Populate all
- RTSP Extension:
- Skip empty session information values (i-tags) in SDP parsing (#1087).
- Decoder Extensions (FFmpeg, VP9, AV1, MIDI, etc.):
- Disable the MIDI extension as a local dependency by default because it requires an additional Maven repository to be configured. Users who need this module from a local dependency can re-enable it.
Version 1.3.0
March 6, 2024
androidx.media3:media3-*:1.3.0 is released.
Version 1.3.0 contains these commits.
- Common Library:
- Implement support for
android.resource://package/[type/]nameraw resource URIs wherepackageis different to the package of the current application. This has always been documented to work, but wasn't correctly implemented until now. - Normalize MIME types set by app code or read from media to be fully lower-case.
- Define ads with a full
MediaIteminstead of a singleUriinAdPlaybackState. - Increase
minSdkto 19 (Android KitKat). This is aligned with all other AndroidX libraries, and is required for us to upgrade to the latest versions of our AndroidX dependencies. - Populate both
artworkUriandartworkDatainMediaMetadata.Builder.populate(MediaMetadata)when at least one of them is non-null (#964).
- Implement support for
- ExoPlayer:
- Add
PreloadMediaSourceandPreloadMediaPeriodthat allows apps to preload a content media source at a specific start position before playback.PreloadMediaSourcetakes care of preparing the content media source to receive theTimeline, preparing and caching the period at the given start position, selecting tracks and loading media data for the period. Apps control the preload progress by implementingPreloadMediaSource.PreloadControland set the preloaded source to the player for playback. - Add
ExoPlayer.setImageOutputthat allows apps to setImageRenderer.ImageOutput. DefaultRenderersFactorynow provides anImageRendererto the player by default with nullImageOutputandImageDecoder.Factory.DEFAULT.- Emit
Player.Listener.onPositionDiscontinuityevent when silence is skipped (#765). - Add experimental support for parsing subtitles during extraction. You
can enable this using
MediaSource.Factory.experimentalParseSubtitlesDuringExtraction(). - Support adaptive media sources with
PreloadMediaSource. - Implement
HttpEngineDataSource, anHttpDataSourceusing the HttpEngine API. - Prevent subclassing
CompositeSequenceableLoader. This component was previously made extensible but was never subclassed within the library. Customizations can be done by wrapping an instance using the decorator pattern and implementing a customCompositeSequenceableLoaderFactory. - Fix issue where repeating the same time causes metadata from this item to be cleared (#1007).
- Rename
experimentalSetSubtitleParserFactorymethods onBundledChunkExtractor.FactoryandDefaultHlsExtractorFactorytosetSubtitleParserFactoryand disallow passingnull. Use the newexperimentalParseSubtitlesDuringExtraction(boolean)methods to control parsing behaviour. - Add support for customising the
SubtitleParser.Factoryused during extraction. This can be achieved withMediaSource.Factory.setSubtitleParserFactory(). - Add source prefix to all
Format.idfields generated fromMergingMediaSource. This helps to identify which source produced aFormat(#883). - Fix the regex used for validating custom Common Media Client Data (CMCD) key names by modifying it to only check for hyphen (#1028).
- Stop double-encoding CMCD query parameters (#1075).
- Add
- Transformer:
- Add support for flattening H.265/HEVC SEF slow motion videos.
- Increase transmuxing speed, especially for 'remove video' edits.
- Add API to ensure that the output file starts on a video frame. This can make the output of trimming operations more compatible with player implementations that don't show the first video frame until its presentation timestamp (#829).
- Add support for optimizing single asset MP4 trim operations.
- Add support to ensure a video frame has the first timestamp in the output file. Fixes output files beginning with black frame on iOS based players (#829).
- Track Selection:
- Add
DefaultTrackSelector.selectImageTrackto enable image track selection. - Add
TrackSelectionParameters.isPrioritizeImageOverVideoEnabledto determine whether to select an image track if both an image track and a video track are available. The default value isfalsewhich means selecting a video track is prioritized.
- Add
- Extractors:
- Add additional AV1C parsing to MP4 extractor to retrieve
ColorInfo.colorSpace,ColorInfo.colorTransfer, andColorInfo.colorRangevalues (#692). - MP3: Use constant bitrate (CBR) seeking for files with an
Infoheader (the CBR equivalent of theXingheader). Previously we used the seek table from theInfoheader, but this results in less precise seeking than if we ignore it and assume the file is CBR. - MPEG2-TS: Add DTS, DTS-LBR and DTS:X Profile2 support (#275).
- Extract audio types from TS descriptors and map them to role flags, allowing users to make better-informed audio track selections (#973).
- Add additional AV1C parsing to MP4 extractor to retrieve
- Audio:
- Video:
- Change the
MediaCodecVideoRendererconstructor that takes aVideoFrameProcessor.Factoryargument and replace it with a constructor that takes aVideoSinkProviderargument. Apps that want to inject a customVideoFrameProcessor.Factorycan instantiate aCompositingVideoSinkProviderthat uses the customVideoFrameProcessor.Factoryand pass the video sink provider toMediaCodecVideoRenderer.
- Change the
- Text:
- Fix serialization of bitmap cues to resolve
Tried to marshall a Parcel that contained Binder objectserror when usingDefaultExtractorsFactory.setTextTrackTranscodingEnabled(#836). - CEA-708: Ignore
rowLockvalue. The CEA-708-E S-2023 spec states thatrowLockandcolumnLockshould both be assumed to be true, regardless of the values present in the stream (columnLocksupport is not implemented, so it's effectively assumed to always be false).
- Fix serialization of bitmap cues to resolve
- Image:
- Add support for DASH thumbnails. Grid images are cropped and individual
thumbnails are provided to
ImageOutputclose to their presentation times.
- Add support for DASH thumbnails. Grid images are cropped and individual
thumbnails are provided to
- DRM:
- Play 'clear lead' unencrypted samples in DRM content immediately by
default, even if the keys for the later encrypted samples aren't ready
yet. This may lead to mid-playback stalls if the keys still aren't ready
when the playback position reaches the encrypted samples (but previously
playback wouldn't have started at all by this point). This behavior can
be disabled with
MediaItem.DrmConfiguration.Builder.setPlayClearContentWithoutKeyorDefaultDrmSessionManager.Builder.setPlayClearSamplesWithoutKeys.
- Play 'clear lead' unencrypted samples in DRM content immediately by
default, even if the keys for the later encrypted samples aren't ready
yet. This may lead to mid-playback stalls if the keys still aren't ready
when the playback position reaches the encrypted samples (but previously
playback wouldn't have started at all by this point). This behavior can
be disabled with
- IMA extension:
- Fix issue where DASH and HLS ads without the appropriate file extension can't be played.
- Session:
- Disable double-click detection for TV apps (#962).
- Fix issue where
MediaItem.RequestMetadatawith just non-null extras is not transmitted between media controllers and sessions. - Add constructor to
MediaLibrarySession.Builderthat only takes aContextinstead of aMediaLibraryService.
- HLS Extension:
- Reduce
HlsMediaPeriodto package-private visibility. This type shouldn't be directly depended on from outside the HLS package. - Resolve seeks to beginning of a segment more efficiently (#1031).
- Reduce
- Decoder Extensions (FFmpeg, VP9, AV1, MIDI, etc.):
- MIDI decoder: Ignore SysEx event messages (#710).
- Test Utilities:
- Don't pause playback in
TestPlayerRunHelper.playUntilPosition. The test keeps the playback in a playing state, but suspends progress until the test is able to add assertions and further actions.
- Don't pause playback in
- Demo app:
- Add a shortform demo module to demo the usage of
PreloadMediaSourcewith the short-form content use case.
- Add a shortform demo module to demo the usage of
Version 1.3.0-rc01
February 22, 2024
Use the 1.3.0 stable version.
Version 1.3.0-beta01
February 7, 2024
Use the 1.3.0 stable version.
Version 1.3.0-alpha01
January 15, 2024
Use the 1.3.0 stable version.
Version 1.2.0
Version 1.2.1
January 9, 2024
- ExoPlayer:
- Fix issue where manual seeks outside of the
LiveConfiguration.min/maxOffsetrange keep adjusting the offset back tomin/maxOffset. - Fix issue that OPUS and VORBIS channel layouts are wrong for 3, 5, 6, 7 and 8 channels (#8396).
- Fix issue where track selections after seek to zero in a live stream incorrectly let the stream start at its default position (#9347).
- Fix the issue where new instances of
CmcdData.Factorywere receiving negative values forbufferedDurationUsfrom chunk sources, resulting in anIllegalArgumentException(#888).
- Fix issue where manual seeks outside of the
- Transformer:
- Work around an issue where the encoder would throw at configuration time due to setting a high operating rate.
- Extractors:
- Mark secondary (unplayable) HEVC tracks in JPEG motion photos as
ROLE_FLAG_ALTERNATEto prevent them being automatically selected for playback because of their higher resolution. - Fix wrong keyframe detection for TS H264 streams (#864).
- Fix duration estimation of TS streams that are longer than 47721 seconds (#855).
- Mark secondary (unplayable) HEVC tracks in JPEG motion photos as
- Audio:
- Fix handling of EOS for
SilenceSkippingAudioProcessorwhen called multiple times (#712).
- Fix handling of EOS for
- Video:
- Add workaround for a device issue on Galaxy Tab S7 FE, Chromecast with Google TV, and Lenovo M10 FHD Plus that causes 60fps AVC streams to be marked as unsupported (#693).
- Metadata:
- Fix bug where
MediaMetadatawas only populated from Vorbis comments with upper-case keys (#876). - Catch
OutOfMemoryErrorwhen parsing very large ID3 frames, meaning playback can continue without the tag info instead of playback failing completely.
- Fix bug where
- DRM:
- Extend workaround for spurious ClearKey
https://default.urllicense URL to API 33+ (previously the workaround only applied on API 33 exactly) (#837). - Fix
ERROR_DRM_SESSION_NOT_OPENEDwhen switching from encrypted to clear content without a surface attached to the player. The error was due to incorrectly using a secure decoder to play the clear content.
- Extend workaround for spurious ClearKey
- Session:
- Put the custom keys and values in
MediaMetadataCompattoMediaMetadata.extrasandMediaMetadata.extrastoMediaMetadataCompat(#756, #802). - Fix broadcasting
notifyChildrenChangedfor legacy controllers (#644). - Fix a bug where setting a negative time for a disabled
setWhentimer of the notification caused a crash on some devices (#903). - Fix
IllegalStateExceptionwhen the media notification controller hasn't completed connecting when the first notification update is requested (#917).
- Put the custom keys and values in
- UI:
- DASH Extension:
- Parse "f800" as channel count of 5 for Dolby in DASH manifest (#688).
- Decoder Extensions (FFmpeg, VP9, AV1, MIDI, etc.):
- Cast Extension:
- Sanitize creation of a
Timelineto not crash the app when loading media fails on the cast device (#708).
- Sanitize creation of a
Version 1.2.0
November 15, 2023
- Common Library:
- Add a
@Nullable Throwableparameter to the methods in theLog.Loggerinterface. Themessageparameter to these methods no longer contains any information about theThrowablepassed to theLog.{d,i,w,e}()methods, so implementations will need to manually append this information if desired (possibly usingLogger.appendThrowableString(String, Throwable)). - Fix Kotlin compatibility issue where nullable generic type parameters
and nullable array element types are not detected as nullable. Examples
are
TrackSelectorResultandSimpleDecodermethod parameters (#6792). - Change default UI and notification behavior in
Util.shouldShowPlayButtonto show a "play" button while playback is temporarily suppressed (e.g. due to transient audio focus loss). The legacy behavior can be maintained by usingPlayerView.setShowPlayButtonIfPlaybackIsSuppressed(false)orMediaSession.Builder.setShowPlayButtonIfPlaybackIsSuppressed(false)(#11213). - Upgrade
androidx.annotation:annotation-experimentalto1.3.1to fix https://issuetracker.google.com/251172715. - Move
ExoPlayer.setAudioAttributesto thePlayerinterface.
- Add a
- ExoPlayer:
- Fix seeking issues in AC4 streams caused by not identifying decode-only samples correctly (#11000).
- Add suppression of playback on unsuitable audio output devices (e.g. the
built-in speaker on Wear OS devices) when this feature is enabled via
ExoPlayer.Builder.setSuppressPlaybackOnUnsuitableOutput. The playback suppression reason will be updated asPlayer.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUTif playback is attempted when no suitable audio outputs are available, or if all suitable outputs are disconnected during playback. The suppression reason will be removed when a suitable output is connected. - Add
MediaSource.canUpdateMediaItemandMediaSource.updateMediaItemto acceptMediaItemupdates after creation viaPlayer.replaceMediaItem(s). - Allow
MediaItemupdates for allMediaSourceclasses provided by the library viaPlayer.replaceMediaItem(s)(#33, #9978). - Rename
MimeTypes.TEXT_EXOPLAYER_CUEStoMimeTypes.APPLICATION_MEDIA3_CUES. - Add
PngExtractorthat sends and reads a whole PNG file into theTrackOutputas one sample. - Enhance
SequenceableLoader.continueLoading(long)method in theSequenceableLoaderinterface toSequenceableLoader.continueLoading(LoadingInfo loadingInfo).LoadingInfocontains additional parameters, includingplaybackSpeedandlastRebufferRealtimeMsin addition to the existingplaybackPositionUs. - Enhance
ChunkSource.getNextChunk(long, long, List, ChunkHolder)method in theChunkSourceinterface toChunkSource.getNextChunk(LoadingInfo, long, List, ChunkHolder). - Add additional fields to Common Media Client Data (CMCD) logging: buffer
starvation (
bs), deadline (dl), playback rate (pr) and startup (su) (#8699). - Add luma and chroma bitdepth to
ColorInfo(#491). - Add additional fields to Common Media Client Data (CMCD) logging: next
object request (
nor) and next range request (nrr) (#8699). - Add functionality to transmit Common Media Client Data (CMCD) data using query parameters (#553).
- Fix
ConcurrentModificationExceptioninExperimentalBandwidthMeter(#612). - Add
MediaPeriodIdparameter toCompositeMediaSource.getMediaTimeForChildMediaTime. - Support
ClippingMediaSource(and other sources with period/window time offsets) inConcatenatingMediaSource2(#11226). - Change
BaseRenderer.onStreamChanged()to also receive aMediaPeriodIdargument.
- Transformer:
- Parse EXIF rotation data for image inputs.
- Remove
TransformationRequest.HdrModeannotation type and its associated constants. UseComposition.HdrModeand its associated constants instead. - Simplify the
OverlaySettingsto fix rotation issues. - Changed
frameRateanddurationUsparameters ofSampleConsumer.queueInputBitmaptoTimestampIterator.
- Track Selection:
- Add
DefaultTrackSelector.Parameters.allowAudioNonSeamlessAdaptivenessto explicitly allow or disallow non-seamless adaptation. The default stays at its current behavior oftrue.
- Add
- Extractors:
- MPEG-TS: Ensure the last frame is rendered by passing the last access unit of a stream to the sample queue (#7909).
- Fix typo when determining
rotationDegrees. ChangedprojectionPosePitchtoprojectionPoseRoll(#461). - Remove the assumption that
Extractorinstances can be directly inspected withinstanceof. If you want runtime access to the implementation details of anExtractoryou must first callExtractor.getUnderlyingInstance. - Add
BmpExtractor. - Add
WebpExtractor. - Add
HeifExtractor. - Add
QuickTime classic
support to
Mp4Extractor.
- Audio:
- Add support for 24/32-bit big-endian PCM in MP4 and Matroska, and parse
PCM encoding for
lpcmin MP4. - Add support for extracting Vorbis audio in MP4.
- Add
AudioSink.getFormatOffloadSupport(Format)that retrieves level of offload support the sink can provide for the format through aDefaultAudioOffloadSupportProvider. It returns the newAudioOffloadSupportthat containsisFormatSupported,isGaplessSupported, andisSpeedChangeSupported. - Add
AudioSink.setOffloadMode()through which the offload configuration on the audio sink is configured. Default isAudioSink.OFFLOAD_MODE_DISABLED. - Offload can be enabled through
setAudioOffloadPreferenceinTrackSelectionParameters. If the set preference is to enable, the device supports offload for the format, and the track selection is a single audio track, then audio offload will be enabled. - If
audioOffloadModePreferenceis set toAUDIO_OFFLOAD_MODE_PREFERENCE_REQUIRED, then theDefaultTrackSelectorwill only select an audio track and only if that track's format is supported in offload. If no audio track is supported in offload, then no track will be selected. - Disabling gapless support for offload when pre-API level 33 due to playback position issue after track transition.
- Remove parameter
enableOffloadfromDefaultRenderersFactory.buildAudioSinkmethod signature. - Remove method
DefaultAudioSink.Builder.setOffloadMode. - Remove intdef value
DefaultAudioSink.OffloadMode.OFFLOAD_MODE_ENABLED_GAPLESS_DISABLED. - Add support for Opus gapless metadata during offload playback.
- Allow renderer recovery by disabling offload if failed at first write (#627).
- Enable Offload Scheduling by default for audio-only offloaded playback.
- Delete
ExoPlayer.experimentalSetOffloadSchedulingEnabledandAudioOffloadListener.onExperimentalOffloadSchedulingEnabledChanged. - Renamed
onExperimentalSleepingForOffloadChangedasonSleepingForOffloadChangedandonExperimentalOffloadedPlaybackasonOffloadedPlayback. - Move audio offload mode related
TrackSelectionParametersinterfaces and definitions to an innerAudioOffloadPreferencesclass. - Add
onAudioTrackInitializedandonAudioTrackReleasedcallbacks toAnalyticsListener,AudioRendererEventListenerandAudioSink.Listener. - Fix DTS Express audio buffer underflow issue (#650).
- Fix bug where the capabilities check for E-AC3-JOC throws an
IllegalArgumentException(#677).
- Add support for 24/32-bit big-endian PCM in MP4 and Matroska, and parse
PCM encoding for
- Video:
- Allow
MediaCodecVideoRendererto use a customVideoFrameProcessor.Factory. - Fix bug where the first frame couldn't be rendered if the audio stream starts with negative timestamps (#291).
- Allow
- Text:
- Remove
ExoplayerCuesDecoder. Text tracks withsampleMimeType = application/x-media3-cuesare now directly handled byTextRendererwithout needing aSubtitleDecoderinstance.
- Remove
- Metadata:
MetadataDecoder.decodewill no longer be called for "decode-only" samples as the implementation must return null anyway.
- Effect:
- Add
VideoFrameProcessor.queueInputBitmap(Bitmap, Iterator<Long>)queuing bitmap input by timestamp. - Change
VideoFrameProcessor.registerInputStream()to be non-blocking. Apps must implementVideoFrameProcessor.Listener#onInputStreamRegistered(). - Changed
frameRateanddurationUsparameters ofVideoFrameProcessor.queueInputBitmaptoTimestampIterator.
- Add
- IMA extension:
- Fix bug where a multi-period DASH live stream that is not the first item in a playlist can throw an exception (#571).
- Release StreamManager before calling
AdsLoader.destroy() - Bump IMA SDK version to 3.31.0.
- Session:
- Set the notifications foreground service behavior to
FOREGROUND_SERVICE_IMMEDIATEinDefaultMediaNotificationProvider(#167). - Use only
android.media.session.MediaSession.setMediaButtonBroadcastReceiver()above API 31 to avoid problems with deprecated API on Samsung devices (#167). - Use the media notification controller as proxy to set available commands and custom layout used to populate the notification and the platform session.
- Convert media button events that are received by
MediaSessionService.onStartCommand()within Media3 instead of routing them to the platform session and back to Media3. With this, the caller controller is always the media notification controller and apps can easily recognize calls coming from the notification in the same way on all supported API levels. - Fix bug where
MediaController.getCurrentPosition()is not advancing when connected to a legacyMediaSessionCompat. - Add
MediaLibrarySession.getSubscribedControllers(mediaId)for convenience. - Override
MediaLibrarySession.Callback.onSubscribe()to assert the availability of the parent ID for which the controller subscribes. If successful, the subscription is accepted andnotifyChildrenChanged()is called immediately to inform the browser (#561). - Add session demo module for Automotive OS and enable session demo for Android Auto.
- Do not set the queue of the framework session when
COMMAND_GET_TIMELINEis not available for the media notification controller. With Android Auto as the client controller reading from the framework session, this has the effect that thequeuebutton in the UI of Android Auto is not displayed (#339). - Use
DataSourceBitmapLoaderby default instead ofSimpleBitmapLoader(#271, #327). - Add
MediaSession.Callback.onMediaButtonEvent(Intent)that allows apps to override the default media button event handling.
- Set the notifications foreground service behavior to
- UI:
- Add a
Player.Listenerimplementation for Wear OS devices that handles playback suppression due toPlayer.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUTby launching a system dialog to allow a user to connect a suitable audio output (e.g. bluetooth headphones). The listener will auto-resume playback if a suitable device is connected within a configurable timeout (default is 5 minutes).
- Add a
- Downloads:
- Declare "data sync" foreground service type for
DownloadServicefor Android 14 compatibility. When using this service, the app also needs to adddataSyncasforegroundServiceTypein the manifest and add theFOREGROUND_SERVICE_DATA_SYNCpermission (#11239).
- Declare "data sync" foreground service type for
- HLS Extension:
- Refresh the HLS live playlist with an interval calculated from the last load start time rather than the last load completed time (#663).
- DASH Extension:
- Allow multiple of the same DASH identifier in segment template URL.
- Add experimental support for parsing subtitles during extraction. This
has better support for merging overlapping subtitles, including
resolving flickering when transitioning between subtitle segments. You
can enable this using
DashMediaSource.Factory.experimentalParseSubtitlesDuringExtraction()(#288).
- RTSP Extension:
- Fix a race condition that could lead to
IndexOutOfBoundsExceptionwhen falling back to TCP, or playback hanging in some situations. - Check state in RTSP setup when returning loading state of
RtspMediaPeriod(#577). - Ignore custom Rtsp request methods in Options response public header (#613).
- Use RTSP Setup Response timeout value in time interval of sending keep-alive RTSP Options requests (#662).
- Fix a race condition that could lead to
- Decoder Extensions (FFmpeg, VP9, AV1, MIDI, etc.):
- Release the MIDI decoder module, which provides support for playback of standard MIDI files using the Jsyn library to synthesize audio.
- Add
DecoderOutputBuffer.shouldBeSkippedto directly mark output buffers that don't need to be presented. This is preferred overC.BUFFER_FLAG_DECODE_ONLYthat will be deprecated. - Add
Decoder.setOutputStartTimeUsandSimpleDecoder.isAtLeastOutputStartTimeUsto allow decoders to drop decode-only samples before the start time. This should be preferred toBuffer.isDecodeOnlythat will be deprecated. - Fix bug publishing MIDI decoder artifact to Maven repository. The
artifact is renamed to
media3-exoplayer-midi(#734).
- Leanback extension:
- Fix bug where disabling a surface can cause an
ArithmeticExceptionin Leanback code (#617).
- Fix bug where disabling a surface can cause an
- Test Utilities:
- Make
TestExoPlayerBuilderandFakeClockcompatible with Espresso UI tests and Compose UI tests. This fixes a bug where playback advances non-deterministically during Espresso or Compose view interactions.
- Make
- Remove deprecated symbols:
- Remove
TransformationRequest.Builder.setEnableRequestSdrToneMapping(boolean)andTransformationRequest.Builder.experimental_setEnableHdrEditing(boolean). UseComposition.Builder.setHdrMode(int)and pass theCompositiontoTransformer.start(Composition, String)instead. - Remove deprecated
DownloadNotificationHelper.buildProgressNotificationmethod, use a non deprecated method that takes anotMetRequirementsparameter instead.
- Remove
Version 1.2.0-rc01
November 1, 2023
Use the 1.2.0 stable version.
Version 1.2.0-beta01
October 19, 2023
Use the 1.2.0 stable version.
Version 1.2.0-alpha02
September 29, 2023
Use the 1.2.0 stable version.
Version 1.2.0-alpha01
August 17, 2023
Use the 1.2.0 stable version.
Version 1.1.0
Version 1.1.1
August 16, 2023
- Common Library:
- Remove accidentally added
multidexdependency from all modules (#499).
- Remove accidentally added
- ExoPlayer:
- Fix issue in
PlaybackStatsListenerwhere spuriousPlaybackStatsare created after the playlist is cleared. - Add additional fields to Common Media Client Data (CMCD) logging: streaming format (sf), stream type (st), version (v), top birate (tb), object duration (d), measured throughput (mtp) and object type (ot) (#8699).
- Fix issue in
- Audio:
- Fix a bug where
Player.getState()never transitioned toSTATE_ENDEDwhen playing very short files (#538).
- Fix a bug where
- Audio Offload:
- Prepend Ogg ID Header and Comment Header Pages to bitstream for offloaded Opus playback in accordance with RFC 7845.
- Video:
- H.265/HEVC: Fix parsing SPS short and long term reference picture info.
- Text:
- CEA-608: Change cue truncation logic to only consider visible text. Previously indent and tab offset were included when limiting the cue length to 32 characters (which was technically correct by the spec) (#11019).
- IMA extension:
- Bump IMA SDK version to 3.30.3.
- Session:
- Add custom layout to the state of the controller and provide a getter to
access it. When the custom layout changes,
MediaController.Listener.onCustomLayoutChangedis called. Apps that want to send different custom layouts to different Media3 controller can do this inMediaSession.Callback.onConnectby using anAcceptedResultBuilderto make sure the custom layout is available to the controller when connection completes. - Fix cases where
MediaLibraryServiceLegacyStubsent an error to aResultthat didn't support this which produced anUnsupportedOperationException(#78). - Fix the way
PlayerWrappercreates aVolumeProviderCompatby determiningvolumeControlTypethrough both legacy commands (COMMAND_ADJUST_DEVICE_VOLUMEandCOMMAND_SET_DEVICE_VOLUME) and new commands (COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGSandCOMMAND_SET_DEVICE_VOLUME_WITH_FLAGS) (#554).
- Add custom layout to the state of the controller and provide a getter to
access it. When the custom layout changes,
Version 1.1.0
July 5, 2023
- Common Library:
- Add suppression reason for unsuitable audio route and play when ready change reason for suppressed too long. (#15).
- Add commands to Player:
COMMAND_GET_METADATACOMMAND_SET_PLAYLIST_METADATACOMMAND_SET_DEVICE_VOLUME_WITH_FLAGSCOMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS
- Add overloaded methods to Player which allow users to specify volume
flags:
void setDeviceVolume(int, int)void increaseDeviceVolume(int)void decreaseDeviceVolume(int)void setDeviceMuted(boolean, int)
- Add
BuilderforDeviceInfoand deprecate existing constructor. - Add
DeviceInfo.routingControllerIdto specify the routing controller ID for remote playbacks. - Add
Player.replaceMediaItem(s)as a shortcut to adding and removing items at the same position (#8046).
- ExoPlayer:
- Allow ExoPlayer to have control of device volume methods only if
explicitly opted in. Use
ExoPlayer.Builder.setDeviceVolumeControlEnabledto have access to:getDeviceVolume()isDeviceMuted()setDeviceVolume(int)andsetDeviceVolume(int, int)increaseDeviceVolume(int)andincreaseDeviceVolume(int, int)decreaseDeviceVolume(int)anddecreaseDeviceVolume(int, int)
- Add
FilteringMediaSourcethat allows to filter available track types from aMediaSource. - Add support for including Common Media Client Data (CMCD) in the
outgoing requests of adaptive streaming formats DASH, HLS, and
SmoothStreaming. The following fields,
br,bl,cid,rtp, andsid, have been incorporated (#8699). API structure and API methods:- CMCD logging is disabled by default, use
MediaSource.Factory.setCmcdConfigurationFactory(CmcdConfiguration.Factory cmcdConfigurationFactory)to enable it. - All keys are enabled by default, override
CmcdConfiguration.RequestConfig.isKeyAllowed(String key)to filter out which keys are logged. - Override
CmcdConfiguration.RequestConfig.getCustomData()to enable custom key logging.
- CMCD logging is disabled by default, use
- Add additional action to manifest of main demo to make it easier to
start the demo app with a custom
*.exolist.jsonfile (#439). - Add
ExoPlayer.setVideoEffects()for usingEffectduring video playback. - Update
SampleQueueto storesourceIdas alongrather than anint. This changes the signatures of public methodsSampleQueue.sourceIdandSampleQueue.peekSourceId. - Add parameters to
LoadControlmethodsshouldStartPlaybackandonTracksSelectedthat allow associating these methods with the relevantMediaPeriod. - Change signature of
ServerSideAdInsertionMediaSource.setAdPlaybackStates(Map<Object, AdPlaybackState>)by adding a timeline parameter that contains the periods with the UIDs used as keys in the map. This is required to avoid concurrency issues with multi-period live streams. - Deprecate
EventDispatcher.withParameters(int windowIndex, @Nullable MediaPeriodId mediaPeriodId, long mediaTimeOffsetMs)andBaseMediaSource.createEventDispatcher(..., long mediaTimeOffsetMs). The variant of the methods without themediaTimeOffsetUscan be called instead. Note that even for the deprecated variants, the offset is not anymore added tostartTimeUsandendTimeUsof theMediaLoadDataobjects that are dispatched by the dispatcher. - Rename
ExoTrackSelection.blacklisttoexcludeTrackandisBlacklistedtoisTrackExcluded. - Fix inconsistent behavior between
ExoPlayer.setMediaItem(s)andaddMediaItem(s)when called on an empty playlist.
- Allow ExoPlayer to have control of device volume methods only if
explicitly opted in. Use
- Transformer:
- Remove
Transformer.Builder.setMediaSourceFactory(MediaSource.Factory). UseExoPlayerAssetLoader.Factory(MediaSource.Factory)andTransformer.Builder.setAssetLoaderFactory(AssetLoader.Factory)instead. - Remove
Transformer.startTransformation(MediaItem, ParcelFileDescriptor). - Fix a bug where transformation could get stuck (leading to muxer timeout) if the end of the video stream was signaled at the moment when an input frame was pending processing.
- Query codecs via
MediaCodecListinstead of usingfindDecoder/EncoderForFormatutilities, to expand support. - Remove B-frame configuration in
DefaultEncoderFactorybecause it doesn't work on some devices.
- Remove
- Track selection:
- Add
DefaultTrackSelector.Parameters.allowInvalidateSelectionsForRendererCapabilitiesChangewhich is disabled by default. When enabled, theDefaultTrackSelectorwill trigger a new track selection when the renderer capabilities changed.
- Add
- Extractors:
- Audio:
- Fix bug where some playbacks fail when tunneling is enabled and
AudioProcessorsare active, e.g. for gapless trimming (#10847). - Encapsulate Opus frames in Ogg packets in direct playbacks (offload).
- Extrapolate current position during sleep with offload scheduling.
- Add
Renderer.release()andAudioSink.release()for releasing the resources at the end of player's lifecycle. - Listen to audio capabilities changes in
DefaultAudioSink. Add a required parametercontextin the constructor ofDefaultAudioSink, with which theDefaultAudioSinkwill register as the listener to theAudioCapabilitiesReceiverand update itsaudioCapabilitiesproperty when informed with a capabilities change. - Propagate audio capabilities changes via a new event
onAudioCapabilitiesChangedinAudioSink.Listenerinterface, and a new interfaceRendererCapabilities.Listenerwhich triggersonRendererCapabilitiesChangedevents. - Add
ChannelMixingAudioProcessorfor applying scaling/mixing to audio channels. - Add new int value
DISCARD_REASON_AUDIO_BYPASS_POSSIBLEtoDecoderDiscardReasonsto discard audio decoder when bypass mode is possible after audio capabilities change. - Add direct playback support for DTS Express and DTS:X (#335).
- Fix bug where some playbacks fail when tunneling is enabled and
- Video:
- Make
MediaCodecVideoRendererreport aVideoSizewith a width and height of 0 when the renderer is disabled.Player.Listener.onVideoSizeChangedis called accordingly whenPlayer.getVideoSize()changes. With this change, ExoPlayer's video size withMediaCodecVideoRendererhas a width and height of 0 whenPlayer.getCurrentTracksdoes not support video, or the size of the supported video track is not yet determined.
- Make
- DRM:
- Reduce the visibility of several internal-only methods on
DefaultDrmSessionthat aren't expected to be called from outside the DRM package:void onMediaDrmEvent(int)void provision()void onProvisionCompleted()onProvisionError(Exception, boolean)
- Reduce the visibility of several internal-only methods on
- Muxer:
- Add a new muxer library which can be used to create an MP4 container file.
- IMA extension:
- Enable multi-period live DASH streams for DAI. Please note that the current implementation does not yet support seeking in live streams (#10912).
- Fix a bug where a new ad group is inserted in live streams because the calculated content position in consecutive timelines varies slightly.
- Session:
- Add helper method
MediaSession.getControllerForCurrentRequestto obtain information about the controller that is currently calling aPlayermethod. - Add
androidx.media3.session.MediaButtonReceiverto enable apps to implement playback resumption with media button events sent by, for example, a Bluetooth headset (#167). - Add default implementation to
MediaSession.Callback.onAddMediaItemsto allow requestedMediaItemsto be passed ontoPlayerif they haveLocalConfiguration(e.g. URI) (#282). - Add "seek to previous" and "seek to next" command buttons on compact media notification view by default for Android 12 and below (#410).
- Add default implementation to
MediaSession.Callback.onAddMediaItemsto allow requestedMediaItemsto be passed ontoPlayerif they haveLocalConfiguration(e.g. URI) (#282). - Add "seek to previous" and "seek to next" command buttons on compact media notification view by default for Android 12 and below (#410).
- Add helper method
- UI:
- Add Util methods
shouldShowPlayButtonandhandlePlayPauseButtonActionto write custom UI elements with a play/pause button.
- Add Util methods
- RTSP Extension:
- DASH Extension:
- Remove the media time offset from
MediaLoadData.startTimeMsandMediaLoadData.endTimeMsfor multi period DASH streams. - Fix a bug where re-preparing a multi-period live Dash media source
produced a
IndexOutOfBoundsException(#10838).
- Remove the media time offset from
- HLS Extension:
- Add
HlsMediaSource.Factory.setTimestampAdjusterInitializationTimeoutMs(long)to set a timeout for the loading thread to wait for theTimestampAdjusterto initialize. If the initialization doesn't complete before the timeout, aPlaybackExceptionis thrown to avoid the playback endless stalling. The timeout is set to zero by default (#323).
- Add
- Test Utilities:
- Check for URI scheme case insensitivity in
DataSourceContractTest.
- Check for URI scheme case insensitivity in
- Remove deprecated symbols:
- Remove
DefaultAudioSinkconstructors, useDefaultAudioSink.Builderinstead. - Remove
HlsMasterPlaylist, useHlsMultivariantPlaylistinstead. - Remove
Player.stop(boolean). UsePlayer.stop()andPlayer.clearMediaItems()(ifresetistrue) instead. - Remove two deprecated
SimpleCacheconstructors, use a non-deprecated constructor that takes aDatabaseProviderinstead for better performance. - Remove
DefaultBandwidthMeterconstructor, useDefaultBandwidthMeter.Builderinstead. - Remove
DefaultDrmSessionManagerconstructors, useDefaultDrmSessionManager.Builderinstead. - Remove two deprecated
HttpDataSource.InvalidResponseCodeExceptionconstructors, use a non-deprecated constructor that accepts additional fields(cause,responseBody) to enhance error logging. - Remove
DownloadHelper.forProgressive,DownloadHelper.forHls,DownloadHelper.forDash, andDownloadHelper.forSmoothStreaming, useDownloadHelper.forMediaIteminstead. - Remove deprecated
DownloadServiceconstructor, use a non deprecated constructor that includes the option to provide achannelDescriptionResourceIdparameter. - Remove deprecated String constants for Charsets (
ASCII_NAME,UTF8_NAME,ISO88591_NAME,UTF16_NAMEandUTF16LE_NAME), use Kotlin Charsets from thekotlin.textpackage, thejava.nio.charset.StandardCharsetsor thecom.google.common.base.Charsetsinstead. - Remove deprecated
WorkManagerSchedulerconstructor, use a non deprecated constructor that includes the option to provide aContextparameter instead. - Remove the deprecated methods
createVideoSampleFormat,createAudioSampleFormat,createContainerFormat, andcreateSampleFormat, which were used to instantiate theFormatclass. Instead useFormat.Builderfor creating instances ofFormat. - Remove the deprecated methods
copyWithMaxInputSize,copyWithSubsampleOffsetUs,copyWithLabel,copyWithManifestFormatInfo,copyWithGaplessInfo,copyWithFrameRate,copyWithDrmInitData,copyWithMetadata,copyWithBitrateandcopyWithVideoSize, useFormat.buildUpon()and setter methods instead. - Remove deprecated
ExoPlayer.retry(), useprepare()instead. - Remove deprecated zero-arg
DefaultTrackSelectorconstructor, useDefaultTrackSelector(Context)instead. - Remove deprecated
OfflineLicenseHelperconstructor, useOfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)instead. - Remove deprecated
DownloadManagerconstructor, use the constructor that takes anExecutorinstead. - Remove deprecated
Cueconstructors, useCue.Builderinstead. - Remove deprecated
OfflineLicenseHelperconstructor, useOfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)instead. - Remove four deprecated
AnalyticsListenermethods:onDecoderEnabled, useonAudioEnabledand/oronVideoEnabledinstead.onDecoderInitialized, useonAudioDecoderInitializedand/oronVideoDecoderInitializedinstead.onDecoderInputFormatChanged, useonAudioInputFormatChangedand/oronVideoInputFormatChangedinstead.onDecoderDisabled, useonAudioDisabledand/oronVideoDisabledinstead.
- Remove the deprecated
Player.Listener.onSeekProcessedandAnalyticsListener.onSeekProcessed, useonPositionDiscontinuitywithDISCONTINUITY_REASON_SEEKinstead. - Remove
ExoPlayer.setHandleWakeLock(boolean), usesetWakeMode(int)instead. - Remove deprecated
DefaultLoadControl.Builder.createDefaultLoadControl(), usebuild()instead. - Remove deprecated
MediaItem.PlaybackProperties, useMediaItem.LocalConfigurationinstead. Deprecated fieldMediaItem.playbackPropertiesis now of typeMediaItem.LocalConfiguration.
- Remove
Version 1.1.0-rc01
June 21, 2023
Use the 1.1.0 stable version.
Version 1.1.0-beta01
June 7, 2023
Use the 1.1.0 stable version.
Version 1.1.0-alpha01
May 10, 2023
Use the 1.1.0 stable version.
Version 1.0.0
Version 1.0.2
May 18, 2023
androidx.media3:media3-*:1.0.2 is released.
Version 1.0.2 contains these commits.
This release corresponds to the ExoPlayer 2.18.7 release.
This release contains the following changes since the 1.0.1 release:
- Core library:
- Add
Buffer.isLastSample()that denotes ifBuffercontains flagC.BUFFER_FLAG_LAST_SAMPLE. - Fix issue where last frame may not be rendered if the last sample with frames is dequeued without reading the 'end of stream' sample. (#11079).
- Add
- Extractors:
- Fix parsing of H.265 SPS in MPEG-TS files by re-using the parsing logic already used by RTSP and MP4 extractors (#303).
- Text:
- SSA: Add support for UTF-16 files if they start with a byte order mark (#319).
- Session:
- Fix issue where
MediaControllerdoesn't update its available commands when connected to a legacyMediaSessionCompatthat updates its actions. - Fix bug that prevented the
MediaLibraryServicefrom returning null for a call from System UI toCallback.onGetLibraryRootwithparams.isRecent == trueon API 30 (#355). - Fix memory leak of
MediaSessionServiceorMediaLibraryService(#346). - Fix bug where a combined
Timelineand position update in aMediaSessionmay cause aMediaControllerto throw anIllegalStateException.
- Fix issue where
Version 1.0.1
April 18, 2023
androidx.media3:media3-*:1.0.1 is released.
Version 1.0.1 contains these commits.
This release corresponds to the ExoPlayer 2.18.6 release.
- Core library:
- Reset target live stream override when seeking to default position (#11051).
- Fix bug where empty sample streams in the media could cause playback to be stuck.
- Session:
- Fix bug where multiple identical queue items published by a legacy
MediaSessionCompatresult in an exception inMediaController(#290). - Add missing forwarding of
MediaSession.broadcastCustomCommandto the legacyMediaControllerCompat.Callback.onSessionEvent(#293). - Fix bug where calling
MediaSession.setPlayerdoesn't update the available commands. - Fix issue that
TrackSelectionOverrideinstances sent from aMediaControllerare ignored if they reference a group withFormat.metadata(#296). - Fix issue where
Player.COMMAND_GET_CURRENT_MEDIA_ITEMneeds to be available to access metadata via the legacyMediaSessionCompat. - Fix issue where
MediaSessioninstances on a background thread cause crashes when used inMediaSessionService(#318). - Fix issue where a media button receiver was declared by the library without the app having intended this (#314).
- Fix bug where multiple identical queue items published by a legacy
- DASH:
- Fix handling of empty segment timelines (#11014).
- RTSP:
- Retry with TCP if RTSP Setup with UDP fails with RTSP Error 461 UnsupportedTransport (#11069).
Version 1.0.0
March 22, 2023
androidx.media3:media3-*:1.0.0 is released.
Version 1.0.0 contains these commits.
This release corresponds to the ExoPlayer 2.18.5 release.
There are no changes since 1.0.0-rc02.
Version 1.0.0-rc02
March 2, 2023
androidx.media3:media3-*:1.0.0-rc02 is released.
Version 1.0.0-rc02 contains these commits.
This release corresponds to the ExoPlayer 2.18.4 release.
- Core library:
- Downloads:
- Make the maximum difference of the start time of two segments to be
merged configurable in
SegmentDownloaderand subclasses (#248).
- Make the maximum difference of the start time of two segments to be
merged configurable in
- Audio:
- Video:
- Map HEVC HDR10 format to
HEVCProfileMain10HDR10instead ofHEVCProfileMain10. - Add workaround for a device issue on Chromecast with Google TV and Lenovo M10 FHD Plus that causes 60fps AVC streams to be marked as unsupported (#10898).
- Fix frame release performance issues when playing media with a frame rate far higher than the screen refresh rate.
- Map HEVC HDR10 format to
- Cast:
- Fix transient
STATE_IDLEwhen transitioning between media items (#245).
- Fix transient
- RTSP:
- Catch the IllegalArgumentException thrown in parsing of invalid RTSP Describe response messages (#10971).
- Session:
- Fix a bug where notification play/pause button doesn't update with player state (#192).
- IMA extension:
- Fix a bug which prevented DAI streams without any ads from starting
because the first (and in the case without ads the only)
LOADEDevent wasn't received.
- Fix a bug which prevented DAI streams without any ads from starting
because the first (and in the case without ads the only)
Version 1.0.0-rc01
February 16, 2023
androidx.media3:media3-*:1.0.0-rc01 is released.
Version 1.0.0-rc01 contains these commits.
This release corresponds to the ExoPlayer 2.18.3 release.
- Core library:
- Tweak the renderer's decoder ordering logic to uphold the
MediaCodecSelector's preferences, even if a decoder reports it may not be able to play the media performantly. For example with default selector, hardware decoder with only functional support will be preferred over software decoder that fully supports the format (#10604). - Add
ExoPlayer.Builder.setPlaybackLooperthat sets a pre-existing playback thread for a new ExoPlayer instance. - Allow download manager helpers to be cleared (#10776).
- Add parameter to
BasePlayer.seekToto also indicate the command used for seeking. - Use theme when loading drawables on API 21+ (#220).
- Add
ConcatenatingMediaSource2that allows combining multiple media items into a single window (#247).
- Tweak the renderer's decoder ordering logic to uphold the
- Extractors:
- Throw a
ParserExceptioninstead of aNullPointerExceptionif the sample table (stbl) is missing a required sample description (stsd) when parsing trak atoms. - Correctly skip samples when seeking directly to a sync frame in fMP4 (#10941).
- Throw a
- Audio:
- Use the compressed audio format bitrate to calculate the min buffer size
for
AudioTrackin direct playbacks (passthrough).
- Use the compressed audio format bitrate to calculate the min buffer size
for
- Text:
- Fix
TextRendererpassing an invalid (negative) index toSubtitle.getEventTimeif a subtitle file contains no cues. - SubRip: Add support for UTF-16 files if they start with a byte order mark.
- Fix
- Metadata:
- Parse multiple null-separated values from ID3 frames, as permitted by ID3 v2.4.
- Add
MediaMetadata.mediaTypeto denote the type of content or the type of folder described by the metadata. - Add
MediaMetadata.isBrowsableas a replacement forMediaMetadata.folderType. The folder type will be deprecated in the next release.
- DASH:
- Add full parsing for image adaptation sets, including tile counts (#3752).
- UI:
- Session:
- Add abstract
SimpleBasePlayerto help implement thePlayerinterface for custom players. - Add helper method to convert platform session token to Media3
SessionToken(#171). - Use
onMediaMetadataChangedto trigger updates of the platform media session (#219). - Add the media session as an argument of
getMediaButtons()of theDefaultMediaNotificationProviderand use immutable lists for clarity (#216). - Add
onSetMediaItemscallback listener to provide means to modify/setMediaItemlist, starting index and position by session before setting onto Player (#156). - Avoid double tap detection for non-Bluetooth media button events (#233).
- Make
QueueTimelinemore robust in case of a shady legacy session state (#241).
- Add abstract
- Metadata:
- Parse multiple null-separated values from ID3 frames, as permitted by ID3 v2.4.
- Add
MediaMetadata.mediaTypeto denote the type of content or the type of folder described by the metadata. - Add
MediaMetadata.isBrowsableas a replacement forMediaMetadata.folderType. The folder type will be deprecated in the next release.
- Cast extension:
- Bump Cast SDK version to 21.2.0.
- IMA extension:
- Remove player listener of the
ImaServerSideAdInsertionMediaSourceon the application thread to avoid threading issues. - Add a property
focusSkipButtonWhenAvailableto theImaServerSideAdInsertionMediaSource.AdsLoader.Builderto request focusing the skip button on TV devices and set it to true by default. - Add a method
focusSkipButton()to theImaServerSideAdInsertionMediaSource.AdsLoaderto programmatically request to focus the skip button. - Bump IMA SDK version to 3.29.0.
- Remove player listener of the
- Demo app:
- Request notification permission for download notifications at runtime (#10884).
Version 1.0.0-beta03
November 22, 2022
androidx.media3:media3-*:1.0.0-beta03 is released.
Version 1.0.0-beta03 contains these commits.
This release corresponds to the ExoPlayer 2.18.2 release.
- Core library:
- Add
ExoPlayer.isTunnelingEnabledto check if tunneling is enabled for the currently selected tracks (#2518). - Add
WrappingMediaSourceto simplify wrapping a singleMediaSource(#7279). - Discard back buffer before playback gets stuck due to insufficient available memory.
- Close the Tracing "doSomeWork" block when offload is enabled.
- Fix session tracking problem with fast seeks in
PlaybackStatsListener(#180). - Send missing
onMediaItemTransitioncallback when callingseekToNextorseekToPreviousin a single-item playlist (#10667). - Add
Player.getSurfaceSizethat returns the size of the surface on which the video is rendered. - Fix bug where removing listeners during the player release can cause an
IllegalStateException(#10758).
- Add
- Build:
- Enforce minimum
compileSdkVersionto avoid compilation errors (#10684). - Avoid publishing block when included in another gradle build.
- Enforce minimum
- Track selection:
- Prefer other tracks to Dolby Vision if display does not support it. (#8944).
- Downloads:
- Video:
- Try alternative decoder for Dolby Vision if display does not support it. (#9794).
- Audio:
- Use
SingleThreadExecutorfor releasingAudioTrackinstances to avoid OutOfMemory errors when releasing multiple players at the same time (#10057). - Adds
AudioOffloadListener.onExperimentalOffloadedPlaybackfor the AudioTrack offload state. (#134). - Make
AudioTrackBufferSizeProvidera public interface. - Add
ExoPlayer.setPreferredAudioDeviceto set the preferred audio output device (#135). - Rename
androidx.media3.exoplayer.audio.AudioProcessortoandroidx.media3.common.audio.AudioProcessor. - Map 8-channel and 12-channel audio to the 7.1 and 7.1.4 channel masks respectively on all Android versions (#10701).
- Use
- Metadata:
MetadataRenderercan now be configured to render metadata as soon as they are available. Create an instance withMetadataRenderer(MetadataOutput, Looper, MetadataDecoderFactory, boolean)to specify whether the renderer will output metadata early or in sync with the player position.
- DRM:
- Work around a bug in the Android 13 ClearKey implementation that returns a non-empty but invalid license URL.
- Fix
setMediaDrmSession failed: session not openederror when switching between DRM schemes in a playlist (e.g. Widevine to ClearKey).
- Text:
- CEA-608: Ensure service switch commands on field 2 are handled correctly (#10666).
- DASH:
- Parse
EventStream.presentationTimeOffsetfrom manifests (#10460).
- Parse
- UI:
- Use current overrides of the player as preset in
TrackSelectionDialogBuilder(#10429).
- Use current overrides of the player as preset in
- Session:
- Ensure commands are always executed in the correct order even if some require asynchronous resolution (#85).
- Add
DefaultMediaNotificationProvider.Builderto buildDefaultMediaNotificationProviderinstances. The builder can configure the notification ID, the notification channel ID and the notification channel name used by the provider. Also, add methodDefaultMediaNotificationProvider.setSmallIcon(int)to set the notifications small icon. (#104). - Ensure commands sent before
MediaController.release()are not dropped (#99). SimpleBitmapLoadercan load bitmap fromfile://URIs (#108).- Fix assertion that prevents
MediaControllerto seek over an ad in a period (#122). - When playback ends, the
MediaSessionServiceis stopped from the foreground and a notification is shown to restart playback of the last played media item (#112). - Don't start a foreground service with a pending intent for pause (#167).
- Manually hide the 'badge' associated with the notification created by
DefaultNotificationProvideron API 26 and API 27 (the badge is automatically hidden on API 28+) (#131). - Fix bug where a second binder connection from a legacy MediaSession to a Media3 MediaController causes IllegalStateExceptions (#49).
- RTSP:
- IMA:
- Add timeout for loading ad information to handle cases where the IMA SDK gets stuck loading an ad (#10510).
- Prevent skipping mid-roll ads when seeking to the end of the content (#10685).
- Correctly calculate window duration for live streams with server-side inserted ads, for example IMA DAI (#10764).
- FFmpeg extension:
- Add newly required flags to link FFmpeg libraries with NDK 23.1.7779620 and above (#9933).
- AV1 extension:
- Update CMake version to avoid incompatibilities with the latest Android Studio releases (#9933).
- Cast extension:
- Implement
getDeviceInfo()to be able to identifyCastPlayerwhen controlling playback with aMediaController(#142).
- Implement
- Transformer:
- Add muxer watchdog timer to detect when generating an output sample is too slow.
- Remove deprecated symbols:
- Remove
Transformer.Builder.setOutputMimeType(String). This feature has been removed. The MIME type will always be MP4 when the default muxer is used.
- Remove
Version 1.0.0-beta02
July 21, 2022
androidx.media3:media3-*:1.0.0-beta02 is released.
Version 1.0.0-beta02 contains these commits.
This release corresponds to the ExoPlayer 2.18.1 release.
- Core library:
- Ensure that changing the
ShuffleOrderwithExoPlayer.setShuffleOrderresults in a call toPlayer.Listener#onTimelineChangedwithreason=Player.TIMELINE_CHANGE_REASON_PLAYLIST_CHANGED(#9889). - For progressive media, only include selected tracks in buffered position (#10361).
- Allow custom logger for all ExoPlayer log output (#9752).
- Fix implementation of
setDataSourceFactoryinDefaultMediaSourceFactory, which was non-functional in some cases (#116).
- Ensure that changing the
- Extractors:
- DASH:
- Parse ClearKey license URL from manifests (#10246).
- UI:
- Ensure TalkBack announces the currently active speed option in the playback controls menu (#10298).
- RTSP:
- Add VP8 fragmented packet handling (#110).
- Leanback extension:
- Listen to
playWhenReadychanges inLeanbackAdapter(10420).
- Listen to
- Cast:
Version 1.0.0-beta01
June 16, 2022
androidx.media3:media3-*:1.0.0-beta01 is released.
Version 1.0.0-beta01 contains these commits.
This corresponds to the ExoPlayer 2.18.0 release.
- Core library:
- Enable support for Android platform diagnostics via
MediaMetricsManager. ExoPlayer will forward playback events and performance data to the platform, which helps to provide system performance and debugging information on the device. This data may also be collected by Google if sharing usage and diagnostics data is enabled by the user of the device. Apps can opt-out of contributing to platform diagnostics for ExoPlayer withExoPlayer.Builder.setUsePlatformDiagnostics(false). - Fix bug that tracks are reset too often when using
MergingMediaSource, for example when side-loading subtitles and changing the selected subtitle mid-playback (#10248). - Stop detecting 5G-NSA network type on API 29 and 30. These playbacks will assume a 4G network.
- Disallow passing
nulltoMediaSource.Factory.setDrmSessionManagerProviderandMediaSource.Factory.setLoadErrorHandlingPolicy. Instances ofDefaultDrmSessionManagerProviderandDefaultLoadErrorHandlingPolicycan be passed explicitly if required. - Add
MediaItem.RequestMetadatato represent metadata needed to play media when the exactLocalConfigurationis not known. Also removeMediaMetadata.mediaUrlas this is now included inRequestMetadata. - Add
Player.Command.COMMAND_SET_MEDIA_ITEMto enable players to allow setting a single item.
- Enable support for Android platform diagnostics via
- Track selection:
- Flatten
TrackSelectionOverridesclass intoTrackSelectionParameters, and promoteTrackSelectionOverrideto a top level class. - Rename
TracksInfotoTracksandTracksInfo.TrackGroupInfotoTracks.Group.Player.getCurrentTracksInfoandPlayer.Listener.onTracksInfoChangedhave also been renamed toPlayer.getCurrentTracksandPlayer.Listener.onTracksChanged. This includes 'un-deprecating' thePlayer.Listener.onTracksChangedmethod name, but with different parameter types. - Change
DefaultTrackSelector.buildUponParametersandDefaultTrackSelector.Parameters.buildUponto returnDefaultTrackSelector.Parameters.Builderinstead of the deprecatedDefaultTrackSelector.ParametersBuilder. - Add
DefaultTrackSelector.Parameters.constrainAudioChannelCountToDeviceCapabilitieswhich is enabled by default. When enabled, theDefaultTrackSelectorwill prefer audio tracks whose channel count does not exceed the device output capabilities. On handheld devices, theDefaultTrackSelectorwill prefer stereo/mono over multichannel audio formats, unless the multichannel format can be Spatialized (Android 12L+) or is a Dolby surround sound format. In addition, on devices that support audio spatialization, theDefaultTrackSelectorwill monitor for changes in the Spatializer properties and trigger a new track selection upon these. Devices with atelevisionUI mode are excluded from these constraints and the format with the highest channel count will be preferred. To enable this feature, theDefaultTrackSelectorinstance must be constructed with aContext.
- Flatten
- Video:
- Rename
DummySurfacetoPlaceholderSurface. - Add AV1 support to the
MediaCodecVideoRenderer.getCodecMaxInputSize.
- Rename
- Audio:
- Use LG AC3 audio decoder advertising non-standard MIME type.
- Change the return type of
AudioAttributes.getAudioAttributesV21()fromandroid.media.AudioAttributesto a newAudioAttributesV21wrapper class, to prevent slow ART verification on API < 21. - Query the platform (API 29+) or assume the audio encoding channel count for audio passthrough when the format audio channel count is unset, which occurs with HLS chunkless preparation (10204).
- Configure
AudioTrackwith channel maskAudioFormat.CHANNEL_OUT_7POINT1POINT4if the decoder outputs 12 channel PCM audio (#10322.
- DRM
- Ensure the DRM session is always correctly updated when seeking immediately after a format change (10274).
- Text:
- Change
Player.getCurrentCues()to returnCueGroupinstead ofList<Cue>. - SSA: Support
OutlineColourstyle setting whenBorderStyle == 3(i.e.OutlineColoursets the background of the cue) (#8435). - CEA-708: Parse data into multiple service blocks and ignore blocks not associated with the currently selected service number.
- Remove
RawCcExtractor, which was only used to handle a Google-internal subtitle format.
- Change
- Extractors:
- UI:
- Fix delivery of events to
OnClickListeners set onPlayerViewin the case thatuseController=false(#9605). Also fix delivery of events toOnLongClickListenerfor all view configurations. - Fix incorrectly treating a sequence of touch events that exit the bounds
of
PlayerViewbeforeACTION_UPas a click (#9861). - Fix
PlayerViewaccessibility issue where tapping might toggle playback rather than hiding the controls (#8627). - Rewrite
TrackSelectionViewandTrackSelectionDialogBuilderto work with thePlayerinterface rather thanExoPlayer. This allows the views to be used with otherPlayerimplementations, and removes the dependency from the UI module to the ExoPlayer module. This is a breaking change. - Don't show forced text tracks in the
PlayerViewtrack selector, and keep a suitable forced text track selected if "None" is selected (#9432).
- Fix delivery of events to
- DASH:
- Parse channel count from DTS
AudioChannelConfigurationelements. This re-enables audio passthrough for DTS streams (#10159). - Disallow passing
nulltoDashMediaSource.Factory.setCompositeSequenceableLoaderFactory. Instances ofDefaultCompositeSequenceableLoaderFactorycan be passed explicitly if required.
- Parse channel count from DTS
- HLS:
- Fallback to chunkful preparation if the playlist CODECS attribute does not contain the audio codec (#10065).
- Disallow passing
nulltoHlsMediaSource.Factory.setCompositeSequenceableLoaderFactory,HlsMediaSource.Factory.setPlaylistParserFactory, andHlsMediaSource.Factory.setPlaylistTrackerFactory. Instances ofDefaultCompositeSequenceableLoaderFactory,DefaultHlsPlaylistParserFactory, or a reference toDefaultHlsPlaylistTracker.FACTORYcan be passed explicitly if required.
- Smooth Streaming:
- Disallow passing
nulltoSsMediaSource.Factory.setCompositeSequenceableLoaderFactory. Instances ofDefaultCompositeSequenceableLoaderFactorycan be passed explicitly if required.
- Disallow passing
- RTSP:
- Add RTP reader for H263 (#63).
- Add RTP reader for MPEG4 (#35).
- Add RTP reader for HEVC (#36).
- Add RTP reader for AMR. Currently only mono-channel, non-interleaved AMR streams are supported. Compound AMR RTP payload is not supported. (#46)
- Add RTP reader for VP8 (#47).
- Add RTP reader for WAV (#56).
- Fix RTSP basic authorization header. (#9544).
- Stop checking mandatory SDP fields as ExoPlayer doesn't need them (#10049).
- Throw checked exception when parsing RTSP timing (#10165).
- Add RTP reader for VP9 (#47).
- Add RTP reader for OPUS (#53).
- Data sources:
- Rename
DummyDataSourcetoPlaceholderDataSource. - Workaround OkHttp interrupt handling.
- Rename
- Session:
- Replace
MediaSession.MediaItemFillerwithMediaSession.Callback.onAddMediaItemsto allow asynchronous resolution of requests. - Support
setMediaItems(s)methods whenMediaControllerconnects to a legacy media session. - Remove
MediaController.setMediaUriandMediaSession.Callback.onSetMediaUri. The same functionality can be achieved by usingMediaController.setMediaItemandMediaSession.Callback.onAddMediaItems. - Forward legacy
MediaControllercalls to play media toMediaSession.Callback.onAddMediaItemsinstead ofonSetMediaUri. - Add
MediaNotification.ProviderandDefaultMediaNotificationProviderto provide customization of the notification. - Add
BitmapLoaderandSimpleBitmapLoaderfor downloading artwork images. - Add
MediaSession.setCustomLayout()to provide backwards compatibility with the legacy session. - Add
MediaSession.setSessionExtras()to provide feature parity with legacy session. - Rename
MediaSession.MediaSessionCallbacktoMediaSession.Callback,MediaLibrarySession.MediaLibrarySessionCallbacktoMediaLibrarySession.CallbackandMediaSession.Builder.setSessionCallbacktosetCallback. - Fix NPE in
MediaControllerImplLegacy(#59). - Update session position info on timeline change(#51).
- Fix NPE in
MediaControllerImplBaseafter releasing controller (#74).
- Replace
- Ad playback / IMA:
- Decrease ad polling rate from every 100ms to every 200ms, to line up with Media Rating Council (MRC) recommendations.
- FFmpeg extension:
- Update CMake version to
3.21.0+to avoid a CMake bug causing AndroidStudio's gradle sync to fail (#9933).
- Update CMake version to
- Remove deprecated symbols:
- Remove
Player.Listener.onTracksChanged(TrackGroupArray, TrackSelectionArray). UsePlayer.Listener.onTracksChanged(Tracks)instead. - Remove
Player.getCurrentTrackGroupsandPlayer.getCurrentTrackSelections. UsePlayer.getCurrentTracksinstead. You can also continue to useExoPlayer.getCurrentTrackGroupsandExoPlayer.getCurrentTrackSelections, although these methods remain deprecated. - Remove
DownloadHelperDEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_VIEWPORTandDEFAULT_TRACK_SELECTOR_PARAMETERSconstants. UsegetDefaultTrackSelectorParameters(Context)instead when possible, andDEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_CONTEXTotherwise. - Remove constructor
DefaultTrackSelector(ExoTrackSelection.Factory). UseDefaultTrackSelector(Context, ExoTrackSelection.Factory)instead. - Remove
Transformer.Builder.setContext. TheContextshould be passed to theTransformer.Builderconstructor instead.
- Remove
Version 1.0.0-alpha03
March 14, 2022
androidx.media3:media3-*:1.0.0-alpha03 is released.
Version 1.0.0-alpha03 contains these commits.
This corresponds to the ExoPlayer 2.17.1 release.
- Audio:
- Fix error checking audio capabilities for Dolby Atmos (E-AC3-JOC) in HLS.
- Extractors:
- FMP4: Fix issue where emsg sample metadata could be output in the wrong order for streams containing both v0 and v1 emsg atoms (#9996).
- Text:
- Fix the interaction of
SingleSampleMediaSource.Factory.setTrackIdandMediaItem.SubtitleConfiguration.Builder.setIdto prioritise theSubtitleConfigurationfield and fall back to theFactoryvalue if it's not set (#10016).
- Fix the interaction of
- Ad playback:
- Fix audio underruns between ad periods in live HLS SSAI streams.
Version 1.0.0-alpha02
March 2, 2022
androidx.media3:media3-*:1.0.0-alpha02 is released.
Version 1.0.0-alpha02 contains these commits.
This corresponds to the ExoPlayer 2.17.0 release.
- Core Library:
- Add protected method
DefaultRenderersFactory.getCodecAdapterFactory()so that subclasses ofDefaultRenderersFactorythat overridebuildVideoRenderers()orbuildAudioRenderers()can access the codec adapter factory and pass it toMediaCodecRendererinstances they create. - Propagate ICY header fields
nameandgenretoMediaMetadata.stationandMediaMetadata.genrerespectively so that they reach the app viaPlayer.Listener.onMediaMetadataChanged()(#9677). - Remove null keys from
DefaultHttpDataSource#getResponseHeaders. - Sleep and retry when creating a
MediaCodecinstance fails. This works around an issue that occurs on some devices when switching a surface from a secure codec to another codec (#8696). - Add
MediaCodecAdapter.getMetrics()to allow users obtain metrics data fromMediaCodec. (#9766). - Fix Maven dependency resolution (#8353).
- Disable automatic speed adjustment for live streams that neither have low-latency features nor a user request setting the speed (#9329).
- Rename
DecoderCounters#inputBufferCounttoqueuedInputBufferCount. - Make
SimpleExoPlayer.renderersprivate. Renderers can be accessed viaExoPlayer.getRenderer. - Updated some
AnalyticsListener.EventFlagsconstant values to match values inPlayer.EventFlags. - Split
AnalyticsCollectorinto an interface and default implementation to allow it to be stripped by R8 if an app doesn't need it.
- Add protected method
- Track selection:
- Support preferred video role flags in track selection (#9402).
- Update video track selection logic to take preferred MIME types and role flags into account when selecting multiple video tracks for adaptation (#9519).
- Update video and audio track selection logic to only choose formats for adaptive selections that have the same level of decoder and hardware support (#9565).
- Update video track selection logic to prefer more efficient codecs if multiple codecs are supported by primary, hardware-accelerated decoders (#4835).
- Prefer audio content preferences (for example, the "default" audio track or a track matching the system locale language) over technical track selection constraints (for example, preferred MIME type, or maximum channel count).
- Fix track selection issue where overriding one track group did not disable other track groups of the same type (#9675).
- Fix track selection issue where a mixture of non-empty and empty track overrides is not applied correctly (#9649).
- Prohibit duplicate
TrackGroups in aTrackGroupArray.TrackGroups can always be made distinguishable by setting anidin theTrackGroupconstructor. This fixes a crash when resuming playback after backgrounding the app with an active track override (#9718). - Amend logic in
AdaptiveTrackSelectionto allow a quality increase under sufficient network bandwidth even if playback is very close to the live edge (#9784).
- Video:
- Fix decoder fallback logic for Dolby Vision to use a compatible H264/H265 decoder if needed.
- Audio:
- Fix decoder fallback logic for Dolby Atmos (E-AC3-JOC) to use a compatible E-AC3 decoder if needed.
- Change
AudioCapabilitiesAPIs to require passing explicitlyAudioCapabilities.DEFAULT_AUDIO_CAPABILITIESinstead ofnull. - Allow customization of the
AudioTrackbuffer size calculation by injecting anAudioTrackBufferSizeProvidertoDefaultAudioSink. (#8891). - Retry
AudioTrackcreation if the requested buffer size was > 1MB. (#9712).
- Extractors:
- Text:
- Add a
MediaItem.SubtitleConfiguration.idfield which is propagated to theFormat.idfield of the subtitle track created from the configuration (#9673). - Add basic support for WebVTT subtitles in Matroska containers (#9886).
- Prevent
Cea708Decoderfrom reading more than the declared size of a service block.
- Add a
- DRM:
- Remove
playbackLooperfromDrmSessionManager.(pre)acquireSession. When aDrmSessionManageris used by an app in a customMediaSource, theplaybackLooperneeds to be passed toDrmSessionManager.setPlayerinstead.
- Remove
- Ad playback / IMA:
- Add support for IMA Dynamic Ad Insertion (DAI) (#8213).
- Add a method to
AdPlaybackStateto allow resetting an ad group so that it can be played again (#9615). - Enforce playback speed of 1.0 during ad playback (#9018).
- Fix issue where an ad group that failed to load caused an immediate playback reset (#9929).
- UI:
- DASH:
- Add parsed essential and supplemental properties to the
Representation(#9579). - Support the
forced-subtitletrack role (#9727). - Stop interpreting the
maintrack role asC.SELECTION_FLAG_DEFAULT. - Fix base URL exclusion logic for manifests that do not declare the DVB namespace (#9856).
- Support relative
MPD.LocationURLs (#9939).
- Add parsed essential and supplemental properties to the
- HLS:
- Correctly populate
Format.labelfor audio only HLS streams (#9608). - Use chunkless preparation by default to improve start up time. If your
renditions contain muxed closed-caption tracks that are not declared
in the master playlist, you should add them to the master playlist to be
available for playback, or turn off chunkless preparation with
HlsMediaSource.Factory.setAllowChunklessPreparation(false). - Support key-frame accurate seeking in HLS (#2882).
- Correctly populate
- RTSP:
- Transformer:
- Increase required min API version to 21.
TransformationExceptionis now used to describe errors that occur during a transformation.- Add
TransformationRequestfor specifying the transformation options. - Allow multiple listeners to be registered.
- Fix Transformer being stuck when the codec output is partially read.
- Fix potential NPE in
Transformer.getProgresswhen releasing the muxer throws. - Add a demo app for applying transformations.
- MediaSession extension:
- By default,
MediaSessionConnectornow clears the playlist on stop. Apps that want the playlist to be retained can callsetClearMediaItemsOnStop(false)on the connector.
- By default,
- Cast extension:
- FFmpeg extension:
- Make
build_ffmpeg.shdepend on LLVM's bin utils instead of GNU's (#9933).
- Make
- Android 12 compatibility:
- Upgrade the Cast extension to depend on
com.google.android.gms:play-services-cast-framework:20.1.0. Earlier versions ofplay-services-cast-frameworkare not compatible with apps targeting Android 12, and will crash with anIllegalArgumentExceptionwhen creatingPendingIntents (#9528).
- Upgrade the Cast extension to depend on
- Remove deprecated symbols:
- Remove
Player.EventListener. UsePlayer.Listenerinstead. - Remove
MediaSourceFactory#setDrmSessionManager,MediaSourceFactory#setDrmHttpDataSourceFactory, andMediaSourceFactory#setDrmUserAgent. UseMediaSourceFactory#setDrmSessionManagerProviderinstead. - Remove
MediaSourceFactory#setStreamKeys. UseMediaItem.Builder#setStreamKeysinstead. - Remove
MediaSourceFactory#createMediaSource(Uri). UseMediaSourceFactory#createMediaSource(MediaItem)instead. - Remove
setTagfromDashMediaSource,HlsMediaSourceandSsMediaSource. UseMediaItem.Builder#setTaginstead. - Remove
DashMediaSource#setLivePresentationDelayMs(long, boolean). UseMediaItem.Builder#setLiveConfigurationandMediaItem.LiveConfiguration.Builder#setTargetOffsetMsto override the manifest, orDashMediaSource#setFallbackTargetLiveOffsetMsto provide a fallback value. - Remove
(Simple)ExoPlayer.setThrowsWhenUsingWrongThread. Opting out of the thread enforcement is no longer possible. - Remove
ActionFileandActionFileUpgradeUtil. Use ExoPlayer 2.16.1 or before to useActionFileUpgradeUtilto merge legacy action files intoDefaultDownloadIndex. - Remove
ProgressiveMediaSource#setExtractorsFactory. UseProgressiveMediaSource.Factory(DataSource.Factory, ExtractorsFactory)constructor instead. - Remove
ProgressiveMediaSource.Factory#setTagand, andProgressiveMediaSource.Factory#setCustomCacheKey. UseMediaItem.Builder#setTagandMediaItem.Builder#setCustomCacheKeyinstead. - Remove
DefaultRenderersFactory(Context, @ExtensionRendererMode int)andDefaultRenderersFactory(Context, @ExtensionRendererMode int, long)constructors. Use theDefaultRenderersFactory(Context)constructor,DefaultRenderersFactory#setExtensionRendererMode, andDefaultRenderersFactory#setAllowedVideoJoiningTimeMsinstead. - Remove all public
CronetDataSourceconstructors. UseCronetDataSource.Factoryinstead.
- Remove
- Change the following
IntDefsto@Target(TYPE_USE)only. This may break the compilation of usages in Kotlin, which can be fixed by moving the annotation to annotate the type (Int).@AacAudioObjectType@Ac3Util.SyncFrameInfo.StreamType@AdLoadException.Type@AdtsExtractor.Flags@AmrExtractor.Flags@AspectRatioFrameLayout.ResizeMode@AudioFocusManager.PlayerCommand@AudioSink.SinkFormatSupport@BinarySearchSeeker.TimestampSearchResult.Type@BufferReplacementMode@C.BufferFlags@C.ColorRange@C.ColorSpace@C.ColorTransfer@C.CryptoMode@C.Encoding@C.PcmEncoding@C.Projection@C.SelectionReason@C.StereoMode@C.VideoOutputMode@CacheDataSource.Flags@CaptionStyleCompat.EdgeType@DataSpec.Flags@DataSpec.HttpMethods@DecoderDiscardReasons@DecoderReuseResult@DefaultAudioSink.OutputMode@DefaultDrmSessionManager.Mode@DefaultTrackSelector.SelectionEligibility@DefaultTsPayloadReaderFactory.Flags@EGLSurfaceTexture.SecureMode@EbmlProcessor.ElementType@ExoMediaDrm.KeyRequest.RequestType@ExtensionRendererMode@Extractor.ReadResult@FileTypes.Type@FlacExtractor.Flags(incom.google.android.exoplayer2.ext.flacpackage)@FlacExtractor.Flags(incom.google.android.exoplayer2.extractor.flacpackage)@FragmentedMp4Extractor.Flags@HlsMediaPlaylist.PlaylistType@HttpDataSourceException.Type@IllegalClippingException.Reason@IllegalMergeException.Reason@LoadErrorHandlingPolicy.FallbackType@MatroskaExtractor.Flags@Mp3Extractor.Flags@Mp4Extractor.Flags@NotificationUtil.Importance@PlaybackException.FieldNumber@PlayerNotificationManager.Priority@PlayerNotificationManager.Visibility@PlayerView.ShowBuffering@Renderer.State@RendererCapabilities.AdaptiveSupport@RendererCapabilities.Capabilities@RendererCapabilities.DecoderSupport@RendererCapabilities.FormatSupport@RendererCapabilities.HardwareAccelerationSupport@RendererCapabilities.TunnelingSupport@SampleStream.ReadDataResult@SampleStream.ReadFlags@StyledPlayerView.ShowBuffering@SubtitleView.ViewType@TextAnnotation.Position@TextEmphasisSpan.MarkFill@TextEmphasisSpan.MarkShape@Track.Transformation@TrackOutput.SampleDataPart@Transformer.ProgressState@TsExtractor.Mode@TsPayloadReader.Flags@WebvttCssStyle.FontSizeUnit
Version 1.0.0-alpha01
October 27, 2021
androidx.media3:media3-*:1.0.0-alpha01 is released.
Version 1.0.0-alpha01 contains these commits.
New features
Media3 is the new home for media support libraries, including ExoPlayer. The first alpha contains early, functional implementations of libraries for implementing media use cases, including:
- ExoPlayer, an application-level media player for Android that is easy to customize and extend.
- Media session functionality, for exposing and controlling playbacks. This new
session module uses the same
Playerinterface as ExoPlayer. - UI components for building media playback user interfaces.
- Modules wrapping functionality in other libraries for use with ExoPlayer, for example, ad insertion via the IMA SDK.
For more information, see the Media3 GitHub project.
ExoPlayer was previously hosted in a separate
ExoPlayer GitHub project. In Media3 its
package name is androidx.media3.exoplayer. We plan to continue to maintain and
release the ExoPlayer GitHub project for a while to give apps time to migrate to
Media3. Media3 has replacements for all the ExoPlayer modules, except for the
legacy media2 and mediasession extensions, which are replaced by the new
media3-session module. This provides direct integration between players and
media sessions without needing to use an adapter/connector class.