Releases: androidx/media
Releases · androidx/media
1.6.0-alpha02
- Common Library:
- Fix bug in
SimpleBasePlayerwhere setting a newcurrentMediaItemIndexinStateaftersetPlaylistwithnullMediaMetadatadoes not reevaluate the metadata (#1940).
- Fix bug in
- ExoPlayer:
- 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. - 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. - Initialize
DeviceInfoand device volume asynchronously (if enabled usingsetDeviceVolumeControlEnabled). These values aren't available instantly afterExoPlayer.Builder.build(), andPlayer.Listenernotifies changes throughonDeviceInfoChangedandonDeviceVolumeChanged. - Reevaluate whether the ongoing load of a chunk should be cancelled when playback is paused (#1785).
- Add experimental 'ExoPlayer' pre-warming support for playback using
- Transformer:
- 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 support for transcoding and transmuxing Dolby Vision (profile 8) format.
- Enable support for Android platform diagnostics using
- Extractors:
- 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).
- Audio:
- 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.
- Don't bypass
- Text:
- 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).
- Add support for VobSub subtitles (#8260).
- 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).
- TTML: Add support for referencing
- Muxers:
- Renamed
setSampleCopyEnabled()method tosetSampleCopyingEnabled()in bothMp4Muxer.BuilderandFragmentedMp4Muxer.Builder. Mp4Muxer.addTrack()andFragmentedMp4Muxer.addTrack()now return aninttrack ID instead of aTrackToken.Mp4MuxerandFragmentedMp4Muxerno longer implementMuxerinterface.
- Renamed
- Session:
- Fix bug where calling a
Playermethod on aMediaControllerconnected to a legacy session dropped changes from a pending update.
- Fix bug where calling a
- UI:
- Add
PresentationStatestate holder class and the correspondingrememberPresentationStateComposable tomedia3-ui-compose.
- Add
- HLS Extension:
- Parse
SUPPLEMENTAL-CODECStag from HLS playlist to detect Dolby Vision formats (#1785).
- Parse
- DASH Extension:
- 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).
- Demo app:
- Use
PresentationStateto control the aspect ratio ofPlayerSurfaceComposable. This depends on the ContentScale type and covers it with a shutter-overlay before the first frame is rendered.
- Use
- Remove deprecated symbols:
- Removed
ExoPlayer.VideoComponent,ExoPlayer.AudioComponent,ExoPlayer.TextComponentandExoPlayer.DeviceComponent.
- Removed
1.6.0-alpha01
This release includes the following changes since the 1.5.1 release:
- Common Library:
- Remove
Format.toBundle(boolean excludeMetadata)method, useFormat.toBundle()instead. - Add
AudioManagerCompatandAudioFocusRequestCompatto replace the equivalent classes inandroidx.media.
- Remove
- ExoPlayer:
- 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).
- Reduce default values for
bufferForPlaybackMsandbufferForPlaybackAfterRebufferMsinDefaultLoadControlto 1000 and 2000 ms respectively. - Add
MediaExtractorCompat, a new class that provides equivalent functionality to platformMediaExtractor. - 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.
- 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
- Transformer:
- Update parameters of
VideoFrameProcessor.registerInputStreamandVideoFrameProcessor.Listener.onInputStreamRegisteredto useFormat. - Add support for transmuxing into alternative backwards compatible formats.
- Generate HDR static metadata when using
DefaultEncoderFactory.
- Update parameters of
- 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.
- Audio:
- Fix
onAudioPositionAdvancingto be called when playback resumes (previously it was called when playback was paused).
- Fix
- Video:
- Fix
MediaCodecVideoRenderersuch that when without aSurface, the renderer will skip just-early frames only if theVideoFrameReleaseControl.getFrameReleaseActionis notFRAME_RELEASE_TRY_AGAIN_LATER.
- Fix
- Text:
- Stop eagerly loading all subtitle files configured with
MediaItem.Builder.setSubtitleConfigurations, and instead only load one if it is selected by track selection (#1721).
- Stop eagerly loading all subtitle files configured with
- 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.
- Moved
- Session:
- Add
Contextas a parameter toMediaButtonReceiver.shouldStartForegroundService(#1887).
- Add
- UI:
- Add
PlayerSurfaceComposable tomedia3-ui-composemodule. - Add
PlayPauseButtonState,NextButtonState,PreviousButtonState,RepeatButtonState,ShuffleButtonStateclasses and the correspondingrememberPlayPauseButtonState,rememberNextButtonState,rememberPreviousButtonState,rememberRepeatButtonState,rememberShuffleButtonStateComposables tomedia3-ui-composemodule.
- Add
- 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.
- Add a first version of
- DASH Extension:
- Add AC-4 Level-4 format support for DASH (#1898).
- Decoder Extensions (FFmpeg, VP9, AV1, etc.):
- Add the MPEG-H decoder module which uses the native MPEG-H decoder module to decode MPEG-H audio (#1826).
- Demo app:
- Add
MinimalControls(PlayPauseButton,NextButton,PreviousButton) andExtraControls(RepeatButton,ShuffleButton) Composable UI elements todemo-composeutilizingPlayPauseButtonState,NextButtonState,PreviousButtonState,RepeatButtonState,ShuffleButtonState.
- Add
- 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.
- Remove deprecated
1.5.1
This release includes the following changes since the 1.5.0 release:
- 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
1.5.0
This release includes the following changes since the 1.4.1 release:
- 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...
- Update
1.5.0-rc02
This release includes the following changes since the
1.5.0-rc01 release:
1.5.0-rc01
This release includes the following changes since the 1.5.0-beta01 release:
- ExoPlayer:
- 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).
- Extractors:
- DataSource:
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
- Text:
- RTSP Extension:
- Fix crashing when parsing of RTP packets with header extensions (#1225).
1.5.0-beta01
This release includes the following changes since the
1.5.0-alpha01 release:
- Common Library:
- 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.
- Remove
- ExoPlayer:
- 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
- Transformer:
- Make setting the image duration using
MediaItem.Builder.setImageDurationMsmandatory for image export. - Add export support for gaps in sequences of audio EditedMediaItems.
- Make setting the image duration using
- Track Selection:
DefaultTrackSelector: Prefer object-based audio over channel-based audio when other factors are equal.
- Extractors:
- 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).
- Audio:
- 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:
- 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:
- 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).
- Ensure WebVTT in HLS with very large subtitle timestamps (which overflow a 64-bit
- Metadata:
- Assign the
C.TRACK_TYPE_METADATAtype to tracks containing icy or vnd.dvb.ait content.
- Assign the
- DRM:
- Fix
IllegalStateExceptionfromDefaultDrmSession.requiresSecureDecoderafter opening a DRM session failed. This issue was introduced in1.5.0-alpha01.
- Fix
- IMA extension:
- 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 server-side inserted DAI streams without a preroll can result in an
- Session:
- 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 Custom Browse actions of AAOS. - 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.
- Fix bug that caused custom commands sent from a
- 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
- Smooth Streaming Extension:
- Fix a
Bad magic number for Bundleerror when playing SmoothStreaming streams with text tracks (#1779).
- Fix a
- RTSP Extension:
- Fix user info removal for URLs that contain encoded @ characters (#1138).
- Decoder Extensions (FFmpeg, VP9, AV1, etc.):
- Add 16 KB page support for decoder extensions on Android 15 ([#1685](https://github.com/a...
1.5.0-alpha01
This release includes the following changes since the
1.4.1 release:
- 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.
- 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.
- Transformer:
- Add
SurfaceAssetLoader, which supports queueing video data to Transformer via aSurface. ImageAssetLoaderreports unsupported input viaAssetLoader.onErrorinstead of throwing anIllegalStateException.
- Add
- 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).
- Allow
- DataSource:
- Update
HttpEngineDataSourceto allow use starting at version S extension 7 instead of API level 34 (#1262).
- Update
- Audio:
- Automatically configure CTA-2075 loudness metadata on the codec if present in the media.
- Ensure smooth volume ramp down when seeking.
- 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).
- Text:
- Add a custom
VoiceSpanand populate it for WebVTT voice spans (#1632).
- Add a custom
- 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 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).
- Add
- DASH Extension:
- Add support for periods starting in the middle of a segment (#1440).
- 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 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 clearning 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
- 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
1.4.1
This release includes the following changes since the 1.4.0 release:
- 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).
1.4.0
This release includes the following changes since the 1.3.1 release:
- 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).
...