Media3
| Latest Update | Stable Release | Release Candidate | Beta Release | Alpha Release |
|---|---|---|---|---|
| November 22, 2022 | - | - | 1.0.0-beta03 | - |
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.0.0-beta03"
// 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 RTSP playback support with ExoPlayer
implementation "androidx.media3:media3-exoplayer-rtsp:$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
implementation "androidx.media3:media3-ui:$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"
// 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 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"
}
Kotlin
dependencies {
val media3_version = "1.0.0-beta03"
// 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 RTSP playback support with ExoPlayer
implementation("androidx.media3:media3-exoplayer-rtsp:$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
implementation("androidx.media3:media3-ui:$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")
// 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 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")
}
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.0.0
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.

