رسانه 3
آخرین به روز رسانی | انتشار پایدار | کاندید را آزاد کنید | نسخه بتا | انتشار آلفا |
---|---|---|---|---|
10 سپتامبر 2024 | 1.4.1 | - | - | 1.5.0-alpha01 |
اعلام وابستگی ها
برای افزودن یک وابستگی به Media3، باید مخزن Google Maven را به پروژه خود اضافه کنید. برای اطلاعات بیشتر ، مخزن Maven Google را بخوانید.
وابستگیهای مصنوعات مورد نیاز خود را در فایل build.gradle
برای برنامه یا ماژول خود اضافه کنید:
شیار
dependencies { def media3_version = "1.4.1" // 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 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" // 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" }
کاتلین
dependencies { val media3_version = "1.4.1" // 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 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") // 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") }
برای اطلاعات بیشتر درباره وابستگیها، به افزودن وابستگیهای ساخت مراجعه کنید.
بازخورد
بازخورد شما به بهتر شدن Jetpack کمک می کند. میتوانید از ردیاب Media3 برای یافتن پاسخ به سؤالات، مسائل شناخته شده و درخواستهای ویژگیها و پروندهسازی مسائل جدید استفاده کنید.
نسخه 1.5
نسخه 1.5.0-alpha01
10 سپتامبر 2024
این نسخه شامل تغییرات زیر از نسخه 1.4.1 است:
- کتابخانه مشترک:
-
ForwardingSimpleBasePlayer
را اضافه کنید که به بازیکن دیگری با تنظیمات کوچک امکان حمل و نقل را می دهد و در عین حال از سازگاری کامل و کنترل شنونده اطمینان حاصل می کند ( #1183 ). -
SimpleBasePlayer.State.playlist
را با متدgetPlaylist()
جایگزین کنید. - برای
SimpleBasePlayer.State.Builder.setPlaylist()
override اضافه کنید تا بهجای ساختن ساختار لیست پخش، مستقیماًTimeline
وTracks
وMetadata
فعلی را مشخص کنید. -
minSdk
به 21 (Android Lollipop) افزایش دهید. این با سایر کتابخانههای AndroidX هماهنگ است. - افزودن
androidx.media3:media3-common-ktx
artifact که عملکردهای مخصوص Kotlin را که در بالای کتابخانه مشترک ساخته شده است، ارائه می دهد. - تابع افزونه تعلیق
Player.listen
را برای چرخاندن یک برنامه برای گوش دادن بهPlayer.Events
به کتابخانهmedia3-common-ktx
اضافه کنید.
-
- ExoPlayer:
- اکنون
MediaCodecRenderer.onProcessedStreamChange()
می توان برای هر آیتم رسانه ای فراخوانی کرد. قبلا برای اولی فراخوانی نشده بود. برای فعال کردن این موردMediaCodecRenderer.experimentalEnableProcessedStreamChangedAtStart()
استفاده کنید. -
PreloadMediaSource.PreloadControl.onPreloadError
را اضافه کنید تا به پیاده سازی هایPreloadMediaSource.PreloadControl
اجازه دهید در صورت بروز خطا اقداماتی را انجام دهند. -
BasePreloadManager.Listener
را برای انتشار رویدادهای پیش بارگذاری در برنامه ها اضافه کنید. - اجازه تغییر مهلت زمانی سرویس گیرنده SNTP را بدهید و آدرسهای جایگزین را دوباره امتحان کنید ( #1540 ).
-
MediaCodecAdapter.Configuration.flags
را حذف کنید زیرا فیلد همیشه صفر بود. - به کاربر اجازه دهید تا بلندگوی داخلی را برای پخش در Wear OS API 35+ انتخاب کند (جایی که دستگاه تبلیغ می کند که از این پشتیبانی می کند).
- تماس مسدود کردن را به
Context.getSystemService(Context.AUDIO_SERVICE)
موکول کنید تا زمانی که کنترل فوکوس صوتی فعال شود. این تضمین میکند که اگر کنترل فوکوس صوتی فعال نباشد، مسدود کردن تماس انجام نمیشود ( #1616 ). - اجازه پخش بدون در نظر گرفتن مدت زمان بافر در هنگام بارگیری ناموفق ( #1571 ).
-
AnalyticsListener.onRendererReadyChanged()
را برای سیگنال دادن به زمانی که رندرهای جداگانه اجازه می دهند پخش را آماده کند، اضافه کنید.
- اکنون
- ترانسفورماتور:
-
SurfaceAssetLoader
را اضافه کنید که از صف بندی داده های ویدیویی به Transformer از طریقSurface
پشتیبانی می کند. -
ImageAssetLoader
به جای ارسال یکIllegalStateException
ورودی پشتیبانی نشده را از طریقAssetLoader.onError
گزارش می دهد.
-
- استخراج کننده ها:
- به
Mp4Extractor
وFragmentedMp4Extractor
اجازه دهید نمونههای H264 را که در نمونههای بعدی به عنوان مرجع استفاده نمیشوند شناسایی کنند. - گزینه ای را برای فعال کردن جستجوی مبتنی بر فهرست در
AmrExtractor
اضافه کنید. - فایل های MP3 با بیش از 128 کیلوبایت بین فریم های معتبر را به عنوان کوتاه شده (به جای نامعتبر) در نظر بگیرید. این بدان معناست که فایلهایی با دادههای غیر MP3 در انتها، بدون هیچ ابرداده دیگری برای نشان دادن طول بایتهای MP3، اکنون به جای شکستن با
ParserException: Searched too many bytes.{contentIsMalformed=true, dataType=1}
( #1563 ).
- به
- منبع داده:
-
HttpEngineDataSource
بهروزرسانی کنید تا به جای API سطح 34 ( #1262 ) از نسخه S افزونه 7 شروع شود.
-
- صوتی:
- در صورت وجود در رسانه، فراداده بلندی صدای CTA-2075 را روی کدک پیکربندی کنید.
- هنگام جستجو از کاهش سطح شیب دار حجمی صاف اطمینان حاصل کنید.
- ویدئو:
-
MediaCodecVideoRenderer
از رمزگشایی نمونه هایی که نه رندر شده اند و نه به عنوان مرجع توسط نمونه های دیگر استفاده می شوند، اجتناب می کند. - در API 35 و بالاتر،
MediaCodecAdapter
اکنون ممکن است یکSurface
null
detachOutputSurface
configure
دریافت کند و در صورتی که کدک از اینSurface
پشتیبانی کند (MediaCodecInfo.detachedSurfaceSupported
). - اگر هنگام پردازش
onOutputFormatChanged
( #1371 ) از مقادیر نسبت تصویر ارائه شده توسطMediaCodecAdapter
استفاده کنید.
-
- متن:
- یک
VoiceSpan
سفارشی اضافه کنید و آن را برای دامنه های صوتی WebVTT پر کنید ( #1632 ).
- یک
- تصویر:
-
ExternallyLoadedImageDecoder
را برای ادغام ساده با کتابخانه های بارگذاری تصویر خارجی مانند Glide یا Coil اضافه کنید.
-
- منبع داده:
-
FileDescriptorDataSource
را اضافه کنید، یکDataSource
جدید که می تواند برای خواندن از یکFileDescriptor
استفاده شود ( #3757 ).
-
- اثر:
- راهحل
DefaultVideoFrameProcessor
را برای مقیاسبندی جزئیSurfaceTexture
اضافه کنید.SurfaceTexture
ممکن است شامل یک مقیاس کوچک باشد که یک حاشیه 1 تکسلی را در اطراف لبه یک بافر برش خورده قطع می کند. اکنون این کار به گونه ای انجام می شود که خروجی به حد انتظار نزدیک تر است. - افزایش سرعت
DefaultVideoFrameProcessor.queueInputBitmap()
. در نتیجه، صادرات تصاویر به ویدیوها باTransformer
سریعتر است.
- راهحل
- پسوند IMA:
- رفع اشکال که در آن پاک کردن لیست پخش ممکن است باعث ایجاد یک
ArrayIndexOutOfBoundsException
درImaServerSideAdInsertionMediaSource
شود.
- رفع اشکال که در آن پاک کردن لیست پخش ممکن است باعث ایجاد یک
- جلسه:
-
MediaButtonReceiver.shouldStartForegroundService(Intent)
را اضافه کنید تا به برنامهها اجازه دهید با نادیده گرفتن این روش، فرمان پخشی را که برای ازسرگیری پخش ارسال میشود، سرکوب کنند. بهطور پیشفرض، سرویس همیشه راهاندازی میشود و بدون اینکه سیستم سرویس را با یکForegroundServiceDidNotStartInTimeException
( #1528 ) خراب کند، نمیتوان پخش را متوقف کرد.
-
- پسوند DASH:
- برای دورههایی که از وسط یک بخش شروع میشوند، پشتیبانی اضافه کنید ( #1440 ).
- پسوندهای رمزگشا (FFmpeg، VP9، AV1، و غیره):
- ماژول رمزگشای IAMF را اضافه کنید که از پخش فایل های MP4 حاوی آهنگ های IAMF با استفاده از کتابخانه بومی libiamf برای ترکیب صدا پشتیبانی می کند.
- پخش با طرح استریو و همچنین 5.1 با فضایی سازی همراه با ردیابی سر اختیاری فعال است، اما پشتیبانی از پخش دو گوش در حال حاضر در دسترس نیست.
- ماژول رمزگشای IAMF را اضافه کنید که از پخش فایل های MP4 حاوی آهنگ های IAMF با استفاده از کتابخانه بومی libiamf برای ترکیب صدا پشتیبانی می کند.
- پسوند بازیگران:
- پس از قطع ارتباط CastSession، پاک کردن جدول زمانی را متوقف کنید، که به برنامه فرستنده امکان میدهد پس از قطع ارتباط، پخش را به صورت محلی از سر بگیرد.
- هنگامی که یک
Context
ارائه می شود،DeviceInfo
CastPlayer را پر کنید. این امکان پیوندMediaSession
را بهRoutingSession
میدهد، که برای یکپارچه کردن خروجی سوئیچر ( #1056 ) ضروری است.
- ابزارهای آزمایشی:
-
DataSourceContractTest
اکنون شامل آزمایش هایی برای تأیید است:-
read position
جریان ورودی به روز شده است. -
offset
بافر خروجی به درستی اعمال می شود.
-
-
- حذف نمادهای منسوخ شده:
-
Player.hasPrevious
،Player.hasPreviousWindow()
منسوخ شده را حذف کنید. به جای آنPlayer.hasPreviousMediaItem()
استفاده کنید. - روش منسوخ شده
Player.previous()
را حذف کنید. به جای آنPlayer.seekToPreviousMediaItem()
استفاده کنید. - روش منسوخ
DrmSessionEventListener.onDrmSessionAcquired
را حذف کنید.
-
نسخه 1.4.0
نسخه 1.4.1
27 آگوست 2024
androidx.media3:media3-*:1.4.1
منتشر شد. نسخه 1.4.1 شامل این commit ها است.
- ExoPlayer:
- استخراج کننده ها:
- MP3: با نادیده گرفتن صحیح داده های غیر MP3 دنباله بر اساس طول فیلد در یک قاب
Info
( #1480 ) خطایSearched too many bytes
را برطرف کنید.
- MP3: با نادیده گرفتن صحیح داده های غیر MP3 دنباله بر اساس طول فیلد در یک قاب
- متن:
- TTML: رسیدگی به مقادیر درصد
tts:fontSize
برطرف کنید تا مطمئن شوید که آنها به درستی از گره های والد با مقادیر درصدtts:fontSize
به ارث برده شده اند. -
IndexOutOfBoundsException
را درLegacySubtitleUtil
به دلیل مدیریت نادرست مورد زمان شروع خروجی درخواستی بزرگتر یا مساوی با زمان رویداد نهایی درSubtitle
( #1516 ) برطرف کنید.
- TTML: رسیدگی به مقادیر درصد
- DRM:
- رفع
android.media.MediaCodec$CryptoException: Operation not supported in this configuration: ERROR_DRM_CANNOT_HANDLE
در دستگاههای API 31+ که محتوای L1 Widevine را پخش میکنند. این خطا ناشی از اجرای ناقص چارچوبMediaDrm.requiresSecureDecoder
( #1603 ) است.
- رفع
- اثر:
- یک متد
release()
را بهGlObjectsProvider
اضافه کنید.
- یک متد
- جلسه:
- همانطور که مستند شده است، یک ضربه دوبار از
KEYCODE_HEADSETHOOK
را به یک اقدام «جستجوی بعدی» تبدیل کنید ( #1493 ). - هنگامی که تصمیم می گیرید برای جلوگیری از
ForegroundServiceDidNotStartInTimeException
( #1581 ) آن را نادیده بگیرید،KEYCODE_HEADSETHOOK
به عنوان یک فرمان «play» درMediaButtonReceiver
مدیریت کنید.
- همانطور که مستند شده است، یک ضربه دوبار از
- پسوند RTSP:
- رد شدن از توضیحات رسانه نامعتبر در تجزیه SDP ( #1087 ).
نسخه 1.4.0
25 جولای 2024
androidx.media3:media3-*:1.4.0
منتشر شد. نسخه 1.4.0 حاوی این تعهدات است.
- کتابخانه مشترک:
- به جای نادیده گرفتن فراخوانهای جستجوی بدون عملیات به متدهای حفاظتشده
BasePlayer.seekTo()
وSimpleBasePlayer.handleSeek()
ارسال کنید. اگر این روشها را در یک پخشکننده سفارشی پیادهسازی میکنید، ممکن است لازم باشد این تماسهای اضافی را باmediaItemIndex == C.INDEX_UNSET
مدیریت کنید. - حذف وابستگی کامپایل به حذف قند بهبود یافته جاوا 8 ( #1312 ).
- مطمئن شوید که مدت زمان ارسال شده به
MediaItem.Builder.setImageDurationMs()
برای یکMediaItem
غیر تصویری نادیده گرفته شده است (طبق مستند). -
Format.customData
را برای ذخیره اطلاعات سفارشی ارائه شده توسط برنامه در مورد نمونه هایFormat
اضافه کنید.
- به جای نادیده گرفتن فراخوانهای جستجوی بدون عملیات به متدهای حفاظتشده
- ExoPlayer:
-
BasePreloadManager
را اضافه کنید که پیش بارگذاری را برای چندین منبع بر اساس اولویت های تعریف شده توسطrankingData
آنها هماهنگ می کند. سفارشی سازی با گسترش این کلاس امکان پذیر است.DefaultPreloadManager
را اضافه کنید که ازPreloadMediaSource
برای از پیش بارگذاری نمونه های رسانه ای از منابع در حافظه استفاده می کند و از یکrankingData
عدد صحیح استفاده می کند که نمایه یک آیتم را در رابط کاربری نشان می دهد. -
PlayerId
به اکثر متدهایLoadControl
اضافه کنید تا اجرایLoadControl
را برای پشتیبانی از چندین بازیکن فعال کنید. -
Buffer.isDecodeOnly()
وC.BUFFER_FLAG_DECODE_ONLY
را حذف کنید. نیازی به تنظیم این پرچم نیست زیرا رندرها و رمزگشاها تصمیم میگیرند از بافرها بر اساس مهر زمانی عبور کنند. اجرای سفارشیRenderer
باید بررسی کند که آیا زمان بافر حداقلBaseRenderer.getLastResetPositionUs()
است تا تصمیم بگیرد که آیا نمونه باید نشان داده شود یا خیر. پیاده سازی های سفارشیSimpleDecoder
می توانند در صورت نیازisAtLeastOutputStartTimeUs()
را بررسی کنند یا بافرهای دیگر را باDecoderOutputBuffer.shouldBeSkipped
علامت گذاری کنند تا از آنها رد شود. - اجازه دهید یک مقدار تهی توسط
TargetPreloadStatusControl.getTargetPreloadStatus(T)
برگردانده شود تا نشان دهد کهMediaSource
باrankingData
داده شده از قبل بارگیری نمی شود. -
remove(MediaSource)
بهBasePreloadManager
اضافه کنید. -
reset()
را بهBasePreloadManager
اضافه کنید تا تمام منابع نگهدارنده را آزاد کنید و در عین حال نمونه مدیریت پیش بارگذاری را حفظ کنید. -
ExoPlayer.setPriority()
وBuilder.setPriority()
) را برای تعریف مقدار اولویت مورد استفاده درPriorityTaskManager
و برای اهمیت MediaCodec از API 35 اضافه کنید. - مشکل بهروزرسانی آخرین زمان بافر را که منجر به کلید
bs
(گرسنگی بافر) نادرست در CMCD شد ( #1124 ) برطرف کنید. -
PreloadMediaSource.PreloadControl.onLoadedToTheEndOfSource(PreloadMediaSource)
را اضافه کنید تا نشان دهید منبع تا پایان بارگذاری شده است. این بهDefaultPreloadManager
و پیاده سازی های سفارشیPreloadMediaSource.PreloadControl
اجازه می دهد تا منبع بعدی را از قبل بارگذاری کنند یا اقدامات دیگری را انجام دهند. - رفع اشکال که در آن پرش بیصدا در انتهای موارد میتواند باعث ایجاد استثنا در پخش شود.
- برای صرفنظر کردن از دوره پیشبارگیری،
clear
بهPreloadMediaSource
اضافه کنید. - کد خطای جدید
PlaybackException.ERROR_CODE_DECODING_RESOURCES_RECLAIMED
را اضافه کنید.ERROR_CODE_DECODING_RESOURCES_RECLAIMED که زمانی استفاده می شود که منابع کدک برای کارهای با اولویت بالاتر بازیابی می شوند. - اجازه دهید
AdsMediaSource
تبلیغات پیش از پخش را قبل از تکمیل آماده سازی رسانه محتوای اولیه بارگیری کند ( #1358 ). - رفع اشکال انتقال پخش به
STATE_ENDED
هنگام آمادهسازی مجدد جریان زنده چند دورهای DASH پس از اینکه دوره اصلی قبلاً از مانیفست حذف شده بود. - نام
onTimelineRefreshed()
بهonSourcePrepared()
وonPrepared()
بهonTracksSelected()
درPreloadMediaSource.PreloadControl
تغییر نام دهید. همچنین نام IntDefs را درDefaultPreloadManager.Stage
بر این اساس تغییر دهید. - پشتیبانی آزمایشی برای زمانبندی پویا اضافه کنید تا کار را با چرخههای بیداری CPU تراز کنید و بیدار شدن را تا زمانی که رندرها میتوانند پیشرفت کنند به تاخیر بیاندازید. هنگام تنظیم نمونه ExoPlayer، میتوانید این را با استفاده از
experimentalSetDynamicSchedulingEnabled()
فعال کنید. -
Renderer.getDurationToProgressUs()
را اضافه کنید. یکRenderer
میتواند این روش را پیادهسازی کند تا مدت زمانی را که پخش برای پیشرفت رندر باید پیش برود، به ExoPlayer بازگرداند. اگرExoPlayer
باexperimentalSetDynamicSchedulingEnabled()
تنظیم شده باشد،ExoPlayer
این متد را هنگام محاسبه زمان برنامه ریزی کار خود فراخوانی می کند. -
MediaCodecAdapter#OnBufferAvailableListener
را اضافه کنید تا زمانی که بافرهای ورودی و خروجی برای استفاده توسطMediaCodecRenderer
در دسترس هستند، هشدار دهید.MediaCodecRenderer
هنگام دریافت این تماسها بهExoPlayer
سیگنال میدهد و اگرExoPlayer
باexperimentalSetDynamicSchedulingEnabled()
تنظیم شده باشد،ExoPlayer
حلقه کار خود را برنامهریزی میکند زیرا رندرها میتوانند پیشرفت کنند. - از کلاس داده برای متدهای
LoadControl
به جای پارامترهای فردی استفاده کنید. -
ExoPlayer.isReleased()
را اضافه کنید تا بررسی کنید کهExoplayer.release()
فراخوانی شده است یا خیر. -
ExoPlayer.Builder.setMaxSeekToPreviousPositionMs()
را برای پیکربندی حداکثر موقعیتی کهseekToPrevious()
برای آن جستجو می کند به آیتم قبلی ( #1425 ) اضافه کنید. - برخی از تناقضات فوکوس صوتی را برطرف کنید، به عنوان مثال گزارش نکردن از دست دادن فوکوس کامل یا گذرا در حالی که پخش کننده متوقف شده است ( #1436 ).
- اصلاح
IndexOutOfBoundsException
بالقوه ناشی از استخراج کننده هایی که آهنگ های اضافی را پس از مرحله آماده سازی اولیه گزارش می کنند ( #1476 ). -
Effects
درExoPlayer.setVideoEffect()
مهرهای زمانی را دریافت میکنند که افست رندر حذف شده است ( #1098 ). - هنگام رسیدگی به خطای پخش کننده که هنگام خواندن پیش رو در یکی دیگر از آیتم های لیست پخش ( #1483 ) رخ داده است، بالقوه
IllegalArgumentException
برطرف کنید.
-
- ترانسفورماتور:
-
audioConversionProcess
وvideoConversionProcess
را بهExportResult
اضافه کنید که نشان می دهد آهنگ مربوطه در فایل خروجی چگونه ساخته شده است. - بررسی سطح H.264 بهینه سازی تریم آرام.
- پشتیبانی برای تغییر بین رسانه ورودی SDR و HDR به صورت متوالی اضافه کنید.
- پشتیبانی از جلوه های صوتی در سطح ترکیب را اضافه کنید.
- پشتیبانی از رمزگذاری تصاویر Ultra HDR به ویدیوهای HDR را اضافه کنید.
- مشکلی را که
DefaultAudioMixer
پس از تنظیم مجدد و استفاده مجدد، مقدار صحیح بایت را تولید نمی کند، برطرف کنید. - در مورد یک اشکال رمزگشا کار کنید که در آن تعداد کانال های صوتی در هنگام مدیریت ورودی PCM در حالت استریو محدود شده است.
- هنگام انتخاب آهنگها در
ExoPlayerAssetLoader
، محدودیتهای تعداد کانالهای صوتی را نادیده بگیرید زیرا فقط برای پخش اعمال میشوند. - رابط
androidx.media3.transformer.Muxer
را باandroidx.media3.muxer.Muxer
جایگزین کنید وandroidx.media3.transformer.Muxer
را حذف کنید. - رفع بارگذاری تصویر HEIC از طرحهای URI محتوا. ( #1373 ).
- برای بهبود همگام سازی AV، مدت آهنگ صوتی را در
AudioGraphInput
تنظیم کنید. - قسمت
ExportResult.processedInputs
حذف کنید. اگر از این فیلد برای جزئیات کدک استفاده می کنید، به جای آن ازDefaultDecoderFactory.listener
استفاده کنید. در صورت استثناء کدک، جزئیات کدک درExportException.codecInfo
در دسترس خواهد بود.
-
- استخراج کننده ها:
- MPEG-TS: تغییر را به جلو بچرخانید تا مطمئن شوید آخرین فریم با عبور دادن آخرین واحد دسترسی یک جریان به صف نمونه ( #7909 ) رندر شده است. افزودن راهحلهایی برای حل مشکلاتی که در I-frame فقط در جریانهای HLS ( #1150 ) و H.262 HLS ( #1126 ) ظاهر شدند.
- MP3: اندازه داده را از یک قاب
Info
به اندازه گزارش شده توسط جریان اصلی ترجیح دهید (مثلاً اندازه فایل یا سرصفحهContent-Length
HTTP). این به حذف دادههای تریلر غیرقابل پخش (مثلاً آثار هنری آلبوم) از محاسبات جستجوی نرخ بیت ثابت کمک میکند و جستجوها را دقیقتر میکند ( #1376 ). - MP3: از تعداد فریم و سایر دادهها در یک قاب
Info
(در صورت وجود) برای محاسبه نرخ بیت متوسط برای جستجوی نرخ بیت ثابت استفاده کنید، به جای برون یابی از نرخ بیت فریم بعد از قابInfo
، که ممکن است به طور مصنوعی کوچک باشد، به عنوان مثال فریمPCUT
( #1376 ). - رفع فرمت صوتی PCM در ظروف AVI.
- صوتی:
- اصلاح ویژگی های رمزگذاری DTS:X Profile 2 برای پخش گذرا ( #1299 ).
- برای پخش بدون بارگذاری، قبل از فراخوانی
AudioTrack.stop()
، فیلد ردیابی را برای تکمیل پخش جریانی درDefaultAudioSink
بازنشانی کنید تاAudioTrack.StreamEventCallback#onPresentationEnded
به درستی تشخیص دهد که همه دادههای در انتظار پخش شدهاند. - رفع اشکال در
SilenceSkippingAudioProcessor
که در آن انتقال بین فرمتهای صوتی مختلف (به عنوان مثال استریو به مونو) میتواند باعث شود پردازنده یک استثنا ایجاد کند ( #1352 ). -
MediaCodecAudioRenderer.getDurationToProgressUs()
را پیاده سازی کنید تا ExoPlayer به صورت پویا حلقه کار اصلی خود را تا زمانی که MediaCodecAudioRenderer می تواند پیشرفت کند برنامه ریزی کند.
- ویدئو:
- مشکلی را که در آن
Listener.onRenderedFirstFrame()
خیلی زود می رسد، هنگام تعویض سطوح در اواسط پخش، برطرف کنید. - منطق برگشتی رمزگشا را برای Dolby Vision اصلاح کنید تا در صورت نیاز از رمزگشای AV1 سازگار استفاده کند ( #1389 ).
- رفع استثنا کدک که ممکن است با فعال کردن رندر ویدیو در اواسط پخش ایجاد شود.
- مشکلی را که در آن
- متن:
- مشکل شروع زیرنویسها قبل از نادیده گرفتن موقعیت جستجو را برطرف کنید. این موضوع فقط در Media3 1.4.0-alpha01 معرفی شد.
- رفتار تجزیه پیشفرض زیرنویس را تغییر دهید تا در حین استخراج به جای رندر کردن اتفاق بیفتد (برای تفاوت بین استخراج و رندر به نمودار معماری ExoPlayer مراجعه کنید).
- این تغییر را می توان با فراخوانی
MediaSource.Factory.experimentalParseSubtitlesDuringExtraction(false)
وTextRenderer.experimentalSetLegacyDecodingEnabled(true)
لغو کرد. برای نحوه وارد کردن این اجزا به یک نمونهExoPlayer
به اسناد سفارشیسازی مراجعه کنید. این روش ها (و همه پشتیبانی از رمزگشایی زیرنویس قدیمی) در نسخه بعدی حذف خواهند شد. - برنامههای دارای پیادهسازی سفارشی
SubtitleDecoder
باید برای پیادهسازیSubtitleParser
(وSubtitleParser.Factory
به جایSubtitleDecoderFactory
) آنها را بهروزرسانی کنند.
- این تغییر را می توان با فراخوانی
- PGS: رمزگشایی طول اجرا را تصحیح کنید تا
0
بهعنوان شاخص رنگ، به جای مقدار واقعی رنگ ( #1367 ) حل کنید. - CEA-708: مقدار
rowLock
را نادیده بگیرید. مشخصات CEA-708-E S-2023 بیان می کند کهrowLock
وcolumnLock
هر دو باید درست فرض شوند، صرف نظر از مقادیر موجود در جریان (پشتیبانی ازcolumnLock
اجرا نمی شود، بنابراین عملاً فرض می شود همیشه نادرست است).- این در ابتدا در یادداشت های انتشار
1.3.0-alpha01
گنجانده شده بود، اما این تغییر به طور تصادفی قبل از انتشار1.3.0-rc01
برگردانده شد. اکنون این مشکل برطرف شده است، بنابراین تغییر دوباره وجود دارد.
- این در ابتدا در یادداشت های انتشار
- CEA-708: از اضافه شدن خطوط جدید تکراری با مدیریت ساده ExoPlayer دستور 'set pen location' ( #1315 ) خودداری کنید.
- هنگامی که یک نمونه زیرنویس WebVTT هیچ نشانه ای ندارد، مثلاً به عنوان بخشی از جریان DASH ( #1516 )، یک
IllegalArgumentException
ازLegacySubtitleUtil
را برطرف کنید.
- فراداده:
- نگاشت برچسب های مرتب سازی MP4 به ID3 را برطرف کنید. قبلاً برچسبهای MP4 «مرتبسازی آلبوم» (
soal
)، «مرتبسازی هنرمند» (soar
) و «مرتبسازی هنرمند آلبوم» (soaa
) به اشتباه با برچسبهایTSO2
،TSOA
وTSOP
ID3 ( #1302 ) نگاشت شده بودند. - خواندن برچسبهای MP4 (/iTunes) عددی
gnre
(ژانر) وtmpo
(تمپو) را هنگامی که مقدار آن بیش از یک بایت است برطرف کنید. - فریم ID3
TCON
را درMediaMetadata.genre
( #1305 ) منتشر کنید.
- نگاشت برچسب های مرتب سازی MP4 به ID3 را برطرف کنید. قبلاً برچسبهای MP4 «مرتبسازی آلبوم» (
- تصویر:
- پشتیبانی از شبکههای تصویر کوچک DASH غیر مربعی ( #1300 ) را اضافه کنید.
- پشتیبانی از AVIF برای API 34+ را اضافه کنید.
- برای پاک کردن یک
ImageOutput
از قبل تنظیم شده، بهnull
به عنوان پارامتر برایExoPlayer.setImageOutput()
اجازه دهید.
- منبع داده:
- پشتیبانی از
android.resource://package/id
URI های منبع خام را در جایی کهpackage
با بسته برنامه فعلی متفاوت است، اجرا کنید. این قبلاً برای کار مستند نشده بود، اما روشی کارآمدتر برای دسترسی به منابع در بستهای دیگر به جای نام است. - مشتاقانه بررسی کنید که
url
در سازنده هایDataSpec
غیر تهی باشد. این پارامتر قبلاً به عنوان غیر تهی توضیح داده شده بود. - به
ByteArrayDataSource
اجازه دهید یک URI را در یک آرایه بایتی در حینopen()
حل کند، به جای اینکه در ساخت و ساز به صورت سخت کدگذاری شود ( #1405 ).
- پشتیبانی از
- DRM:
- اجازه تنظیم
LoadErrorHandlingPolicy
درDefaultDrmSessionManagerProvider
( #1271 ).
- اجازه تنظیم
- اثر:
- از تغییرات سرعت چندگانه در یک
EditedMediaItem
یاComposition
درSpeedChangeEffect
پشتیبانی کنید. - پشتیبانی از خروجی HLG و PQ از ورودی bitmap ultra HDR.
- پشتیبانی از EGL_GL_COLORSPACE_BT2020_HLG_EXT را اضافه کنید، که خروجی سطح HLG را در ExoPlayer.setVideoEffect و Transformer's Debug SurfaceView بهبود می بخشد.
- اجرای ماتریس Overlay را با برگرداندن مقادیر x و y اعمال شده در
setOverlayFrameAnchor()
بهروزرسانی کنید تا با مستندات مطابقت داشته باشد. اگر ازOverlaySettings.Builder.setOverlayFrameAnchor()
استفاده می کنید، مقادیر x و y آنها را با ضرب آنها در-1
برگردانید. - رفع اشکال زمانی که
TimestampWrapper
هنگام استفاده باExoPlayer#setVideoEffects
( #821 ) از کار می افتد. - فضای کار رنگ SDR پیشفرض را از رنگهای خطی به ویدیوی الکتریکی BT 709 SDR تغییر دهید. همچنین گزینه سوم را برای حفظ فضای رنگ اصلی ارائه دهید.
- اجازه تعریف مرتبه z نامعین EditedMediaItemSequences ( #1055 ).
- محدوده روشنایی ثابتی را در قطعات مختلف محتوای HDR حفظ کنید (از محدوده HLG استفاده می کند).
- پشتیبانی از پوششهای Ultra HDR (bitmap) روی محتوای HDR را اضافه کنید.
- اجازه استفاده از جلوههای
SeparableConvolution
قبل از API 26 را بدهید. -
OverlaySettings.useHdr
استفاده نشده را حذف کنید زیرا محدوده دینامیکی پوشش و فریم باید مطابقت داشته باشند. - پشتیبانی HDR را برای
TextOverlay
اضافه کنید. درخشندگی روکش متن را می توان باOverlaySettings.Builder.setHdrLuminanceMultiplier()
تنظیم کرد.
- از تغییرات سرعت چندگانه در یک
- پسوند IMA:
- API مورد نیاز برای برنامهها برای پخش جریانهای تبلیغات DAI را به پایداری ارتقا دهید.
- به
ImaServerSideAdInsertionMediaSource.AdLoader
،replaceAdTagParameters(Map <String, String>)
اضافه کنید. - رفع اشکالی که در آن هنگام پخش یک خطای پخش کننده در حین پخش آگهی ( #1334 ) فراخوانی نشد
VideoAdPlayer.VideoAdPlayerCallback.onError()
- نسخه IMA SDK را به 3.33.0 برسانید تا یک
NullPointerException
در هنگام استفاده از URIهای برچسب آگهیdata://
( #700 ) برطرف شود.
- جلسه:
- پیشفرض
CommandButton.enabled
را بهtrue
تغییر دهید و اطمینان حاصل کنید که مقدار ممکن است برای کنترلکنندهها نادرست بماند، حتی اگر دستور مربوطه در دسترس باشد. - ثابت های نماد را برای
CommandButton
اضافه کنید که باید به جای منابع آیکون سفارشی استفاده شود. -
MediaSessionService.isPlaybackOngoing()
را اضافه کنید تا به برنامه ها اجازه دهید پرس و جو کنند که آیا سرویس باید درonTaskRemoved()
متوقف شود ( #1219 ). -
MediaSessionService.pauseAllPlayersAndStopSelf()
را اضافه کنید که به راحتی امکان توقف پخش تمام جلسات و فراخوانیstopSelf()
برای پایان دادن به چرخه عمرMediaSessionService
فراهم می کند. -
MediaSessionService.onTaskRemoved(Intent)
را نادیده بگیرید تا یک پیادهسازی پیشفرض ایمن ارائه کنید که اگر پخش ادامه دارد، سرویس را در پیشزمینه در حال اجرا نگه میدارد یا در غیر این صورت سرویس را متوقف میکند. - با تنظیم نکردن مدت زمان در فراداده جلسه پلت فرم ( #1256 )، نوار جستجو را در اعلان رسانه برای پخشهای زنده پنهان کنید.
- تبدیل
MediaMetadata
بهMediaDescriptionCompat
را تراز کنید تا از همان نظم و منطق ترجیحی هنگام انتخاب ویژگیهای ابرداده مانند media1 استفاده کنید. -
MediaSession.sendError()
را اضافه کنید که امکان ارسال خطاهای غیر کشنده را به کنترلر Media3 می دهد. هنگام استفاده از کنترلر اعلان (بهMediaSession.getMediaNotificationControllerInfo()
مراجعه کنید)، از خطای سفارشی برای به روز رسانیPlaybackState
جلسه پلت فرم به حالت خطا با اطلاعات خطای داده شده ( #543 ) استفاده می شود. -
MediaSession.Callback.onPlayerInteractionFinished()
را برای اطلاع رسانی به جلسات زمانی که یک سری از تعاملات پخش کننده از یک کنترلر خاص به پایان رسید، اضافه کنید. -
SessionError
را اضافه کنید و از آن به جای کد خطا درSessionResult
وLibraryResult
استفاده کنید تا در صورت امکان اطلاعات بیشتری در مورد خطا و نحوه رفع خطا ارائه دهید. - کد برنامه آزمایشی کنترلر media3 را منتشر کنید که می تواند برای آزمایش تعامل با برنامه هایی که یک جلسه رسانه را منتشر می کنند استفاده شود.
- موارد اضافی ارسال شده به
MediaSession[Builder].setSessionExtras()
بهPlaybackStateCompat.getExtras()
کنترلر media1 منتشر کنید. - خطاهای کشنده و غیرکشنده را به و از جلسه پلت فرم نقشه برداری کنید. یک
PlaybackException
به حالت خطای مرگبارPlaybackStateCompat
نگاشت می شود. یکSessionError
که باMediaSession.sendError(ControllerInfo, SessionError)
به کنترلکننده اعلان رسانه ارسال میشود به یک خطای غیرمرگبار درPlaybackStateCompat
نگاشت میشود که به این معنی است که کد خطا و پیام تنظیم شدهاند اما وضعیت جلسه پلتفرم باSTATE_ERROR
متفاوت است. - اجازه دهید فعالیت جلسه برای هر کنترل کننده تنظیم شود تا فعالیت جلسه سراسری را لغو کند. فعالیت جلسه را می توان برای یک کنترلر در زمان اتصال با ایجاد یک
ConnectionResult
باAcceptedResultBuilder.setSessionActivivty(PendingIntent)
تعریف کرد. پس از اتصال، فعالیت جلسه را می توان باMediaSession.setSessionActivity(ControllerInfo, PendingIntent)
به روز کرد. - تکرار خطای تماس ها به
MediaLibrarySession.Callback
را بهبود بخشید. تکرار خطا را می توان با استفاده ازMediaLibrarySession.Builder.setLibraryErrorReplicationMode()
برای انتخاب نوع خطا یا انصراف از تکرار خطا که به طور پیش فرض روشن است پیکربندی کرد.
- پیشفرض
- UI:
- هنگام اتصال به
ExoPlayer
، پشتیبانی از نمایش تصویر را بهPlayerView
اضافه کنید ( #1144 ). - سفارشیسازی نمادهای مختلف در
PlayerControlView
را از طریق ویژگیهای xml اضافه کنید تا به جای بازنویسیهای سراسری، نقشههای مختلف در هر نمونهPlayerView
مجاز شود ( #1200 ). - هنگام استفاده از
SurfaceView
در داخل ComposeAndroidView
در API 34 ( #1237 ) باگ پلتفرمی را که باعث کشیدگی/برش ویدیو میشود، حل کنید.
- هنگام اتصال به
- دانلودها:
- اطمینان حاصل کنید که
DownloadHelper
نمونههایRenderer
منتشر نشده را لو نمیدهد، که در نهایت میتواند منجر به از کار افتادن برنامه باIllegalStateException: Too many receivers, total of 1000, registered for pid
( #1224 ).
- اطمینان حاصل کنید که
- پسوند کرونت:
-
SocketTimeoutException
درCronetDataSource
رفع کنید. در برخی از نسخه های Cronet، درخواست ارائه شده توسط callback همیشه یکسان نیست. این منجر به تکمیل نشدن تماس و اتمام زمان درخواست می شود (https://issuetracker.google.com/328442628).
-
- برنامه افزودنی HLS:
- رفع اشکال که در آن نمونههای معلق EMSG در انتظار یک ناپیوستگی در
HlsSampleStreamWrapper
با یک افست نادرست که باعث یکIndexOutOfBoundsException
یا یکIllegalArgumentException
میشود ( #1002 ) تفویض شده است. - رفع اشکال که در آن لیستهای پخش غیراصلی برای جریانهای LL-HLS بارگیری مجدد میشوند ( #1240 ).
- رفع اشکال که در آن فعال کردن CMCD برای HLS با بخش های اولیه منجر به
Source Error
وIllegalArgumentException
شد. - رفع اشکال که در آن لیستهای پخش غیراصلی در حین پخش زنده به روز نمیشوند ( #1240 ).
- رفع اشکال که در آن فعال کردن CMCD برای پخشهای زنده HLS باعث ایجاد
ArrayIndexOutOfBoundsException
( #1395 ) میشود.
- رفع اشکال که در آن نمونههای معلق EMSG در انتظار یک ناپیوستگی در
- پسوند DASH:
- پسوند بازیگران:
- رفع اشکالی که عنوان آلبوم
MediaQueueItem
را به هنرمند در آیتم رسانه Media3 ( #1255 ) تبدیل کرده است.
- رفع اشکالی که عنوان آلبوم
- ابزارهای آزمایشی:
-
onInit()
وonRelease()
درFakeRenderer
پیاده سازی کنید. - روشهای
TestPlayerRunHelper.runUntil()/playUntil()
را تغییر دهید تا در خطاهای غیرمرگبار (مثلاً مواردی که بهAnalyticsListener.onVideoCodecError()
گزارش شدهاند با شکست مواجه شوند. برای غیرفعال کردن این رفتار از زنجیره روشTestPlayerRunHelper.run(player).ignoringNonFatalErrors().untilXXX()
جدید استفاده کنید.
-
- برنامه دمو:
- از
DefaultPreloadManager
در برنامه نمایشی فرم کوتاه استفاده کنید. - اجازه تنظیم حالت تکرار با آرگومان های
Intent
از خط فرمان ( #1266 ). - هنگامی که دستگاه پشتیبانی می کند، از
HttpEngineDataSource
به عنوانHttpDataSource
استفاده کنید.
- از
- حذف نمادهای منسوخ شده:
-
CronetDataSourceFactory
حذف کنید. به جای آن ازCronetDataSource.Factory
استفاده کنید. - برخی از سازنده های
DataSpec
را حذف کنید. به جای آن ازDataSpec.Builder
استفاده کنید. - متد
setContentTypePredicate(Predicate)
ازDefaultHttpDataSource
،OkHttpDataSource
وCronetDataSource
حذف کنید. به جای آن از روش معادل در هرXXXDataSource.Factory
استفاده کنید. - سازنده های
OkHttpDataSource
وOkHttpDataSourceFactory
را حذف کنید. به جای آنOkHttpDataSource.Factory
استفاده کنید. -
PlayerMessage.setHandler(Handler)
را حذف کنید. به جای آنsetLooper(Looper)
استفاده کنید. - قسمت
Timeline.Window.isLive
را حذف کنید. به جای آن از متدisLive()
استفاده کنید. - سازندگان
DefaultHttpDataSource
را حذف کنید. به جای آنDefaultHttpDataSource.Factory
استفاده کنید. -
DashMediaSource.DEFAULT_LIVE_PRESENTATION_DELAY_MS
را حذف کنید. به جای آن ازDashMediaSource.DEFAULT_FALLBACK_TARGET_LIVE_OFFSET_MS
استفاده کنید. -
MediaCodecInfo.isSeamlessAdaptationSupported(Format, Format, boolean)
را حذف کنید. به جای آن ازMediaCodecInfo.canReuseCodec(Format, Format)
استفاده کنید. - روش
DrmSessionManager.DUMMY
وgetDummyDrmSessionManager()
را حذف کنید. به جای آن ازDrmSessionManager.DRM_UNSUPPORTED
استفاده کنید. - حذف
AnalyticsListener.onAudioInputFormatChanged(EventTime, Format)
,AnalyticsListener.onVideoInputFormatChanged(EventTime, Format)
,AudioRendererEventListener.onAudioInputFormatChanged(Format)
VideoRendererEventListener.onVideoInputFormatChanged(Format)
. به جای آن از بارهای اضافه استفاده کنید کهDecoderReuseEvaluation
می گیرند. -
RendererSupport.FormatSupport
IntDef وFORMAT_HANDLED
،FORMAT_EXCEEDS_CAPABILITIES
،FORMAT_UNSUPPORTED_DRM
،FORMAT_UNSUPPORTED_SUBTYPE
،FORMAT_UNSUPPORTED_TYPE
را حذف کنید. به جای آن از IntDef و ثابت های معادل درandroidx.media3.common.C
استفاده کنید (مثلاًC.FORMAT_HANDLED
). - رابط
Bundleable
حذف کنید. این شامل حذف تمام فیلدهای ثابتBundleable.Creator<Foo> CREATOR
. تماس گیرندگان باید از روش هایBundle toBundle()
وstatic Foo fromBundle(Bundle)
در هر نوع استفاده کنند.
-
نسخه 1.4.0-rc01
10 جولای 2024
از نسخه پایدار 1.4.0 استفاده کنید.
نسخه 1.4.0-beta01
26 ژوئن 2024
از نسخه پایدار 1.4.0 استفاده کنید.
نسخه 1.4.0-alpha02
07 ژوئن 2024
از نسخه پایدار 1.4.0 استفاده کنید.
نسخه 1.4.0-alpha01
17 آوریل 2024
از نسخه پایدار 1.4.0 استفاده کنید.
نسخه 1.3.0
نسخه 1.3.1
11 آوریل 2024
androidx.media3:media3-*:1.3.1
منتشر شد. نسخه 1.3.1 حاوی این commit ها است.
- کتابخانه مشترک:
-
Format.labels
را اضافه کنید تا به برچسبهای محلی یا جایگزین دیگر اجازه دهید.
-
- ExoPlayer:
- مشکلی را که در آن
PreloadMediaPeriod
نمیتواند جریانها را پس از بارگیری مجدد از قبل حفظ کند، برطرف کنید. -
TrackSelectionResult
صحیح مربوطه را به دوره پخش در انتخاب مجدد آهنگ اعمال کنید. - رندرهای فعال اولیه را فقط پس از پیشبرد دوره پخش هنگام انتقال بین آیتم های رسانه ( #1017 ) شروع کنید.
- نوع بازگشت گمشده را به قانون proguard
-keepclasseswithmembers
برایDefaultVideoFrameProcessor.Factory.Builder.build()
( #1187 ) اضافه کنید.
- مشکلی را که در آن
- ترانسفورماتور:
- به دلیل عدم پشتیبانی
MediaMuxer
از مهرهای زمانی ارائه منفی قبل از API 30، راه حلی را برای استثناء ایجاد شده اضافه کنید.
- به دلیل عدم پشتیبانی
- انتخاب آهنگ:
-
DefaultTrackSelector
: آهنگهای ویدیویی با نرخ فریم «معقول» (>=10 فریم در ثانیه) را به آهنگهایی با نرخ فریم پایینتر یا تنظیمنشده ترجیح دهید. این تضمین میکند که پخشکننده آهنگ ویدیویی «واقعی» را در MP4های استخراجشده از عکسهای متحرک که میتواند حاوی دو آهنگ HEVC باشد، انتخاب کند که یکی از آنها وضوح بالاتر اما تعداد فریمهای بسیار کمی دارد ( #1051 ).
-
- استخراج کننده ها:
- مشکلی را که در آن هنگام خواندن تکههایی با اندازه عجیب و غریب از فایلهای WAV حذف نمیشد، برطرف کنید ( #1117 ).
- MP3:
Format.averageBitrate
از فریم های ابرداده مانندXING
وVBRI
پر کنید. - MPEG-TS: تغییری را که هدف آن اطمینان از رندر شدن آخرین فریم با ارسال آخرین واحد دسترسی یک جریان به صف نمونه ( #7909 ) است، برگردانید. این به دلیل تغییری است که باعث ایجاد مشکلات جدید در جریانهای HLS فقط با I-frame ( #1150 ) و جریانهای H.262 HLS ( #1126 ) شده است.
- صوتی:
- در صورتی که تراک صوتی در حالت بارگذاری اولیه نشد، با غیرفعال کردن بارگذاری، بازیابی رندر را مجاز کنید.
- ویدئو:
- راهحلی برای مشکل دستگاه در Galaxy Tab S7 FE، Chromecast با Google TV و Lenovo M10 FHD Plus اضافه کنید که باعث میشود جریانهای H265 با سرعت 60 فریم در ثانیه بهعنوان پشتیبانینشده علامتگذاری شوند.
- راه حلی را اضافه کنید که اطمینان حاصل کند که اولین فریم همیشه در حین تونل زدن رندر می شود، حتی اگر دستگاه این کار را به طور خودکار همانطور که توسط API لازم است انجام ندهد ( #1169 ). ( #966 ).
- مشکلی را که در آن مدیریت اطلاعات رنگ HDR باعث رفتار نادرست کدک میشود و از تغییر فرمت تطبیقی برای آهنگهای ویدیوی SDR جلوگیری میکند، برطرف کنید ( #1158 ).
- متن:
- WebVTT: از ایجاد نمونه های جعلی اضافی
CuesWithTiming
ازWebvttParser.parse
( #1177 ) از نشانه های مستقیم متوالی جلوگیری کنید.
- WebVTT: از ایجاد نمونه های جعلی اضافی
- DRM:
- یک
NoSuchMethodError
را حل کنید که می تواند توسط چارچوبMediaDrm
به جایResourceBusyException
یاNotProvisionedException
در برخی از دستگاه های Android 14 ( #1145 ) پرتاب شود.
- یک
- اثر:
- با تبدیل فضاهای رنگی، نگاشت تن PQ به SDR بهبود یافته است.
- جلسه:
- UI:
- اگر
Locale
نتواند نام نمایشگر را شناسایی کند ( شماره 988 ) نام زبان را شامل می شود.
- اگر
- پسوند داش:
- همه عناصر
Label
را از مانیفست بهFormat.labels
( #1054 ) جمع کنید.
- همه عناصر
- پسوند RTSP:
- مقادیر اطلاعات جلسه خالی (I-TAG) را در تجزیه SDP ( #1087 ) پرش کنید.
- پسوندهای رمزگشایی (FFMPEG ، VP9 ، AV1 ، MIDI و غیره):
- پسوند MIDI را به طور پیش فرض به عنوان یک وابستگی محلی غیرفعال کنید زیرا به یک مخزن Maven اضافی نیاز دارد تا پیکربندی شود. کاربرانی که از یک وابستگی محلی به این ماژول احتیاج دارند می توانند دوباره آن را فعال کنند .
نسخه 1.3.0
6 مارس 2024
androidx.media3:media3-*:1.3.0
منتشر می شود. نسخه 1.3.0 شامل این تعهدات است.
- کتابخانه مشترک:
- پشتیبانی از
android.resource://package/[type/]name
منبع خام URIS را در جایی کهpackage
با بسته برنامه فعلی متفاوت است ، پیاده سازی کنید. این همیشه مستند به کار بوده است ، اما تاکنون به درستی اجرا نشده است. - انواع MIME را تنظیم شده توسط کد برنامه یا خواندن از رسانه ها به صورت کاملاً پایین تر بخوانید.
- تبلیغات را با یک
MediaItem
کامل به جای یکUri
درAdPlaybackState
تعریف کنید. -
minSdk
به 19 (Android Kitkat) افزایش دهید. این با سایر کتابخانه های Androidx هماهنگ است و برای ما لازم است تا به آخرین نسخه های وابستگی های Androidx ما ارتقا دهیم. - هر دو
artworkUri
وartworkData
را درMediaMetadata.Builder.populate(MediaMetadata)
جمع کنید که حداقل یکی از آنها غیر تهی باشد ( شماره 964 ).
- پشتیبانی از
- سیارات فراتر:
-
PreloadMediaSource
وPreloadMediaPeriod
را اضافه کنید که به برنامه ها اجازه می دهد تا قبل از پخش ، یک منبع رسانه محتوا را در یک موقعیت خاص شروع کنند.PreloadMediaSource
مراقبت از تهیه منبع رسانه محتوا برای دریافتTimeline
، تهیه و ذخیره دوره در موقعیت شروع داده شده ، انتخاب آهنگ ها و بارگیری داده های رسانه ای برای دوره است. برنامه ها با اجرایPreloadMediaSource.PreloadControl
، پیشرفت پیش بارگذاری را کنترل می کنند و منبع از پیش بارگذاری شده را برای پخش برای پخش تنظیم می کنند. -
ExoPlayer.setImageOutput
را اضافه کنید که به برنامه ها اجازه می دهد تاImageRenderer.ImageOutput
تنظیم کنند. -
DefaultRenderersFactory
اکنون به طور پیش فرض با NULLImageOutput
وImageDecoder.Factory.DEFAULT
یکImageRenderer
به بازیکن ارائه می دهد. - Emit
Player.Listener.onPositionDiscontinuity
هنگام پرش از سکوت ( شماره 765 ). - پشتیبانی آزمایشی برای زیرنویس تجزیه در هنگام استخراج. شما می توانید این کار را با استفاده از
MediaSource.Factory.experimentalParseSubtitlesDuringExtraction()
فعال کنید. - پشتیبانی از منابع رسانه ای تطبیقی با
PreloadMediaSource
. - اجرای
HttpEngineDataSource
،HttpDataSource
با استفاده از API httpengine . - از زیر طبقه بندی
CompositeSequenceableLoader
جلوگیری کنید. این مؤلفه قبلاً قابل گسترش بود اما هرگز در داخل کتابخانه طبقه بندی نشده بود. سفارشی سازی ها را می توان با بسته بندی نمونه ای با استفاده از الگوی دکوراتور و اجرای یکCompositeSequenceableLoaderFactory
انجام داد. - مشکل را برطرف کنید که تکرار در همان زمان باعث پاک شدن ابرداده از این مورد شود ( #1007 ).
- روش های
experimentalSetSubtitleParserFactory
DefaultHlsExtractorFactory
BundledChunkExtractor.Factory
setSubtitleParserFactory
null
برای کنترل رفتار تجزیه و تحلیل از روشهای جدیدexperimentalParseSubtitlesDuringExtraction(boolean)
استفاده کنید. - پشتیبانی را برای شخصی سازی
SubtitleParser.Factory
اضافه کنید. فاکتور استفاده شده در هنگام استخراج. این امر می تواند باMediaSource.Factory.setSubtitleParserFactory()
حاصل شود. - پیشوند منبع را به تمام زمینه های
Format.id
ایجاد شده ازMergingMediaSource
اضافه کنید. این کمک می کند تا مشخص شود کدام منبع یکFormat
تولید کرده است ( شماره 883 ). - Regex مورد استفاده برای اعتبارسنجی نام های اصلی داده های مشتری مشترک (CMCD) را با اصلاح آن با اصلاح آن فقط بررسی کنید ( #1028 ).
- پارامترهای پرس و جو CMCD دو رمزگذاری را متوقف کنید ( #1075 ).
-
- ترانسفورماتور:
- پشتیبانی از مسطح کردن H.265/HEVC SEF فیلم های حرکت آهسته را اضافه کنید.
- سرعت انتقال را افزایش دهید ، به خصوص برای ویرایش های "حذف فیلم".
- API را اضافه کنید تا اطمینان حاصل شود که پرونده خروجی روی یک قاب ویدیویی شروع می شود. این می تواند خروجی عملیات پیرایش را با پیاده سازی های پخش کننده سازگار تر کند که اولین قاب ویدیویی را تا زمان ارائه آن نشان نمی دهد ( شماره 829 ).
- پشتیبانی را برای بهینه سازی عملیات تریم MP4 دارایی تک اضافه کنید.
- اضافه کردن پشتیبانی برای اطمینان از یک قاب ویدیویی اولین زمان بندی در پرونده خروجی را دارد. فایلهای خروجی را که با قاب سیاه در بازیکنان مبتنی بر iOS شروع می شود ، اصلاح می کند ( #829 ).
- انتخاب آهنگ:
- برای فعال کردن انتخاب آهنگ تصویر
DefaultTrackSelector.selectImageTrack
را اضافه کنید. - اضافه کردن
TrackSelectionParameters.isPrioritizeImageOverVideoEnabled
برای تعیین اینکه آیا در صورت وجود یک آهنگ تصویر و یک آهنگ ویدیویی ، یک آهنگ تصویر را انتخاب کنید. مقدار پیش فرضfalse
است و به معنای انتخاب آهنگ ویدیویی در اولویت قرار دارد.
- برای فعال کردن انتخاب آهنگ تصویر
- استخراج کننده ها:
- برای بازیابی
ColorInfo.colorSpace
،ColorInfo.colorTransfer
و مقادیرColorInfo.colorRange
( #692 ) تجزیه شده AR1C اضافی را به استخراج MP4 اضافه کنید. - MP3: از Bitrate ثابت (CBR) استفاده کنید که به دنبال پرونده هایی با عنوان
Info
(معادل CBR از عنوانXing
) باشید. پیش از این ما از جدول Seek از عنوانInfo
استفاده می کردیم ، اما این منجر به جستجوی دقیق کمتری نسبت به اینکه اگر آن را نادیده بگیریم و فرض کنیم پرونده CBR است. - MPEG2-TS: DTS ، DTS-LBR و DTS: X Profile2 پشتیبانی ( #275 ) را اضافه کنید.
- انواع صوتی را از توصیف کنندگان TS استخراج کرده و آنها را به پرچم های نقش نقشه برداری کنید و به کاربران این امکان را می دهد تا انتخاب های صوتی آگاهانه و آگاهانه ای را انتخاب کنند ( شماره 973 ).
- برای بازیابی
- صوتی:
- الگوریتم پرش از سکوت را با رمپ حجم صاف بهبود بخشید. حداقل سکوت و مدت زمان سکوت طبیعی را حفظ کرد ( شماره 7423 ).
- سکوت پرش را به صورت قطعی تر گزارش دهید ( شماره 1035 ).
- ویدئو:
- سازنده
MediaCodecVideoRenderer
را تغییر دهید که یک آرگومانVideoFrameProcessor.Factory
را می گیرد و آن را با سازنده جایگزین می کند که یک آرگومانVideoSinkProvider
را می گیرد. برنامه هایی که می خواهند یکVideoFrameProcessor.Factory
سفارشی تزریق کنند می توانند یکCompositingVideoSinkProvider
را که ازVideoFrameProcessor.Factory
سفارشی استفاده می کند ، فوری کنند و ارائه دهنده سینک ویدیویی را بهMediaCodecVideoRenderer
منتقل کنند.
- سازنده
- متن:
- سریال سازی نشانه های bitmap را برای حل و فصل
Tried to marshall a Parcel that contained Binder objects
هنگام استفاده ازDefaultExtractorsFactory.setTextTrackTranscodingEnabled
( #836 ) است. - CEA-708: مقدار
rowLock
نادیده بگیرید. مشخصات CEA-708-E S-2023 بیان می کند که بدون توجه به مقادیر موجود در جریان ، باید هر دوrowLock
وcolumnLock
درست فرض شوند (پشتیبانیcolumnLock
اجرا نمی شود ، بنابراین به طور مؤثر فرض می شود که همیشه نادرست است).
- سریال سازی نشانه های bitmap را برای حل و فصل
- تصویر:
- پشتیبانی از تصاویر کوچک را اضافه کنید. تصاویر شبکه بریده شده و تصاویر کوچک به
ImageOutput
نزدیک به زمان ارائه آنها ارائه می شود.
- پشتیبانی از تصاویر کوچک را اضافه کنید. تصاویر شبکه بریده شده و تصاویر کوچک به
- DRM:
- نمونه های رمزگذاری نشده "Clear Lead" را در محتوای DRM بلافاصله به طور پیش فرض بازی کنید ، حتی اگر کلیدهای نمونه های رمزگذاری شده بعدی هنوز آماده نباشند. این ممکن است به غرفه های بازی برگشت منجر شود اگر کلیدها هنوز آماده نباشند وقتی موقعیت پخش به نمونه های رمزگذاری شده برسد (اما قبلاً پخش تا این مرحله به هیچ وجه شروع نمی شد). این رفتار را می توان با
MediaItem.DrmConfiguration.Builder.setPlayClearContentWithoutKey
یاDefaultDrmSessionManager.Builder.setPlayClearSamplesWithoutKeys
غیرفعال کرد.
- نمونه های رمزگذاری نشده "Clear Lead" را در محتوای DRM بلافاصله به طور پیش فرض بازی کنید ، حتی اگر کلیدهای نمونه های رمزگذاری شده بعدی هنوز آماده نباشند. این ممکن است به غرفه های بازی برگشت منجر شود اگر کلیدها هنوز آماده نباشند وقتی موقعیت پخش به نمونه های رمزگذاری شده برسد (اما قبلاً پخش تا این مرحله به هیچ وجه شروع نمی شد). این رفتار را می توان با
- پسوند IMA:
- مسئله را در جایی که تبلیغات DASH و HLS بدون پسوند پرونده مناسب انجام نمی شود ، برطرف کنید.
- جلسه:
- تشخیص دو بر روی برنامه های تلویزیونی ( #962 ) را غیرفعال کنید.
- مسئله ای را که
MediaItem.RequestMetadata
با لوازم اضافی غیر تهی بین کنترل کننده های رسانه و جلسات منتقل نمی شود ، برطرف کنید. - سازنده را به
MediaLibrarySession.Builder
اضافه کنید که فقط به جای یکMediaLibraryService
Context
می گیرد.
- پسوند HLS:
-
HlsMediaPeriod
به صورت بسته بندی خصوصی کاهش دهید. این نوع نباید مستقیماً از خارج از بسته HLS به آن بستگی داشته باشد. - Resolve به دنبال شروع یک بخش با کارآمدتر است ( #1031 ).
-
- پسوندهای رمزگشایی (FFMPEG ، VP9 ، AV1 ، MIDI و غیره):
- MIDI DECODER: پیام های رویداد Sysex را نادیده بگیرید ( شماره 710 ).
- خدمات تست:
- پخش مکث را در
TestPlayerRunHelper.playUntilPosition
مکث نکنید. این تست پخش را در حالت بازی نگه می دارد ، اما پیشرفت را به حالت تعلیق در می آورد تا اینکه آزمایش قادر به اضافه کردن ادعاها و اقدامات بیشتر باشد.
- پخش مکث را در
- برنامه نسخه ی نمایشی:
- یک ماژول نسخه ی نمایشی کوتاه را برای نمایشی استفاده از
PreloadMediaSource
با مورد استفاده از محتوای کوتاه اضافه کنید.
- یک ماژول نسخه ی نمایشی کوتاه را برای نمایشی استفاده از
نسخه 1.3.0-RC01
22 فوریه 2024
از نسخه 1.3.0 پایدار استفاده کنید.
نسخه 1.3.0-beta01
7 فوریه 2024
از نسخه 1.3.0 پایدار استفاده کنید.
نسخه 1.3.0-alpha01
15 ژانویه 2024
از نسخه 1.3.0 پایدار استفاده کنید.
نسخه 1.2.0
نسخه 1.2.1
9 ژانویه 2024
- سیارات فراتر:
- مسئله را در جایی که کتابچه راهنمای کاربر در خارج از
LiveConfiguration.min/maxOffset
به دنبال است ، تنظیم کنید تا جبران را بهmin/maxOffset
تنظیم کنید. - مسئله را حل کنید که طرح های کانال Opus و Vorbis برای کانال 3 ، 5 ، 6 ، 7 و 8 اشتباه است ( #8396 ).
- مسئله را برطرف کنید که انتخاب های آهنگ پس از جستجوی صفر در یک جریان مستقیم به طور نادرست اجازه دهید جریان در موقعیت پیش فرض خود شروع شود ( شماره 9347 ).
- مسئله ای را برطرف کنید که در آن موارد جدید
CmcdData.Factory
مقادیر منفی برایbufferedDurationUs
از منابع تکه دریافت کرده و در نتیجه یکIllegalArgumentException
( #888 ) ایجاد می شود.
- مسئله را در جایی که کتابچه راهنمای کاربر در خارج از
- ترانسفورماتور:
- در مورد مسئله ای کار کنید که رمزگذار به دلیل تعیین نرخ کار بالا ، در زمان پیکربندی پرتاب کند.
- استخراج کننده ها:
- آهنگ های HEVC ثانویه (غیرقابل پخش) را در عکسهای حرکت JPEG به عنوان
ROLE_FLAG_ALTERNATE
علامت گذاری کنید تا به دلیل وضوح بالاتر از آنها به طور خودکار برای پخش انتخاب شود. - تشخیص اشتباه کلید برای جریان های TS H264 ( #864 ) را برطرف کنید.
- برآورد مدت زمان جریان TS که بیش از 47721 ثانیه ( #855 ) هستند را برطرف کنید.
- آهنگ های HEVC ثانویه (غیرقابل پخش) را در عکسهای حرکت JPEG به عنوان
- صوتی:
- رسیدگی به EOS را برای
SilenceSkippingAudioProcessor
هنگامی که چندین بار خوانده می شود ( شماره 712 ) برطرف کنید.
- رسیدگی به EOS را برای
- ویدئو:
- راه حل را برای مسئله دستگاه در Galaxy Tab S7 Fe ، Chromecast با Google TV و Lenovo M10 FHD Plus اضافه کنید که باعث می شود جریان های AVC 60 فریم در ثانیه به صورت پشتیبانی نشود ( #693 ).
- فراداده:
- رفع اشکال در جایی که
MediaMetadata
فقط از نظرات Vorbis با کلیدهای مورد نظر بالا ( #876 ) جمع شده بود. - هنگام تجزیه فریم های بسیار بزرگ ID3 ، از
OutOfMemoryError
بگیرید ، به این معنی که پخش می تواند بدون اطلاعات برچسب به جای عدم موفقیت در پخش ، ادامه یابد.
- رفع اشکال در جایی که
- DRM:
- راه حل را برای ClearKey Clearky
https://default.url
مجوز به API 33+ گسترش دهید (قبلاً این راه حل فقط در API 33 دقیقاً اعمال می شود) ( #837 ). - هنگام تعویض از رمزگذاری شده برای پاک کردن محتوا بدون یک سطح متصل به بازیکن
ERROR_DRM_SESSION_NOT_OPENED
برطرف کنید. این خطا به دلیل نادرست استفاده از یک رمزگذار ایمن برای پخش محتوای واضح بود.
- راه حل را برای ClearKey Clearky
- جلسه:
- کلیدها و مقادیر سفارشی را در
MediaMetadataCompat
بهMediaMetadata.extras
وMediaMetadata.extras
بهMediaMetadataCompat
( #756 ، #802 ) قرار دهید. - برای کنترل کننده های میراث ( شماره 644 ) Broadcasting
notifyChildrenChanged
برطرف کنید. - رفع اشکال در جایی که تنظیم زمان منفی برای یک
setWhen
غیرفعال در زمان تایمر اعلان باعث خرابی در برخی از دستگاه ها شد ( شماره 903 ). - هنگامی که کنترل کننده اعلان رسانه در هنگام درخواست اولین به روزرسانی اعلان ، اتصال را تکمیل نکرده است ( شماره 917 )
IllegalStateException
برطرف کنید.
- کلیدها و مقادیر سفارشی را در
- UI:
- پسوند داش:
- تجزیه و تحلیل "F800" به عنوان تعداد کانال 5 برای Dolby in Dash Misper ( #688 ).
- پسوندهای رمزگشایی (FFMPEG ، VP9 ، AV1 ، MIDI و غیره):
- پسوند بازیگران:
- ایجاد یک
Timeline
برای خراب کردن برنامه هنگام بارگیری رسانه در دستگاه بازیگران ( شماره 708 ).
- ایجاد یک
نسخه 1.2.0
15 نوامبر 2023
- کتابخانه مشترک:
- یک پارامتر
@Nullable Throwable
را به روش های موجود در رابطLog.Logger
اضافه کنید. پارامترmessage
به این روشها دیگر حاوی اطلاعاتی در موردThrowable
به ورود بهLog.{d,i,w,e}()
، بنابراین پیاده سازی ها باید در صورت دلخواه این اطلاعات را به صورت دستی اضافه کنند (احتمالاً با استفاده ازLogger.appendThrowableString(String, Throwable)
). - مسئله سازگاری Kotlin را برطرف کنید که در آن پارامترهای نوع عمومی قابل تهی و انواع عناصر آرایه قابل تهی به عنوان تهی تشخیص داده نمی شوند. نمونه ها پارامترهای روش
TrackSelectorResult
وSimpleDecoder
( #6792 ) هستند. - UI پیش فرض و رفتار اطلاع رسانی را در
Util.shouldShowPlayButton
تغییر دهید تا یک دکمه "بازی" را نشان دهید در حالی که پخش به طور موقت سرکوب می شود (به عنوان مثال به دلیل از دست دادن تمرکز صوتی گذرا). رفتار میراث را می توان با استفاده ازPlayerView.setShowPlayButtonIfPlaybackIsSuppressed(false)
یاMediaSession.Builder.setShowPlayButtonIfPlaybackIsSuppressed(false)
( #11213 ) حفظ کرد. -
androidx.annotation:annotation-experimental
به1.3.1
برای رفع https://issuetracker.google.com/251172715. -
ExoPlayer.setAudioAttributes
به رابطPlayer
منتقل کنید.
- یک پارامتر
- سیارات فراتر:
- رفع مشکلات در جریان های AC4 ناشی از عدم شناسایی صحیح نمونه های رمزگشایی ( #11000 ).
- هنگامی که این ویژگی از طریق
ExoPlayer.Builder.setSuppressPlaybackOnUnsuitableOutput
به صورت نامناسب پخش در دستگاه های خروجی صوتی نامناسب (به عنوان مثال بلندگو داخلی در دستگاه های سیستم عامل Wear) اضافه کنید. دلیل سرکوب پخش به عنوانPlayer.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUT
به روز می شود اگر در صورت عدم دسترسی به خروجی صوتی مناسب ، یا اگر تمام خروجی های مناسب در طول پخش قطع شوند ، پخش می شود. دلیل سرکوب هنگام اتصال خروجی مناسب حذف می شود. - برای پذیرش به روزرسانی های
MediaItem
پس از ایجاد از طریقPlayer.replaceMediaItem(s)
اضافه کردنMediaSource.canUpdateMediaItem
وMediaSource.updateMediaItem
را اضافه کنید. - اجازه دهید به روزرسانی های
MediaItem
برای کلیه کلاسهایMediaSource
ارائه شده توسط کتابخانه از طریقPlayer.replaceMediaItem(s)
( #33 ، #9978 ). - تغییر نام
MimeTypes.TEXT_EXOPLAYER_CUES
بهMimeTypes.APPLICATION_MEDIA3_CUES
. -
PngExtractor
که یک فایل PNG را به عنوان یکTrackOutput
به صورت یک نمونه ارسال و می خواند ، اضافه کنید. - روش
SequenceableLoader.continueLoading(long)
در رابطSequenceableLoader
بهSequenceableLoader.continueLoading(LoadingInfo loadingInfo)
.LoadingInfo
شامل پارامترهای اضافی ، از جملهplaybackSpeed
وlastRebufferRealtimeMs
علاوه برplaybackPositionUs
موجود است. - Enhance
ChunkSource.getNextChunk(long, long, List, ChunkHolder)
در رابطChunkSource
بهChunkSource.getNextChunk(LoadingInfo, long, List, ChunkHolder)
. - زمینه های اضافی را به داده های مشتری مشترک رسانه (CMCD) اضافه کنید: گرسنگی بافر (
bs
) ، مهلت (dl
) ، نرخ پخش (pr
) و راه اندازی (su
) ( #8699 ). - Luma و Chroma Bitdepth را به
ColorInfo
اضافه کنید ( شماره 491 ). - زمینه های اضافی را به داده های مشتری متداول (CMCD) وارد کنید: درخواست شیء بعدی (
nor
) و درخواست محدوده بعدی (nrr
) ( #8699 ). - با استفاده از پارامترهای پرس و جو ( شماره 553 ) ، عملکرد داده های داده مشتری مشترک (CMCD) را اضافه کنید.
- رفع
ConcurrentModificationException
درExperimentalBandwidthMeter
( #612 ). - پارامتر
MediaPeriodId
را بهCompositeMediaSource.getMediaTimeForChildMediaTime
اضافه کنید. - پشتیبانی از
ClippingMediaSource
(و سایر منابع با جبران زمان/پنجره) درConcatenatingMediaSource2
( #11226 ). -
BaseRenderer.onStreamChanged()
را نیز تغییر دهید تا یک استدلالMediaPeriodId
نیز دریافت کنید.
- ترانسفورماتور:
- تجزیه و تحلیل داده های چرخش Exif برای ورودی های تصویر.
- نوع حاشیه نویسی
TransformationRequest.HdrMode
و ثابت های مرتبط با آن را حذف کنید. به جای آنComposition.HdrMode
و ثابت های مرتبط با آن استفاده کنید. - برای رفع مشکلات چرخش
OverlaySettings
ساده کنید. - پارامترهای
frameRate
وdurationUs
تغییر یافته ازSampleConsumer.queueInputBitmap
بهTimestampIterator
.
- انتخاب آهنگ:
- اضافه کردن
DefaultTrackSelector.Parameters.allowAudioNonSeamlessAdaptiveness
را برای صریح یا مجاز بودن سازگاری غیر یککاره ای اضافه کنید. پیش فرض در رفتار فعلی خود ازtrue
باقی می ماند.
- اضافه کردن
- استخراج کننده ها:
- MPEG-TS: اطمینان حاصل کنید که آخرین قاب با عبور آخرین واحد دسترسی یک جریان به صف نمونه ( شماره 7909 ) ارائه می شود.
- هنگام تعیین
rotationDegrees
، تایپی را برطرف کنید.projectionPosePitch
بهprojectionPoseRoll
تغییر داد ( شماره 461 ). - این فرض را حذف کنید که نمونه های
Extractor
می توانند مستقیماً باinstanceof
مورد بازرسی قرار گیرند. اگر می خواهید دسترسی به زمان اجرا به جزئیات اجرای یکExtractor
، ابتدا باExtractor.getUnderlyingInstance
تماس بگیرید. -
BmpExtractor
اضافه کنید. -
WebpExtractor
اضافه کنید. -
HeifExtractor
را اضافه کنید. - پشتیبانی QuickTime Classic را به
Mp4Extractor
اضافه کنید.
- صوتی:
- پشتیبانی از PCM بزرگ 24/32 بیتی در MP4 و Matroska و رمزگذاری PCM PARSE برای
lpcm
در MP4 را اضافه کنید. - پشتیبانی از استخراج صوتی Vorbis را در MP4 اضافه کنید.
-
DefaultAudioOffloadSupportProvider
AudioSink.getFormatOffloadSupport(Format)
را که بازیابی سطح Offload پشتیبانی می کند ، اضافه کنید. اینAudioOffloadSupport
جدید را که شاملisFormatSupported
،isGaplessSupported
وisSpeedChangeSupported
است ، برمی گرداند. -
AudioSink.setOffloadMode()
را که از طریق آن پیکربندی Offload روی سینک صوتی پیکربندی شده است ، اضافه کنید. پیش فرضAudioSink.OFFLOAD_MODE_DISABLED
است. - بارگیری را می توان از طریق
setAudioOffloadPreference
درTrackSelectionParameters
فعال کرد. اگر اولویت تنظیم شده برای فعال کردن باشد ، دستگاه از بارگیری برای قالب پشتیبانی می کند و انتخاب آهنگ یک آهنگ صوتی واحد است ، سپس بارگیری صوتی فعال می شود. - اگر
audioOffloadModePreference
رویAUDIO_OFFLOAD_MODE_PREFERENCE_REQUIRED
تنظیم شده باشد ، آنگاهDefaultTrackSelector
فقط یک آهنگ صوتی را انتخاب می کند و تنها در صورتی که فرمت آهنگ در Offload پشتیبانی شود. اگر هیچ آهنگ صوتی در بارگیری پشتیبانی نشود ، هیچ آهنگ انتخاب نمی شود. - غیرفعال کردن پشتیبانی بدون شکاف برای بارگیری در هنگام قبل از API سطح 33 به دلیل مشکل موقعیت پخش پس از انتقال آهنگ.
- پارامتر
enableOffload
ازDefaultRenderersFactory.buildAudioSink
امضا کنید. - روش
DefaultAudioSink.Builder.setOffloadMode
را حذف کنید. - حذف مقدار intdef
DefaultAudioSink.OffloadMode.OFFLOAD_MODE_ENABLED_GAPLESS_DISABLED
. - پشتیبانی از ابرداده بدون شکاف OPUS را در حین پخش بارگیری اضافه کنید.
- در صورت عدم موفقیت در ابتدا نوشتن ، بازیابی رندر را با غیرفعال کردن بارگیری مجاز می کند ( شماره 627 ).
- برنامه ریزی Offload را به طور پیش فرض برای پخش بارگذاری شده فقط صوتی فعال کنید.
- حذف
ExoPlayer.experimentalSetOffloadSchedulingEnabled
وAudioOffloadListener.onExperimentalOffloadSchedulingEnabledChanged
. - با نام
onExperimentalSleepingForOffloadChanged
به عنوانonSleepingForOffloadChanged
وonExperimentalOffloadedPlayback
به عنوانonOffloadedPlayback
تغییر نام داد. - جابجایی رابط ها و تعاریف مربوط به
TrackSelectionParameters
به حالت Offload Audio Offload Mode را به یک کلاس داخلیAudioOffloadPreferences
منتقل کنید. - تماسهای برگشتی و
onAudioTrackInitialized
وonAudioTrackReleased
را بهAnalyticsListener
،AudioRendererEventListener
وAudioSink.Listener
اضافه کنید. - مشکل زیر جریان بافر صوتی DTS Express را برطرف کنید ( #650 ).
- رفع اشکال در جایی که قابلیت های E-AC3-JOC را بررسی می کند ، یک
IllegalArgumentException
( #677 ) را پرتاب می کند.
- پشتیبانی از PCM بزرگ 24/32 بیتی در MP4 و Matroska و رمزگذاری PCM PARSE برای
- ویدئو:
- به
MediaCodecVideoRenderer
اجازه دهید از یکVideoFrameProcessor.Factory
سفارشی استفاده کند. - در صورت شروع جریان صوتی با جدول زمانی منفی ( شماره 291 ) ، اشکال را در جایی که قاب اول قابل ارائه نیست ، برطرف کنید.
- به
- متن:
-
ExoplayerCuesDecoder
حذف کنید. آهنگ های متنی باsampleMimeType = application/x-media3-cues
اکنون مستقیماً توسطTextRenderer
بدون نیاز به یک نمونهSubtitleDecoder
به طور مستقیم اداره می شوند.
-
- فراداده:
-
MetadataDecoder.decode
دیگر برای نمونه های "فقط رمزگشایی" فراخوانی نمی شود زیرا اجرای به هر حال باید تهی شود.
-
- اثر:
- اضافه کردن
VideoFrameProcessor.queueInputBitmap(Bitmap, Iterator<Long>)
ورودی بیت مپ توسط Timestamp. - تغییر
VideoFrameProcessor.registerInputStream()
به غیر مسدود کننده. برنامه ها بایدVideoFrameProcessor.Listener#onInputStreamRegistered()
را پیاده سازی کنند. - پارامترهای
frameRate
وdurationUs
تغییر یافته ازVideoFrameProcessor.queueInputBitmap
بهTimestampIterator
.
- اضافه کردن
- پسوند IMA:
- رفع اشکال در جایی که یک جریان مستقیم چند دوره ای که اولین مورد در لیست پخش نیست می تواند یک استثنا را پرتاب کند ( شماره 571 ).
- انتشار streammanager قبل از تماس با
AdsLoader.destroy()
- نسخه IMA SDK BUMP به 3.31.0.
- جلسه:
- اعلان های پیش زمینه خدمات پیش زمینه را روی
FOREGROUND_SERVICE_IMMEDIATE
درDefaultMediaNotificationProvider
( شماره 167 ) تنظیم کنید. - فقط از
android.media.session.MediaSession.setMediaButtonBroadcastReceiver()
در بالا API 31 استفاده کنید تا از مشکلات مربوط به API کاهش یافته در دستگاه های سامسونگ جلوگیری کنید ( شماره 167 ). - برای تنظیم دستورات موجود و طرح بندی سفارشی که برای جمع آوری اعلان و جلسه پلتفرم استفاده می شود ، از کنترلر اعلان رسانه به عنوان پروکسی استفاده کنید.
- به جای اینکه آنها را به جلسه پلتفرم و بازگشت به Media3 برگردانید ، رویدادهای دکمه رسانه ای را که توسط
MediaSessionService.onStartCommand()
در Media3 دریافت می شود ، تبدیل کنید. با این کار ، کنترلر تماس گیرنده همیشه کنترل کننده اعلان رسانه است و برنامه ها می توانند به راحتی تماس های حاصل از اعلان را به همان روش در تمام سطوح API پشتیبانی شده تشخیص دهند. - رفع اشکال در جایی که
MediaController.getCurrentPosition()
هنگام اتصال به یکMediaSessionCompat
میراث پیش نمی رود. - برای راحتی
MediaLibrarySession.getSubscribedControllers(mediaId)
را اضافه کنید. - برای ادعای در دسترس بودن شناسه والدین که کنترل کننده در آن مشترک است ، ادعای
MediaLibrarySession.Callback.onSubscribe()
را نادیده بگیرید. در صورت موفقیت ، اشتراک پذیرفته می شود وnotifyChildrenChanged()
بلافاصله برای اطلاع رسانی به مرورگر ( شماره 561 ) فراخوانی می شود. - ماژول نسخه ی نمایشی جلسه را برای سیستم عامل خودرو اضافه کرده و نسخه آزمایشی جلسه را برای Android Auto فعال کنید.
- وقتی
COMMAND_GET_TIMELINE
برای کنترل کننده اعلان رسانه در دسترس نیست ، صف جلسه Framework را تنظیم نکنید. با استفاده از Android Auto به عنوان کنترلر مشتری که از جلسه Framework می خواند ، این تأثیر دارد که دکمهqueue
در UI Android Auto نمایش داده نمی شود ( شماره 339 ). - به جای
SimpleBitmapLoader
( #271 ، #327 ) به طور پیش فرض ازDataSourceBitmapLoader
استفاده کنید. - اضافه کردن
MediaSession.Callback.onMediaButtonEvent(Intent)
که به برنامه ها اجازه می دهد تا از اجرای رویداد پیش فرض دکمه رسانه استفاده کنند.
- اعلان های پیش زمینه خدمات پیش زمینه را روی
- UI:
- با راه اندازی یک گفتگوی سیستم ، یک
Player.Listener
برای دستگاه های سیستم عامل Wear که سرکوب پخش را به دلیلPlayer.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUT
انجام می دهد ، اضافه کنید. اگر یک دستگاه مناسب در یک زمان تنظیم قابل تنظیم (پیش فرض 5 دقیقه باشد) ، شنونده پخش خودکار را پخش می کند.
- با راه اندازی یک گفتگوی سیستم ، یک
- دانلودها:
- برای سازگاری Android 14 نوع سرویس
DownloadService
زمینه "Data Sync" را اعلام کنید. هنگام استفاده از این سرویس ، برنامه همچنین بایدdataSync
به عنوانforegroundServiceType
در مانیفست اضافه کرده و مجوزFOREGROUND_SERVICE_DATA_SYNC
را اضافه کند ( #11239 ).
- برای سازگاری Android 14 نوع سرویس
- پسوند HLS:
- لیست پخش زنده HLS را با فاصله ای محاسبه شده از آخرین زمان شروع بار به جای آخرین بار زمان تکمیل شده ( #663 ) تازه کنید.
- پسوند داش:
- اجازه دهید چندین مورد از همان شناسه DASH در URL الگوی قطعه.
- پشتیبانی آزمایشی برای زیرنویس تجزیه در هنگام استخراج. این پشتیبانی بهتری برای ادغام زیرنویس های همپوشانی دارد ، از جمله حل سوسو هنگام انتقال بین بخش های زیرنویس. شما می توانید این کار را با استفاده از
DashMediaSource.Factory.experimentalParseSubtitlesDuringExtraction()
( #288 ) فعال کنید.
- پسوند RTSP:
- یک وضعیت مسابقه را برطرف کنید که می تواند هنگام بازگشت به TCP یا پخش در برخی از مواقع ، به
IndexOutOfBoundsException
منجر شود. - هنگام بازگشت حالت بارگذاری
RtspMediaPeriod
( #577 ) حالت را در تنظیم RTSP بررسی کنید. - روشهای درخواست RTSP سفارشی را در گزینه های پاسخ دهی عمومی ( شماره 613 ) نادیده بگیرید.
- از مقدار زمان پاسخگویی تنظیم RTSP در فاصله زمانی ارسال درخواست گزینه های گزینه RTSP ( شماره 662 ) استفاده کنید.
- یک وضعیت مسابقه را برطرف کنید که می تواند هنگام بازگشت به TCP یا پخش در برخی از مواقع ، به
- پسوندهای رمزگشایی (FFMPEG ، VP9 ، AV1 ، MIDI و غیره):
- ماژول Decoder MIDI را منتشر کنید ، که پشتیبانی از پخش پرونده های استاندارد MIDI را با استفاده از کتابخانه JSYN برای سنتز صوتی فراهم می کند.
- به
DecoderOutputBuffer.shouldBeSkipped
اضافه کنید تا مستقیماً بافرهای خروجی را که نیازی به ارائه ندارند ، علامت گذاری کنید. این بیش ازC.BUFFER_FLAG_DECODE_ONLY
ترجیح داده می شود که کاهش می یابد. -
Decoder.setOutputStartTimeUs
وSimpleDecoder.isAtLeastOutputStartTimeUs
را اضافه کنید تا به رمزگشایی ها اجازه دهید نمونه های رمزگشایی را قبل از زمان شروع رها کنند. این باید بهBuffer.isDecodeOnly
ترجیح داده شود که کاهش یابد. - تصحیح آثار باستانی MIDI را به مخزن Maven Fix کنید. مصنوعات به
media3-exoplayer-midi
( شماره 734 ) تغییر نام داده می شود.
- پسوند Leanback:
- رفع اشکال در جایی که غیرفعال کردن یک سطح می تواند باعث
ArithmeticException
در کد Leanback شود ( شماره 617 ).
- رفع اشکال در جایی که غیرفعال کردن یک سطح می تواند باعث
- خدمات تست:
-
TestExoPlayerBuilder
وFakeClock
را با تست های UI اسپرسو سازگار و تست های UI سازگار کنید. این یک اشکال را برطرف می کند که در آن پخش به طور غیر قطعی در طول اسپرسو پیشرفت می کند یا تعامل نمای را ایجاد می کند.
-
- نمادهای کاهش یافته را حذف کنید:
- حذف
TransformationRequest.Builder.setEnableRequestSdrToneMapping(boolean)
وTransformationRequest.Builder.experimental_setEnableHdrEditing(boolean)
. ازComposition.Builder.setHdrMode(int)
استفاده کنید و به جای آنComposition
بهTransformer.start(Composition, String)
منتقل کنید. - حذف Deadcated
DownloadNotificationHelper.buildProgressNotification
، از یک روش غیر مستهجن استفاده کنید که به جای آن یک پارامترnotMetRequirements
می گیرد.
- حذف
نسخه 1.2.0-RC01
1 نوامبر 2023
از نسخه 1.2.0 پایدار استفاده کنید.
نسخه 1.2.0-beta01
19 اکتبر 2023
از نسخه 1.2.0 پایدار استفاده کنید.
نسخه 1.2.0-alpha02
29 سپتامبر 2023
از نسخه 1.2.0 پایدار استفاده کنید.
نسخه 1.2.0-alpha01
17 آگوست 2023
از نسخه 1.2.0 پایدار استفاده کنید.
نسخه 1.1.0
نسخه 1.1.1
16 آگوست 2023
- کتابخانه مشترک:
- وابستگی
multidex
به طور تصادفی اضافه شده را از همه ماژول ها حذف کنید ( شماره 499 ).
- وابستگی
- سیارات فراتر:
- مشکل را در
PlaybackStatsListener
که در آنPlaybackStats
Spurious پس از پاکسازی لیست پخش ایجاد می شوند ، رفع کنید. - زمینه های اضافی را به داده های مشتری متداول (CMCD) وارد کنید: فرمت جریان (SF) ، نوع جریان (ST) ، نسخه (V) ، Top Birate (TB) ، مدت زمان شی (D) ، توان اندازه گیری شده (MTP) و نوع شیء (OT) ( #8699 ).
- مشکل را در
- صوتی:
- اشکال را برطرف کنید که در آن
Player.getState()
هنگام پخش پرونده های بسیار کوتاه بهSTATE_ENDED
منتقل نشد ( شماره 538 ).
- اشکال را برطرف کنید که در آن
- بارگیری صوتی:
- صفحه اصلی OGG ID و صفحات هدر نظر را به BitStream برای پخش OPUS بارگیری شده مطابق با RFC 7845 ارائه دهید.
- ویدئو:
- H.265/HEVC: اطلاعات مربوط به تصویر مرجع کوتاه مدت و بلند مدت SPS را برطرف کنید.
- متن:
- CEA-608: منطق کوتاه کردن نشانه را تغییر دهید تا فقط متن قابل مشاهده را در نظر بگیرید. پیش از این ، هنگام محدود کردن طول نشانه به 32 کاراکتر (که از نظر فنی توسط مشخصات صحیح بود) (که از نظر فنی صحیح بود) ( #11019) ( #11019 ).
- پسوند IMA:
- نسخه Bump IMA SDK تا 3.30.3.
- جلسه:
- طرح سفارشی را به حالت کنترلر اضافه کنید و یک گیرنده را برای دسترسی به آن فراهم کنید. هنگامی که طرح بندی سفارشی تغییر می کند ،
MediaController.Listener.onCustomLayoutChanged
خوانده می شود. برنامه هایی که می خواهند طرح های مختلف سفارشی را به کنترل کننده Media3 مختلف ارسال کنند می توانند این کار را درMediaSession.Callback.onConnect
با استفاده از یکAcceptedResultBuilder
انجام دهند تا مطمئن شوید که هنگام اتمام اتصال ، طرح سفارشی در دسترس کنترلر است. - مواردی را برطرف کنید که
MediaLibraryServiceLegacyStub
خطایی را بهResult
ای ارسال کند که از این امر پشتیبانی نمی کند که باعث ایجادUnsupportedOperationException
( شماره 78 ) می شود. - Fix the way
PlayerWrapper
creates aVolumeProviderCompat
by determiningvolumeControlType
through both legacy commands (COMMAND_ADJUST_DEVICE_VOLUME
andCOMMAND_SET_DEVICE_VOLUME
) and new commands (COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS
andCOMMAND_SET_DEVICE_VOLUME_WITH_FLAGS
) ( #554 ).
- طرح سفارشی را به حالت کنترلر اضافه کنید و یک گیرنده را برای دسترسی به آن فراهم کنید. هنگامی که طرح بندی سفارشی تغییر می کند ،
نسخه 1.1.0
5 جولای 2023
- کتابخانه مشترک:
- دلیل سرکوب را برای مسیر صوتی نامناسب اضافه کنید و در هنگام تغییر آماده برای سرکوب بیش از حد طولانی ، بازی کنید. ( شماره 15 ).
- دستورات را به بازیکن اضافه کنید:
-
COMMAND_GET_METADATA
-
COMMAND_SET_PLAYLIST_METADATA
-
COMMAND_SET_DEVICE_VOLUME_WITH_FLAGS
-
COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS
-
- روشهای اضافه بار را به بازیکن اضافه کنید که به کاربران امکان می دهد پرچم های حجم را مشخص کنند:
-
void setDeviceVolume(int, int)
-
void increaseDeviceVolume(int)
-
void decreaseDeviceVolume(int)
-
void setDeviceMuted(boolean, int)
-
-
Builder
برایDeviceInfo
اضافه کنید و سازنده موجود را کاهش دهید. - برای مشخص کردن شناسه کنترل کننده مسیریابی برای پخش از راه دور ،
DeviceInfo.routingControllerId
را اضافه کنید. -
Player.replaceMediaItem(s)
را به عنوان میانبر اضافه کردن و حذف موارد در همان موقعیت ( شماره 8046 ) اضافه کنید.
- سیارات فراتر:
- اجازه دهید سیاخلایر بتواند روشهای حجم دستگاه را فقط در صورت انتخاب صریح کنترل کند. از
ExoPlayer.Builder.setDeviceVolumeControlEnabled
استفاده کنید تا به این موارد دسترسی داشته باشید:-
getDeviceVolume()
-
isDeviceMuted()
-
setDeviceVolume(int)
وsetDeviceVolume(int, int)
-
increaseDeviceVolume(int)
وincreaseDeviceVolume(int, int)
-
decreaseDeviceVolume(int)
وdecreaseDeviceVolume(int, int)
-
-
FilteringMediaSource
را اضافه کنید که امکان فیلتر کردن انواع آهنگ های موجود را ازMediaSource
فراهم می کند. - پشتیبانی از داده های مشتری مشترک رسانه (CMCD) را در درخواست های خروجی قالب های جریان سازگار ، HLS و Smoothstreaming اضافه کنید. زمینه های زیر ،
br
،bl
،cid
،rtp
وsid
گنجانیده شده اند ( #8699 ). ساختار API و روش های API:- ورود به سیستم CMCD به طور پیش فرض غیرفعال است ، از
MediaSource.Factory.setCmcdConfigurationFactory(CmcdConfiguration.Factory cmcdConfigurationFactory)
استفاده کنید تا آن را فعال کنید. - تمام کلیدها به طور پیش فرض فعال می شوند ،
CmcdConfiguration.RequestConfig.isKeyAllowed(String key)
را نادیده می گیرند تا از کدام کلیدها وارد شوند. - برای فعال کردن ورود به سیستم کلید سفارشی
CmcdConfiguration.RequestConfig.getCustomData()
را نادیده بگیرید.
- ورود به سیستم CMCD به طور پیش فرض غیرفعال است ، از
- برای آشکار کردن نسخه ی نمایشی اصلی ، اقدامات اضافی اضافه کنید تا شروع برنامه نسخه ی نمایشی با پرونده سفارشی
*.exolist.json
( شماره 439 ) را آسان تر کنید. -
ExoPlayer.setVideoEffects()
را برای استفاده ازEffect
در هنگام پخش ویدیویی اضافه کنید. -
SampleQueue
به روز کنید تاsourceId
به عنوان یکint
long
ذخیره کنید. این تغییر امضاهای روشهای عمومیSampleQueue.sourceId
وSampleQueue.peekSourceId
. - پارامترها را به روشهای
LoadControl
اضافه کنیدshouldStartPlayback
وonTracksSelected
استفاده کنید که امکان ارتباط این روش ها را باMediaPeriod
مربوطه فراهم می کند. - تغییر امضا از
ServerSideAdInsertionMediaSource.setAdPlaybackStates(Map<Object, AdPlaybackState>)
با اضافه کردن یک پارامتر جدول زمانی که شامل دوره هایی با UID های مورد استفاده به عنوان کلیدهای موجود در نقشه است. این مورد برای جلوگیری از مشکلات همزمانی با جریان های زنده چند دوره ای لازم است. - deprecate
EventDispatcher.withParameters(int windowIndex, @Nullable MediaPeriodId mediaPeriodId, long mediaTimeOffsetMs)
وBaseMediaSource.createEventDispatcher(..., long mediaTimeOffsetMs)
. به جای آن ، نوع روش های بدونmediaTimeOffsetUs
را می توان نامید. توجه داشته باشید که حتی برای انواع مستهجن ، افست دیگر بهstartTimeUs
وendTimeUs
از اشیاءMediaLoadData
که توسط توزیع کننده ارسال می شوند اضافه نمی شود. - تغییر نام
ExoTrackSelection.blacklist
toexcludeTrack
وisBlacklisted
بهisTrackExcluded
. - رفتار متناقض بین
ExoPlayer.setMediaItem(s)
وaddMediaItem(s)
را هنگام فراخوانی در لیست پخش خالی برطرف کنید.
- اجازه دهید سیاخلایر بتواند روشهای حجم دستگاه را فقط در صورت انتخاب صریح کنترل کند. از
- ترانسفورماتور:
- حذف
Transformer.Builder.setMediaSourceFactory(MediaSource.Factory)
. به جای آن ازExoPlayerAssetLoader.Factory(MediaSource.Factory)
وTransformer.Builder.setAssetLoaderFactory(AssetLoader.Factory)
استفاده کنید. - حذف
Transformer.startTransformation(MediaItem, ParcelFileDescriptor)
. - در صورتی که پایان جریان ویدیو در لحظه ای که یک قاب ورودی در انتظار پردازش بود ، یک اشکال را برطرف کرد (که منجر به مدت زمان موکسی می شود).
- کد های پرس و جو از طریق
MediaCodecList
به جای استفاده از برنامه هایfindDecoder/EncoderForFormat
، برای گسترش پشتیبانی. - پیکربندی B-Frame را در
DefaultEncoderFactory
حذف کنید زیرا در برخی از دستگاه ها کار نمی کند.
- حذف
- انتخاب آهنگ:
- اضافه کردن
DefaultTrackSelector.Parameters.allowInvalidateSelectionsForRendererCapabilitiesChange
که به طور پیش فرض غیرفعال است. در صورت فعال شدن ،DefaultTrackSelector
با تغییر قابلیت های Renderer ، انتخاب آهنگ جدیدی را ایجاد می کند.
- اضافه کردن
- استخراج کننده ها:
- صوتی:
- رفع اشکال در جایی که برخی از پخش ها در هنگام فعال کردن تونل سازی شکست می خورند و
AudioProcessors
فعال هستند ، به عنوان مثال برای پیرایش بدون شکاف ( #10847 ). - فریم های Opus را در بسته های OGG در پخش مستقیم (Offload) محصور کنید.
- موقعیت فعلی را در هنگام خواب با برنامه ریزی خاموش برون یابی کنید.
-
Renderer.release()
وAudioSink.release()
را برای انتشار منابع در پایان چرخه حیات بازیکن اضافه کنید. - به تغییرات قابلیت های صوتی در
DefaultAudioSink
گوش دهید. یکcontext
پارامتر مورد نیاز را در سازندهDefaultAudioSink
اضافه کنید ، که با استفاده از آنDefaultAudioSink
به عنوان شنوندهAudioCapabilitiesReceiver
ثبت می شود و در صورت اطلاع از قابلیت های تغییر ، ویژگیaudioCapabilities
آن را به روز می کند. - Propagate audio capabilities changes via a new event
onAudioCapabilitiesChanged
inAudioSink.Listener
interface, and a new interfaceRendererCapabilities.Listener
which triggersonRendererCapabilitiesChanged
events. - Add
ChannelMixingAudioProcessor
for applying scaling/mixing to audio channels. - Add new int value
DISCARD_REASON_AUDIO_BYPASS_POSSIBLE
toDecoderDiscardReasons
to discard audio decoder when bypass mode is possible after audio capabilities change. - Add direct playback support for DTS Express and DTS:X ( #335 ).
- رفع اشکال در جایی که برخی از پخش ها در هنگام فعال کردن تونل سازی شکست می خورند و
- ویدئو:
- Make
MediaCodecVideoRenderer
report aVideoSize
with a width and height of 0 when the renderer is disabled.Player.Listener.onVideoSizeChanged
is called accordingly whenPlayer.getVideoSize()
changes. With this change, ExoPlayer's video size withMediaCodecVideoRenderer
has a width and height of 0 whenPlayer.getCurrentTracks
does 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
DefaultDrmSession
that 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.getControllerForCurrentRequest
to obtain information about the controller that is currently calling aPlayer
method. - Add
androidx.media3.session.MediaButtonReceiver
to enable apps to implement playback resumption with media button events sent by, for example, a Bluetooth headset ( #167 ). - Add default implementation to
MediaSession.Callback.onAddMediaItems
to allow requestedMediaItems
to be passed ontoPlayer
if they haveLocalConfiguration
(eg 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.onAddMediaItems
to allow requestedMediaItems
to be passed ontoPlayer
if they haveLocalConfiguration
(eg 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
shouldShowPlayButton
andhandlePlayPauseButtonAction
to write custom UI elements with a play/pause button.
- Add Util methods
- RTSP Extension:
- DASH Extension:
- Remove the media time offset from
MediaLoadData.startTimeMs
andMediaLoadData.endTimeMs
for 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 theTimestampAdjuster
to initialize. If the initialization doesn't complete before the timeout, aPlaybackException
is 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
DefaultAudioSink
constructors, useDefaultAudioSink.Builder
instead. - Remove
HlsMasterPlaylist
, useHlsMultivariantPlaylist
instead. - Remove
Player.stop(boolean)
. UsePlayer.stop()
andPlayer.clearMediaItems()
(ifreset
istrue
) instead. - Remove two deprecated
SimpleCache
constructors, use a non-deprecated constructor that takes aDatabaseProvider
instead for better performance. - Remove
DefaultBandwidthMeter
constructor, useDefaultBandwidthMeter.Builder
instead. - Remove
DefaultDrmSessionManager
constructors, useDefaultDrmSessionManager.Builder
instead. - Remove two deprecated
HttpDataSource.InvalidResponseCodeException
constructors, 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.forMediaItem
instead. - Remove deprecated
DownloadService
constructor, use a non deprecated constructor that includes the option to provide achannelDescriptionResourceId
parameter. - Remove deprecated String constants for Charsets (
ASCII_NAME
,UTF8_NAME
,ISO88591_NAME
,UTF16_NAME
andUTF16LE_NAME
), use Kotlin Charsets from thekotlin.text
package, thejava.nio.charset.StandardCharsets
or thecom.google.common.base.Charsets
instead. - Remove deprecated
WorkManagerScheduler
constructor, use a non deprecated constructor that includes the option to provide aContext
parameter instead. - Remove the deprecated methods
createVideoSampleFormat
,createAudioSampleFormat
,createContainerFormat
, andcreateSampleFormat
, which were used to instantiate theFormat
class. Instead useFormat.Builder
for creating instances ofFormat
. - Remove the deprecated methods
copyWithMaxInputSize
,copyWithSubsampleOffsetUs
,copyWithLabel
,copyWithManifestFormatInfo
,copyWithGaplessInfo
,copyWithFrameRate
,copyWithDrmInitData
,copyWithMetadata
,copyWithBitrate
andcopyWithVideoSize
, useFormat.buildUpon()
and setter methods instead. - Remove deprecated
ExoPlayer.retry()
, useprepare()
instead. - Remove deprecated zero-arg
DefaultTrackSelector
constructor, useDefaultTrackSelector(Context)
instead. - Remove deprecated
OfflineLicenseHelper
constructor, useOfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)
instead. - Remove deprecated
DownloadManager
constructor, use the constructor that takes anExecutor
instead. - Remove deprecated
Cue
constructors, useCue.Builder
instead. - Remove deprecated
OfflineLicenseHelper
constructor, useOfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)
instead. - Remove four deprecated
AnalyticsListener
methods:-
onDecoderEnabled
, useonAudioEnabled
and/oronVideoEnabled
instead. -
onDecoderInitialized
, useonAudioDecoderInitialized
and/oronVideoDecoderInitialized
instead. -
onDecoderInputFormatChanged
, useonAudioInputFormatChanged
and/oronVideoInputFormatChanged
instead. -
onDecoderDisabled
, useonAudioDisabled
and/oronVideoDisabled
instead.
-
- Remove the deprecated
Player.Listener.onSeekProcessed
andAnalyticsListener.onSeekProcessed
, useonPositionDiscontinuity
withDISCONTINUITY_REASON_SEEK
instead. - Remove
ExoPlayer.setHandleWakeLock(boolean)
, usesetWakeMode(int)
instead. - Remove deprecated
DefaultLoadControl.Builder.createDefaultLoadControl()
, usebuild()
instead. - Remove deprecated
MediaItem.PlaybackProperties
, useMediaItem.LocalConfiguration
instead. Deprecated fieldMediaItem.playbackProperties
is now of typeMediaItem.LocalConfiguration
.
- Remove
Version 1.1.0-rc01
21 ژوئن 2023
Use the 1.1.0 stable version .
Version 1.1.0-beta01
7 ژوئن 2023
Use the 1.1.0 stable version .
Version 1.1.0-alpha01
10 مه 2023
Use the 1.1.0 stable version .
نسخه 1.0.0
Version 1.0.2
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 ifBuffer
contains 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 ).
- متن:
- SSA: Add support for UTF-16 files if they start with a byte order mark ( #319 ).
- Session:
- Fix issue where
MediaController
doesn't update its available commands when connected to a legacyMediaSessionCompat
that updates its actions. - Fix bug that prevented the
MediaLibraryService
from returning null for a call from System UI toCallback.onGetLibraryRoot
withparams.isRecent == true
on API 30 ( #355 ). - Fix memory leak of
MediaSessionService
orMediaLibraryService
( #346 ). - Fix bug where a combined
Timeline
and position update in aMediaSession
may cause aMediaController
to throw anIllegalStateException
.
- Fix issue where
Version 1.0.1
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
MediaSessionCompat
result in an exception inMediaController
( #290 ). - Add missing forwarding of
MediaSession.broadcastCustomCommand
to the legacyMediaControllerCompat.Callback.onSessionEvent
( #293 ). - Fix bug where calling
MediaSession.setPlayer
doesn't update the available commands. - Fix issue that
TrackSelectionOverride
instances sent from aMediaController
are ignored if they reference a group withFormat.metadata
( #296 ). - Fix issue where
Player.COMMAND_GET_CURRENT_MEDIA_ITEM
needs to be available to access metadata via the legacyMediaSessionCompat
. - Fix issue where
MediaSession
instances 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 ).
نسخه 1.0.0
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
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:
- دانلودها:
- Make the maximum difference of the start time of two segments to be merged configurable in
SegmentDownloader
and subclasses ( #248 ).
- Make the maximum difference of the start time of two segments to be merged configurable in
- صوتی:
- ویدئو:
- Map HEVC HDR10 format to
HEVCProfileMain10HDR10
instead 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
- بازیگران:
- Fix transient
STATE_IDLE
when 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)
LOADED
event 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
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.setPlaybackLooper
that sets a pre-existing playback thread for a new ExoPlayer instance. - Allow download manager helpers to be cleared ( #10776 ).
- Add parameter to
BasePlayer.seekTo
to also indicate the command used for seeking. - Use theme when loading drawables on API 21+ ( #220 ).
- Add
ConcatenatingMediaSource2
that allows combining multiple media items into a single window ( #247 ).
- Tweak the renderer's decoder ordering logic to uphold the
- Extractors:
- Throw a
ParserException
instead of aNullPointerException
if 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
- صوتی:
- Use the compressed audio format bitrate to calculate the min buffer size for
AudioTrack
in direct playbacks (passthrough).
- Use the compressed audio format bitrate to calculate the min buffer size for
- متن:
- Fix
TextRenderer
passing an invalid (negative) index toSubtitle.getEventTime
if a subtitle file contains no cues. - SubRip: Add support for UTF-16 files if they start with a byte order mark.
- Fix
- فراداده:
- Parse multiple null-separated values from ID3 frames, as permitted by ID3 v2.4.
- Add
MediaMetadata.mediaType
to denote the type of content or the type of folder described by the metadata. - Add
MediaMetadata.isBrowsable
as 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
SimpleBasePlayer
to help implement thePlayer
interface for custom players. - Add helper method to convert platform session token to Media3
SessionToken
( #171 ). - Use
onMediaMetadataChanged
to trigger updates of the platform media session ( #219 ). - Add the media session as an argument of
getMediaButtons()
of theDefaultMediaNotificationProvider
and use immutable lists for clarity ( #216 ). - Add
onSetMediaItems
callback listener to provide means to modify/setMediaItem
list, starting index and position by session before setting onto Player ( #156 ). - Avoid double tap detection for non-Bluetooth media button events ( #233 ).
- Make
QueueTimeline
more robust in case of a shady legacy session state ( #241 ).
- Add abstract
- فراداده:
- Parse multiple null-separated values from ID3 frames, as permitted by ID3 v2.4.
- Add
MediaMetadata.mediaType
to denote the type of content or the type of folder described by the metadata. - Add
MediaMetadata.isBrowsable
as 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
ImaServerSideAdInsertionMediaSource
on the application thread to avoid threading issues. - Add a property
focusSkipButtonWhenAvailable
to theImaServerSideAdInsertionMediaSource.AdsLoader.Builder
to request focusing the skip button on TV devices and set it to true by default. - Add a method
focusSkipButton()
to theImaServerSideAdInsertionMediaSource.AdsLoader
to 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
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.isTunnelingEnabled
to check if tunneling is enabled for the currently selected tracks ( #2518 ). - Add
WrappingMediaSource
to 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
onMediaItemTransition
callback when callingseekToNext
orseekToPrevious
in a single-item playlist ( #10667 ). - Add
Player.getSurfaceSize
that 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
compileSdkVersion
to 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 ).
- دانلودها:
- ویدئو:
- Try alternative decoder for Dolby Vision if display does not support it. ( #9794 ).
- صوتی:
- Use
SingleThreadExecutor
for releasingAudioTrack
instances to avoid OutOfMemory errors when releasing multiple players at the same time ( #10057 ). - Adds
AudioOffloadListener.onExperimentalOffloadedPlayback
for the AudioTrack offload state. ( #134 ). - Make
AudioTrackBufferSizeProvider
a public interface. - Add
ExoPlayer.setPreferredAudioDevice
to set the preferred audio output device ( #135 ). - Rename
androidx.media3.exoplayer.audio.AudioProcessor
toandroidx.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
- فراداده:
-
MetadataRenderer
can 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 opened
error when switching between DRM schemes in a playlist (eg Widevine to ClearKey).
- متن:
- CEA-608: Ensure service switch commands on field 2 are handled correctly ( #10666 ).
- DASH:
- Parse
EventStream.presentationTimeOffset
from 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.Builder
to buildDefaultMediaNotificationProvider
instances. 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 ). -
SimpleBitmapLoader
can load bitmap fromfile://
URIs ( #108 ). - Fix assertion that prevents
MediaController
to seek over an ad in a period ( #122 ). - When playback ends, the
MediaSessionService
is 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
DefaultNotificationProvider
on 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 identifyCastPlayer
when controlling playback with aMediaController
( #142 ).
- Implement
- ترانسفورماتور:
- 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
ShuffleOrder
withExoPlayer.setShuffleOrder
results in a call toPlayer.Listener#onTimelineChanged
withreason=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
setDataSourceFactory
inDefaultMediaSourceFactory
, 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
playWhenReady
changes inLeanbackAdapter
( 10420 ).
- Listen to
- بازیگران:
Version 1.0.0-beta01
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
null
toMediaSource.Factory.setDrmSessionManagerProvider
andMediaSource.Factory.setLoadErrorHandlingPolicy
. Instances ofDefaultDrmSessionManagerProvider
andDefaultLoadErrorHandlingPolicy
can be passed explicitly if required. - Add
MediaItem.RequestMetadata
to represent metadata needed to play media when the exactLocalConfiguration
is not known. Also removeMediaMetadata.mediaUrl
as this is now included inRequestMetadata
. - Add
Player.Command.COMMAND_SET_MEDIA_ITEM
to enable players to allow setting a single item.
- Enable support for Android platform diagnostics via
- Track selection:
- Flatten
TrackSelectionOverrides
class intoTrackSelectionParameters
, and promoteTrackSelectionOverride
to a top level class. - Rename
TracksInfo
toTracks
andTracksInfo.TrackGroupInfo
toTracks.Group
.Player.getCurrentTracksInfo
andPlayer.Listener.onTracksInfoChanged
have also been renamed toPlayer.getCurrentTracks
andPlayer.Listener.onTracksChanged
. This includes 'un-deprecating' thePlayer.Listener.onTracksChanged
method name, but with different parameter types. - Change
DefaultTrackSelector.buildUponParameters
andDefaultTrackSelector.Parameters.buildUpon
to returnDefaultTrackSelector.Parameters.Builder
instead of the deprecatedDefaultTrackSelector.ParametersBuilder
. - Add
DefaultTrackSelector.Parameters.constrainAudioChannelCountToDeviceCapabilities
which is enabled by default. When enabled, theDefaultTrackSelector
will prefer audio tracks whose channel count does not exceed the device output capabilities. On handheld devices, theDefaultTrackSelector
will 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, theDefaultTrackSelector
will monitor for changes in the Spatializer properties and trigger a new track selection upon these. Devices with atelevision
UI mode are excluded from these constraints and the format with the highest channel count will be preferred. To enable this feature, theDefaultTrackSelector
instance must be constructed with aContext
.
- Flatten
- ویدئو:
- Rename
DummySurface
toPlaceholderSurface
. - Add AV1 support to the
MediaCodecVideoRenderer.getCodecMaxInputSize
.
- Rename
- صوتی:
- Use LG AC3 audio decoder advertising non-standard MIME type.
- Change the return type of
AudioAttributes.getAudioAttributesV21()
fromandroid.media.AudioAttributes
to a newAudioAttributesV21
wrapper 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
AudioTrack
with channel maskAudioFormat.CHANNEL_OUT_7POINT1POINT4
if 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 ).
- متن:
- Change
Player.getCurrentCues()
to returnCueGroup
instead ofList<Cue>
. - SSA: Support
OutlineColour
style setting whenBorderStyle == 3
(ieOutlineColour
sets 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
OnClickListener
s set onPlayerView
in the case thatuseController=false
( #9605 ). Also fix delivery of events toOnLongClickListener
for all view configurations. - Fix incorrectly treating a sequence of touch events that exit the bounds of
PlayerView
beforeACTION_UP
as a click ( #9861 ). - Fix
PlayerView
accessibility issue where tapping might toggle playback rather than hiding the controls ( #8627 ). - Rewrite
TrackSelectionView
andTrackSelectionDialogBuilder
to work with thePlayer
interface rather thanExoPlayer
. This allows the views to be used with otherPlayer
implementations, 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
PlayerView
track 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
AudioChannelConfiguration
elements. This re-enables audio passthrough for DTS streams ( #10159 ). - Disallow passing
null
toDashMediaSource.Factory.setCompositeSequenceableLoaderFactory
. Instances ofDefaultCompositeSequenceableLoaderFactory
can 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
null
toHlsMediaSource.Factory.setCompositeSequenceableLoaderFactory
,HlsMediaSource.Factory.setPlaylistParserFactory
, andHlsMediaSource.Factory.setPlaylistTrackerFactory
. Instances ofDefaultCompositeSequenceableLoaderFactory
,DefaultHlsPlaylistParserFactory
, or a reference toDefaultHlsPlaylistTracker.FACTORY
can be passed explicitly if required.
- Smooth Streaming:
- Disallow passing
null
toSsMediaSource.Factory.setCompositeSequenceableLoaderFactory
. Instances ofDefaultCompositeSequenceableLoaderFactory
can 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 ).
- منابع داده:
- Rename
DummyDataSource
toPlaceholderDataSource
. - Workaround OkHttp interrupt handling.
- Rename
- Session:
- Replace
MediaSession.MediaItemFiller
withMediaSession.Callback.onAddMediaItems
to allow asynchronous resolution of requests. - Support
setMediaItems(s)
methods whenMediaController
connects to a legacy media session. - Remove
MediaController.setMediaUri
andMediaSession.Callback.onSetMediaUri
. The same functionality can be achieved by usingMediaController.setMediaItem
andMediaSession.Callback.onAddMediaItems
. - Forward legacy
MediaController
calls to play media toMediaSession.Callback.onAddMediaItems
instead ofonSetMediaUri
. - Add
MediaNotification.Provider
andDefaultMediaNotificationProvider
to provide customization of the notification. - Add
BitmapLoader
andSimpleBitmapLoader
for 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.MediaSessionCallback
toMediaSession.Callback
,MediaLibrarySession.MediaLibrarySessionCallback
toMediaLibrarySession.Callback
andMediaSession.Builder.setSessionCallback
tosetCallback
. - Fix NPE in
MediaControllerImplLegacy
( #59 ). - Update session position info on timeline change( #51 ).
- Fix NPE in
MediaControllerImplBase
after 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.getCurrentTrackGroups
andPlayer.getCurrentTrackSelections
. UsePlayer.getCurrentTracks
instead. You can also continue to useExoPlayer.getCurrentTrackGroups
andExoPlayer.getCurrentTrackSelections
, although these methods remain deprecated. - Remove
DownloadHelper
DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_VIEWPORT
andDEFAULT_TRACK_SELECTOR_PARAMETERS
constants. UsegetDefaultTrackSelectorParameters(Context)
instead when possible, andDEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_CONTEXT
otherwise. - Remove constructor
DefaultTrackSelector(ExoTrackSelection.Factory)
. UseDefaultTrackSelector(Context, ExoTrackSelection.Factory)
instead. - Remove
Transformer.Builder.setContext
. TheContext
should be passed to theTransformer.Builder
constructor instead.
- Remove
Version 1.0.0-alpha03
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 .
- صوتی:
- 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 ).
- متن:
- Fix the interaction of
SingleSampleMediaSource.Factory.setTrackId
andMediaItem.SubtitleConfiguration.Builder.setId
to prioritise theSubtitleConfiguration
field and fall back to theFactory
value 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
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 ofDefaultRenderersFactory
that overridebuildVideoRenderers()
orbuildAudioRenderers()
can access the codec adapter factory and pass it toMediaCodecRenderer
instances they create. - Propagate ICY header fields
name
andgenre
toMediaMetadata.station
andMediaMetadata.genre
respectively so that they reach the app viaPlayer.Listener.onMediaMetadataChanged()
( #9677 ). - Remove null keys from
DefaultHttpDataSource#getResponseHeaders
. - Sleep and retry when creating a
MediaCodec
instance 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#inputBufferCount
toqueuedInputBufferCount
. - Make
SimpleExoPlayer.renderers
private. Renderers can be accessed viaExoPlayer.getRenderer
. - Updated some
AnalyticsListener.EventFlags
constant values to match values inPlayer.EventFlags
. - Split
AnalyticsCollector
into 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
TrackGroup
s in aTrackGroupArray
.TrackGroup
s can always be made distinguishable by setting anid
in theTrackGroup
constructor. This fixes a crash when resuming playback after backgrounding the app with an active track override ( #9718 ). - Amend logic in
AdaptiveTrackSelection
to allow a quality increase under sufficient network bandwidth even if playback is very close to the live edge ( #9784 ).
- ویدئو:
- Fix decoder fallback logic for Dolby Vision to use a compatible H264/H265 decoder if needed.
- صوتی:
- Fix decoder fallback logic for Dolby Atmos (E-AC3-JOC) to use a compatible E-AC3 decoder if needed.
- Change
AudioCapabilities
APIs to require passing explicitlyAudioCapabilities.DEFAULT_AUDIO_CAPABILITIES
instead ofnull
. - Allow customization of the
AudioTrack
buffer size calculation by injecting anAudioTrackBufferSizeProvider
toDefaultAudioSink
. ( #8891 ). - Retry
AudioTrack
creation if the requested buffer size was > 1MB. ( #9712 ).
- Extractors:
- متن:
- Add a
MediaItem.SubtitleConfiguration.id
field which is propagated to theFormat.id
field of the subtitle track created from the configuration ( #9673 ). - Add basic support for WebVTT subtitles in Matroska containers ( #9886 ).
- Prevent
Cea708Decoder
from reading more than the declared size of a service block.
- Add a
- DRM:
- Remove
playbackLooper
fromDrmSessionManager.(pre)acquireSession
. When aDrmSessionManager
is used by an app in a customMediaSource
, theplaybackLooper
needs to be passed toDrmSessionManager.setPlayer
instead.
- Remove
- Ad playback / IMA:
- Add support for IMA Dynamic Ad Insertion (DAI) ( #8213 ).
- Add a method to
AdPlaybackState
to 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-subtitle
track role ( #9727 ). - Stop interpreting the
main
track role asC.SELECTION_FLAG_DEFAULT
. - Fix base URL exclusion logic for manifests that do not declare the DVB namespace ( #9856 ).
- Support relative
MPD.Location
URLs ( #9939 ).
- Add parsed essential and supplemental properties to the
- HLS:
- Correctly populate
Format.label
for 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:
- ترانسفورماتور:
- Increase required min API version to 21.
-
TransformationException
is now used to describe errors that occur during a transformation. - Add
TransformationRequest
for 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.getProgress
when releasing the muxer throws. - Add a demo app for applying transformations.
- MediaSession extension:
- By default,
MediaSessionConnector
now 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.sh
depend 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-framework
are not compatible with apps targeting Android 12, and will crash with anIllegalArgumentException
when creatingPendingIntent
s ( #9528 ).
- Upgrade the Cast extension to depend on
- Remove deprecated symbols:
- Remove
Player.EventListener
. UsePlayer.Listener
instead. - Remove
MediaSourceFactory#setDrmSessionManager
,MediaSourceFactory#setDrmHttpDataSourceFactory
, andMediaSourceFactory#setDrmUserAgent
. UseMediaSourceFactory#setDrmSessionManagerProvider
instead. - Remove
MediaSourceFactory#setStreamKeys
. UseMediaItem.Builder#setStreamKeys
instead. - Remove
MediaSourceFactory#createMediaSource(Uri)
. UseMediaSourceFactory#createMediaSource(MediaItem)
instead. - Remove
setTag
fromDashMediaSource
,HlsMediaSource
andSsMediaSource
. UseMediaItem.Builder#setTag
instead. - Remove
DashMediaSource#setLivePresentationDelayMs(long, boolean)
. UseMediaItem.Builder#setLiveConfiguration
andMediaItem.LiveConfiguration.Builder#setTargetOffsetMs
to override the manifest, orDashMediaSource#setFallbackTargetLiveOffsetMs
to provide a fallback value. - Remove
(Simple)ExoPlayer.setThrowsWhenUsingWrongThread
. Opting out of the thread enforcement is no longer possible. - Remove
ActionFile
andActionFileUpgradeUtil
. Use ExoPlayer 2.16.1 or before to useActionFileUpgradeUtil
to merge legacy action files intoDefaultDownloadIndex
. - Remove
ProgressiveMediaSource#setExtractorsFactory
. UseProgressiveMediaSource.Factory(DataSource.Factory, ExtractorsFactory)
constructor instead. - Remove
ProgressiveMediaSource.Factory#setTag
and, andProgressiveMediaSource.Factory#setCustomCacheKey
. UseMediaItem.Builder#setTag
andMediaItem.Builder#setCustomCacheKey
instead. - Remove
DefaultRenderersFactory(Context, @ExtensionRendererMode int)
andDefaultRenderersFactory(Context, @ExtensionRendererMode int, long)
constructors. Use theDefaultRenderersFactory(Context)
constructor,DefaultRenderersFactory#setExtensionRendererMode
, andDefaultRenderersFactory#setAllowedVideoJoiningTimeMs
instead. - Remove all public
CronetDataSource
constructors. UseCronetDataSource.Factory
instead.
- Remove
- Change the following
IntDefs
to@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.flac
package) -
@FlacExtractor.Flags
(incom.google.android.exoplayer2.extractor.flac
package) -
@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
27 اکتبر 2021
androidx.media3:media3-*:1.0.0-alpha01
is released. Version 1.0.0-alpha01 contains these commits.
ویژگی های جدید
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
Player
interface 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.
Media3
Latest Update | Stable Release | Release Candidate | Beta Release | Alpha Release |
---|---|---|---|---|
10 سپتامبر 2024 | 1.4.1 | - | - | 1.5.0-alpha01 |
Declaring dependencies
To add a dependency on Media3, you must add the Google Maven repository to your project. برای اطلاعات بیشتر ، مخزن Maven Google را بخوانید.
Add the dependencies for the artifacts you need in the build.gradle
file for your app or module:
شیار
dependencies { def media3_version = "1.4.1" // 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 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" // 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" }
کاتلین
dependencies { val media3_version = "1.4.1" // 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 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") // 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 .
بازخورد
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.5
Version 1.5.0-alpha01
10 سپتامبر 2024
This release includes the following changes since the 1.4.1 release :
- Common Library:
- Add
ForwardingSimpleBasePlayer
that allows forwarding to another player with small adjustments while ensuring full consistency and listener handling ( #1183 ). - Replace
SimpleBasePlayer.State.playlist
bygetPlaylist()
method. - Add override for
SimpleBasePlayer.State.Builder.setPlaylist()
to directly specify aTimeline
and currentTracks
andMetadata
instead of building a playlist structure. - Increase
minSdk
to 21 (Android Lollipop). This is aligned with all other AndroidX libraries. - Add
androidx.media3:media3-common-ktx
artifact which provides Kotlin-specific functionality built on top of the Common library - Add
Player.listen
suspending extension function to spin a coroutine to listen toPlayer.Events
to themedia3-common-ktx
library.
- 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.onPreloadError
to allowPreloadMediaSource.PreloadControl
implementations to take actions when error occurs. - Add
BasePreloadManager.Listener
to propagate preload events to apps. - Allow changing SNTP client timeout and retry alternative addresses on timeout ( #1540 ).
- Remove
MediaCodecAdapter.Configuration.flags
as 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.
-
- ترانسفورماتور:
- Add
SurfaceAssetLoader
, which supports queueing video data to Transformer via aSurface
. -
ImageAssetLoader
reports unsupported input viaAssetLoader.onError
instead of throwing anIllegalStateException
.
- Add
- Extractors:
- Allow
Mp4Extractor
andFragmentedMp4Extractor
to 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
HttpEngineDataSource
to allow use starting at version S extension 7 instead of API level 34 ( #1262 ).
- Update
- صوتی:
- Automatically configure CTA-2075 loudness metadata on the codec if present in the media.
- Ensure smooth volume ramp down when seeking.
- ویدئو:
-
MediaCodecVideoRenderer
avoids decoding samples that are neither rendered nor used as reference by other samples. - On API 35 and above,
MediaCodecAdapter
may now receive anull
Surface
inconfigure
and calls to a new methoddetachOutputSurface
to remove a previously setSurface
if the codec supports this (MediaCodecInfo.detachedSurfaceSupported
). - Use
MediaCodecAdapter
supplied pixel aspect ratio values if provided when processingonOutputFormatChanged
( #1371 ).
-
- متن:
- Add a custom
VoiceSpan
and populate it for WebVTT voice spans ( #1632 ).
- Add a custom
- تصویر:
- Add
ExternallyLoadedImageDecoder
for simplified integration with external image loading libraries like Glide or Coil.
- Add
- DataSource:
- Add
FileDescriptorDataSource
, a newDataSource
that can be used to read from aFileDescriptor
( #3757 ).
- Add
- اثر:
- Add
DefaultVideoFrameProcessor
workaround for minorSurfaceTexture
scaling.SurfaceTexture
may 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 withTransformer
is faster.
- Add
- IMA extension:
- Fix bug where clearing the playlist may cause an
ArrayIndexOutOfBoundsException
inImaServerSideAdInsertionMediaSource
.
- 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
DeviceInfo
when aContext
is provided. This enables linking theMediaSession
to aRoutingSession
, which is necessary for integrating Output Switcher ( #1056 ).
- Test Utilities:
-
DataSourceContractTest
now includes tests to verify:- Input stream
read position
is updated. - Output buffer
offset
is 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.onDrmSessionAcquired
method.
- Remove deprecated
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 bytes
error by correctly ignoring trailing non-MP3 data based on the length field in anInfo
frame ( #1480 ).
- MP3: Fix
- متن:
- TTML: Fix handling of percentage
tts:fontSize
values to ensure they are correctly inherited from parent nodes with percentagetts:fontSize
values. - Fix
IndexOutOfBoundsException
inLegacySubtitleUtil
due 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_HANDLE
error on API 31+ devices playing L1 Widevine content. This error is caused by an incomplete implementation of the frameworkMediaDrm.requiresSecureDecoder
method ( #1603 ).
- Fix
- اثر:
- Add a
release()
method toGlObjectsProvider
.
- Add a
- Session:
- Transform a double-tap of
KEYCODE_HEADSETHOOK
into a 'seek to next' action, as documented ( #1493 ). - Handle
KEYCODE_HEADSETHOOK
as a 'play' command inMediaButtonReceiver
when 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
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.customData
to store app-provided custom information aboutFormat
instances.
- Forward presumed no-op seek calls to the protected
- ExoPlayer:
- Add
BasePreloadManager
which coordinates the preloading for multiple sources based on the priorities defined by theirrankingData
. Customization is possible by extending this class. AddDefaultPreloadManager
which usesPreloadMediaSource
to preload media samples of the sources into memory, and uses an integerrankingData
that indicates the index of an item on the UI. - Add
PlayerId
to most methods ofLoadControl
to enableLoadControl
implementations 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. CustomRenderer
implementations should check if the buffer time is at leastBaseRenderer.getLastResetPositionUs()
to decide whether a sample should be shown. CustomSimpleDecoder
implementations can checkisAtLeastOutputStartTimeUs()
if needed or mark other buffers withDecoderOutputBuffer.shouldBeSkipped
to skip them. - Allow a null value to be returned by
TargetPreloadStatusControl.getTargetPreloadStatus(T)
to indicate not to preload aMediaSource
with the givenrankingData
. - Add
remove(MediaSource)
toBasePreloadManager
. - Add
reset()
toBasePreloadManager
to release all the holding sources while keep the preload manager instance. - Add
ExoPlayer.setPriority()
(andBuilder.setPriority()
) to define the priority value used inPriorityTaskManager
and 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 theDefaultPreloadManager
and the customPreloadMediaSource.PreloadControl
implementations 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
clear
toPreloadMediaSource
to discard the preloading period. - Add new error code
PlaybackException.ERROR_CODE_DECODING_RESOURCES_RECLAIMED
that is used when codec resources are reclaimed for higher priority tasks. - Let
AdsMediaSource
load preroll ads before initial content media preparation completes ( #1358 ). - Fix bug where playback moved to
STATE_ENDED
when 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.Stage
accordingly. - 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()
. ARenderer
can implement this method to return to ExoPlayer the duration that playback must advance for the renderer to progress. IfExoPlayer
is set withexperimentalSetDynamicSchedulingEnabled()
thenExoPlayer
will call this method when calculating the time to schedule its work task. - Add
MediaCodecAdapter#OnBufferAvailableListener
to alert when input and output buffers are available for use byMediaCodecRenderer
.MediaCodecRenderer
will signalExoPlayer
when receiving these callbacks and ifExoPlayer
is set withexperimentalSetDynamicSchedulingEnabled()
, thenExoPlayer
will schedule its work loop as renderers can make progress. - Use data class for
LoadControl
methods 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, eg not reporting full or transient focus loss while the player is paused ( #1436 ).
- Fix potential
IndexOutOfBoundsException
caused by extractors reporting additional tracks after the initial preparation step ( #1476 ). -
Effects
inExoPlayer.setVideoEffect()
will receive the timestamps with the renderer offset removed ( #1098 ). - Fix potential
IllegalArgumentException
when handling player error that happened while reading ahead into another playlist item ( #1483 ).
- Add
- ترانسفورماتور:
- Add
audioConversionProcess
andvideoConversionProcess
toExportResult
indicating 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
DefaultAudioMixer
does 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.Muxer
interface withandroidx.media3.muxer.Muxer
and removeandroidx.media3.transformer.Muxer
. - Fix HEIC image loading from content URI schemes. ( #1373 ).
- Adjust audio track duration in
AudioGraphInput
to improve AV sync. - Remove
ExportResult.processedInputs
field. If you use this field for codec details, then useDefaultDecoderFactory.listener
instead. 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
Info
frame over the size reported by the underlying stream (eg file size, or HTTPContent-Length
header). This helps to exclude non-playable trailer data (eg album artwork) from constant bitrate seeking calculations, making seeks more accurate ( #1376 ). - MP3: Use the frame count and other data in an
Info
frame (if present) to compute an average bitrate for constant bitrate seeking, rather than extrapolating from the bitrate of the frame after theInfo
frame, which may be artificially small, egPCUT
frame ( #1376 ). - Fix PCM audio format extraction in AVI containers.
- صوتی:
- Fix DTS:X Profile 2 encoding attributes for passthrough playback ( #1299 ).
- For offloaded playback, reset the tracking field for stream completion in
DefaultAudioSink
prior to callingAudioTrack.stop()
so thatAudioTrack.StreamEventCallback#onPresentationEnded
correctly identifies when all pending data has been played. - Fix bug in
SilenceSkippingAudioProcessor
where 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.
- ویدئو:
- 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
- متن:
- 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 anExoPlayer
instance. These methods (and all support for legacy subtitle decoding) will be removed in a future release. - Apps with custom
SubtitleDecoder
implementations need to update them to implementSubtitleParser
instead (andSubtitleParser.Factory
instead ofSubtitleDecoderFactory
).
- This change can be overridden by calling both
- PGS: Fix run-length decoding to resolve
0
as a color index, instead of a literal color value ( #1367 ). - CEA-708: Ignore
rowLock
value. The CEA-708-E S-2023 spec states thatrowLock
andcolumnLock
should both be assumed to be true, regardless of the values present in the stream (columnLock
support is not implemented, so it's effectively assumed to always be false).- This was originally included in the
1.3.0-alpha01
release notes, but the change was accidentally reverted before the1.3.0-rc01
release. 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
IllegalArgumentException
fromLegacySubtitleUtil
when a WebVTT subtitle sample contains no cues, eg as part of a DASH stream ( #1516 ).
- فراداده:
- 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
,TSOA
andTSOP
ID3 tags ( #1302 ). - Fix reading of MP4 (/iTunes) numeric
gnre
(genre) andtmpo
(tempo) tags when the value is more than one byte long. - Propagate ID3
TCON
frame toMediaMetadata.genre
( #1305 ).
- Fix mapping of MP4 to ID3 sort tags. Previously the 'album sort' (
- تصویر:
- Add support for non-square DASH thumbnail grids ( #1300 ).
- Add support for AVIF for API 34+.
- Allow
null
as parameter forExoPlayer.setImageOutput()
to clear a previously setImageOutput
.
- DataSource:
- Implement support for
android.resource://package/id
raw resource URIs wherepackage
is 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
url
is non-null in theDataSpec
constructors. This parameter was already annotated to be non-null. - Allow
ByteArrayDataSource
to resolve a URI to a byte array duringopen()
, instead of being hard-coded at construction ( #1405 ).
- Implement support for
- DRM:
- Allow setting a
LoadErrorHandlingPolicy
onDefaultDrmSessionManagerProvider
( #1271 ).
- Allow setting a
- اثر:
- Support multiple speed changes within the same
EditedMediaItem
orComposition
inSpeedChangeEffect
. - 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
TimestampWrapper
crashes 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
SeparableConvolution
effects to be used before API 26. - Remove unused
OverlaySettings.useHdr
since 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.AdLoader
that 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
NullPointerException
when usingdata://
ad tag URIs ( #700 ).
- Session:
- Change default of
CommandButton.enabled
totrue
and ensure the value can stay false for controllers even if the associated command is available. - Add icon constants for
CommandButton
that 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
MediaMetadata
toMediaDescriptionCompat
, 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 thePlaybackState
of 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
SessionError
and use it inSessionResult
andLibraryResult
instead 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
PlaybackException
is mapped to a fatal error state of thePlaybackStateCompat
. ASessionError
sent to the media notification controller withMediaSession.sendError(ControllerInfo, SessionError)
is mapped to a non-fatal error inPlaybackStateCompat
which 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
ConnectionResult
withAcceptedResultBuilder.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
PlayerView
when connected to anExoPlayer
( #1144 ). - Add customization of various icons in
PlayerControlView
through xml attributes to allow different drawables perPlayerView
instance, rather than global overrides ( #1200 ). - Work around a platform bug causing stretched/cropped video when using
SurfaceView
inside a ComposeAndroidView
on API 34 ( #1237 ).
- Add image display support to
- دانلودها:
- Ensure that
DownloadHelper
does not leak unreleasedRenderer
instances, which can eventually result in an app crashing withIllegalStateException: Too many receivers, total of 1000, registered for pid
( #1224 ).
- Ensure that
- Cronet Extension:
- Fix
SocketTimeoutException
inCronetDataSource
. 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
HlsSampleStreamWrapper
with an incorrect offset causing anIndexOutOfBoundsException
or 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 Error
andIllegalArgumentException
. - 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
MediaQueueItem
to 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 (eg those reported toAnalyticsListener.onVideoCodecError()
). Use the newTestPlayerRunHelper.run(player).ignoringNonFatalErrors().untilXXX()
method chain to disable this behavior.
- Implement
- Demo app:
- Use
DefaultPreloadManager
in the short form demo app. - Allow setting repeat mode with
Intent
arguments from command line ( #1266 ). - Use
HttpEngineDataSource
as theHttpDataSource
when supported by the device.
- Use
- Remove deprecated symbols:
- Remove
CronetDataSourceFactory
. UseCronetDataSource.Factory
instead. - Remove some
DataSpec
constructors. UseDataSpec.Builder
instead. - Remove
setContentTypePredicate(Predicate)
method fromDefaultHttpDataSource
,OkHttpDataSource
andCronetDataSource
. Use the equivalent method on eachXXXDataSource.Factory
instead. - Remove
OkHttpDataSource
constructors andOkHttpDataSourceFactory
. UseOkHttpDataSource.Factory
instead. - Remove
PlayerMessage.setHandler(Handler)
. UsesetLooper(Looper)
instead. - Remove
Timeline.Window.isLive
field. Use theisLive()
method instead. - Remove
DefaultHttpDataSource
constructors. UseDefaultHttpDataSource.Factory
instead. - Remove
DashMediaSource.DEFAULT_LIVE_PRESENTATION_DELAY_MS
. UseDashMediaSource.DEFAULT_FALLBACK_TARGET_LIVE_OFFSET_MS
instead. - Remove
MediaCodecInfo.isSeamlessAdaptationSupported(Format, Format, boolean)
. UseMediaCodecInfo.canReuseCodec(Format, Format)
instead. - Remove
DrmSessionManager.DUMMY
andgetDummyDrmSessionManager()
method. UseDrmSessionManager.DRM_UNSUPPORTED
instead. - Remove
AnalyticsListener.onAudioInputFormatChanged(EventTime, Format)
,AnalyticsListener.onVideoInputFormatChanged(EventTime, Format)
,AudioRendererEventListener.onAudioInputFormatChanged(Format)
,VideoRendererEventListener.onVideoInputFormatChanged(Format)
. Use the overloads that take aDecoderReuseEvaluation
instead. - Remove
RendererSupport.FormatSupport
IntDef andFORMAT_HANDLED
,FORMAT_EXCEEDS_CAPABILITIES
,FORMAT_UNSUPPORTED_DRM
,FORMAT_UNSUPPORTED_SUBTYPE
,FORMAT_UNSUPPORTED_TYPE
constants. Use the equivalent IntDef and constants inandroidx.media3.common.C
instead (egC.FORMAT_HANDLED
). - Remove
Bundleable
interface. This includes removing allBundleable.Creator<Foo> CREATOR
constant fields. Callers should use theBundle toBundle()
andstatic Foo fromBundle(Bundle)
methods on each type instead.
- Remove
Version 1.4.0-rc01
10 جولای 2024
Use the 1.4.0 stable version .
Version 1.4.0-beta01
26 ژوئن 2024
Use the 1.4.0 stable version .
Version 1.4.0-alpha02
07 ژوئن 2024
Use the 1.4.0 stable version .
Version 1.4.0-alpha01
17 آوریل 2024
Use the 1.4.0 stable version .
Version 1.3.0
Version 1.3.1
11 آوریل 2024
androidx.media3:media3-*:1.3.1
is released. Version 1.3.1 contains these commits .
- Common Library:
- Add
Format.labels
to allow localized or other alternative labels.
- Add
- ExoPlayer:
- Fix issue where
PreloadMediaPeriod
cannot retain the streams when it is preloaded again. - Apply the correct corresponding
TrackSelectionResult
to 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
-keepclasseswithmembers
rule forDefaultVideoFrameProcessor.Factory.Builder.build()
( #1187 ).
- Fix issue where
- ترانسفورماتور:
- Add workaround for exception thrown due to
MediaMuxer
not 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.averageBitrate
from metadata frames such asXING
andVBRI
. - 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 ).
- صوتی:
- Allow renderer recovery by disabling offload if audio track fails to initialize in offload mode.
- ویدئو:
- 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 ).
- متن:
- WebVTT: Prevent directly consecutive cues from creating spurious additional
CuesWithTiming
instances fromWebvttParser.parse
( #1177 ).
- WebVTT: Prevent directly consecutive cues from creating spurious additional
- DRM:
- Work around a
NoSuchMethodError
which can be thrown by theMediaDrm
framework instead ofResourceBusyException
orNotProvisionedException
on some Android 14 devices ( #1145 ).
- Work around a
- اثر:
- Improved PQ to SDR tone-mapping by converting color spaces.
- Session:
- UI:
- Fallback to include audio track language name if
Locale
cannot identify a display name ( #988 ).
- Fallback to include audio track language name if
- DASH Extension:
- Populate all
Label
elements 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
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/]name
raw resource URIs wherepackage
is 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
MediaItem
instead of a singleUri
inAdPlaybackState
. - Increase
minSdk
to 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
artworkUri
andartworkData
inMediaMetadata.Builder.populate(MediaMetadata)
when at least one of them is non-null ( #964 ).
- Implement support for
- ExoPlayer:
- Add
PreloadMediaSource
andPreloadMediaPeriod
that allows apps to preload a content media source at a specific start position before playback.PreloadMediaSource
takes 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.PreloadControl
and set the preloaded source to the player for playback. - Add
ExoPlayer.setImageOutput
that allows apps to setImageRenderer.ImageOutput
. -
DefaultRenderersFactory
now provides anImageRenderer
to the player by default with nullImageOutput
andImageDecoder.Factory.DEFAULT
. - Emit
Player.Listener.onPositionDiscontinuity
event 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
, anHttpDataSource
using 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
experimentalSetSubtitleParserFactory
methods onBundledChunkExtractor.Factory
andDefaultHlsExtractorFactory
tosetSubtitleParserFactory
and disallow passingnull
. Use the newexperimentalParseSubtitlesDuringExtraction(boolean)
methods to control parsing behaviour. - Add support for customising the
SubtitleParser.Factory
used during extraction. This can be achieved withMediaSource.Factory.setSubtitleParserFactory()
. - Add source prefix to all
Format.id
fields 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
- ترانسفورماتور:
- 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.selectImageTrack
to enable image track selection. - Add
TrackSelectionParameters.isPrioritizeImageOverVideoEnabled
to determine whether to select an image track if both an image track and a video track are available. The default value isfalse
which means selecting a video track is prioritized.
- Add
- Extractors:
- Add additional AV1C parsing to MP4 extractor to retrieve
ColorInfo.colorSpace
,ColorInfo.colorTransfer
, andColorInfo.colorRange
values ( #692 ). - MP3: Use constant bitrate (CBR) seeking for files with an
Info
header (the CBR equivalent of theXing
header). Previously we used the seek table from theInfo
header, 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
- صوتی:
- ویدئو:
- Change the
MediaCodecVideoRenderer
constructor that takes aVideoFrameProcessor.Factory
argument and replace it with a constructor that takes aVideoSinkProvider
argument. Apps that want to inject a customVideoFrameProcessor.Factory
can instantiate aCompositingVideoSinkProvider
that uses the customVideoFrameProcessor.Factory
and pass the video sink provider toMediaCodecVideoRenderer
.
- Change the
- متن:
- Fix serialization of bitmap cues to resolve
Tried to marshall a Parcel that contained Binder objects
error when usingDefaultExtractorsFactory.setTextTrackTranscodingEnabled
( #836 ). - CEA-708: Ignore
rowLock
value. The CEA-708-E S-2023 spec states thatrowLock
andcolumnLock
should both be assumed to be true, regardless of the values present in the stream (columnLock
support is not implemented, so it's effectively assumed to always be false).
- Fix serialization of bitmap cues to resolve
- تصویر:
- Add support for DASH thumbnails. Grid images are cropped and individual thumbnails are provided to
ImageOutput
close 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.setPlayClearContentWithoutKey
orDefaultDrmSessionManager.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.RequestMetadata
with just non-null extras is not transmitted between media controllers and sessions. - Add constructor to
MediaLibrarySession.Builder
that only takes aContext
instead of aMediaLibraryService
.
- HLS Extension:
- Reduce
HlsMediaPeriod
to 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
PreloadMediaSource
with the short-form content use case.
- Add a shortform demo module to demo the usage of
Version 1.3.0-rc01
22 فوریه 2024
Use the 1.3.0 stable version .
Version 1.3.0-beta01
7 فوریه 2024
Use the 1.3.0 stable version .
Version 1.3.0-alpha01
15 ژانویه 2024
Use the 1.3.0 stable version .
Version 1.2.0
Version 1.2.1
9 ژانویه 2024
- ExoPlayer:
- Fix issue where manual seeks outside of the
LiveConfiguration.min/maxOffset
range 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.Factory
were receiving negative values forbufferedDurationUs
from chunk sources, resulting in anIllegalArgumentException
( #888 ).
- Fix issue where manual seeks outside of the
- ترانسفورماتور:
- 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_ALTERNATE
to 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
- صوتی:
- Fix handling of EOS for
SilenceSkippingAudioProcessor
when called multiple times ( #712 ).
- Fix handling of EOS for
- ویدئو:
- 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 ).
- فراداده:
- Fix bug where
MediaMetadata
was only populated from Vorbis comments with upper-case keys ( #876 ). - Catch
OutOfMemoryError
when 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.url
license URL to API 33+ (previously the workaround only applied on API 33 exactly) ( #837 ). - Fix
ERROR_DRM_SESSION_NOT_OPENED
when 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
MediaMetadataCompat
toMediaMetadata.extras
andMediaMetadata.extras
toMediaMetadataCompat
( #756 , #802 ). - Fix broadcasting
notifyChildrenChanged
for legacy controllers ( #644 ). - Fix a bug where setting a negative time for a disabled
setWhen
timer of the notification caused a crash on some devices ( #903 ). - Fix
IllegalStateException
when 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
Timeline
to not crash the app when loading media fails on the cast device ( #708 ).
- Sanitize creation of a
Version 1.2.0
15 نوامبر 2023
- Common Library:
- Add a
@Nullable Throwable
parameter to the methods in theLog.Logger
interface. Themessage
parameter to these methods no longer contains any information about theThrowable
passed 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
TrackSelectorResult
andSimpleDecoder
method parameters ( #6792 ). - Change default UI and notification behavior in
Util.shouldShowPlayButton
to show a "play" button while playback is temporarily suppressed (eg 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-experimental
to1.3.1
to fix https://issuetracker.google.com/251172715. - Move
ExoPlayer.setAudioAttributes
to thePlayer
interface.
- 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 (eg 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_OUTPUT
if 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.canUpdateMediaItem
andMediaSource.updateMediaItem
to acceptMediaItem
updates after creation viaPlayer.replaceMediaItem(s)
. - Allow
MediaItem
updates for allMediaSource
classes provided by the library viaPlayer.replaceMediaItem(s)
( #33 , #9978 ). - Rename
MimeTypes.TEXT_EXOPLAYER_CUES
toMimeTypes.APPLICATION_MEDIA3_CUES
. - Add
PngExtractor
that sends and reads a whole PNG file into theTrackOutput
as one sample. - Enhance
SequenceableLoader.continueLoading(long)
method in theSequenceableLoader
interface toSequenceableLoader.continueLoading(LoadingInfo loadingInfo)
.LoadingInfo
contains additional parameters, includingplaybackSpeed
andlastRebufferRealtimeMs
in addition to the existingplaybackPositionUs
. - Enhance
ChunkSource.getNextChunk(long, long, List, ChunkHolder)
method in theChunkSource
interface 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
ConcurrentModificationException
inExperimentalBandwidthMeter
( #612 ). - Add
MediaPeriodId
parameter toCompositeMediaSource.getMediaTimeForChildMediaTime
. - Support
ClippingMediaSource
(and other sources with period/window time offsets) inConcatenatingMediaSource2
( #11226 ). - Change
BaseRenderer.onStreamChanged()
to also receive aMediaPeriodId
argument.
- ترانسفورماتور:
- Parse EXIF rotation data for image inputs.
- Remove
TransformationRequest.HdrMode
annotation type and its associated constants. UseComposition.HdrMode
and its associated constants instead. - Simplify the
OverlaySettings
to fix rotation issues. - Changed
frameRate
anddurationUs
parameters ofSampleConsumer.queueInputBitmap
toTimestampIterator
.
- Track Selection:
- Add
DefaultTrackSelector.Parameters.allowAudioNonSeamlessAdaptiveness
to 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
. ChangedprojectionPosePitch
toprojectionPoseRoll
( #461 ). - Remove the assumption that
Extractor
instances can be directly inspected withinstanceof
. If you want runtime access to the implementation details of anExtractor
you must first callExtractor.getUnderlyingInstance
. - Add
BmpExtractor
. - Add
WebpExtractor
. - Add
HeifExtractor
. - Add QuickTime classic support to
Mp4Extractor
.
- صوتی:
- Add support for 24/32-bit big-endian PCM in MP4 and Matroska, and parse PCM encoding for
lpcm
in 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 newAudioOffloadSupport
that 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
setAudioOffloadPreference
inTrackSelectionParameters
. 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
audioOffloadModePreference
is set toAUDIO_OFFLOAD_MODE_PREFERENCE_REQUIRED
, then theDefaultTrackSelector
will 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
enableOffload
fromDefaultRenderersFactory.buildAudioSink
method 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.experimentalSetOffloadSchedulingEnabled
andAudioOffloadListener.onExperimentalOffloadSchedulingEnabledChanged
. - Renamed
onExperimentalSleepingForOffloadChanged
asonSleepingForOffloadChanged
andonExperimentalOffloadedPlayback
asonOffloadedPlayback
. - Move audio offload mode related
TrackSelectionParameters
interfaces and definitions to an innerAudioOffloadPreferences
class. - Add
onAudioTrackInitialized
andonAudioTrackReleased
callbacks toAnalyticsListener
,AudioRendererEventListener
andAudioSink.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
- ویدئو:
- Allow
MediaCodecVideoRenderer
to use a customVideoFrameProcessor.Factory
. - Fix bug where the first frame couldn't be rendered if the audio stream starts with negative timestamps ( #291 ).
- Allow
- متن:
- Remove
ExoplayerCuesDecoder
. Text tracks withsampleMimeType = application/x-media3-cues
are now directly handled byTextRenderer
without needing aSubtitleDecoder
instance.
- Remove
- فراداده:
-
MetadataDecoder.decode
will no longer be called for "decode-only" samples as the implementation must return null anyway.
-
- اثر:
- Add
VideoFrameProcessor.queueInputBitmap(Bitmap, Iterator<Long>)
queuing bitmap input by timestamp. - Change
VideoFrameProcessor.registerInputStream()
to be non-blocking. Apps must implementVideoFrameProcessor.Listener#onInputStreamRegistered()
. - Changed
frameRate
anddurationUs
parameters ofVideoFrameProcessor.queueInputBitmap
toTimestampIterator
.
- 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_IMMEDIATE
inDefaultMediaNotificationProvider
( #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_TIMELINE
is not available for the media notification controller. With Android Auto as the client controller reading from the framework session, this has the effect that thequeue
button in the UI of Android Auto is not displayed ( #339 ). - Use
DataSourceBitmapLoader
by 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.Listener
implementation for Wear OS devices that handles playback suppression due toPlayer.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUT
by launching a system dialog to allow a user to connect a suitable audio output (eg bluetooth headphones). The listener will auto-resume playback if a suitable device is connected within a configurable timeout (default is 5 minutes).
- Add a
- دانلودها:
- Declare "data sync" foreground service type for
DownloadService
for Android 14 compatibility. When using this service, the app also needs to adddataSync
asforegroundServiceType
in the manifest and add theFOREGROUND_SERVICE_DATA_SYNC
permission ( #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
IndexOutOfBoundsException
when 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.shouldBeSkipped
to directly mark output buffers that don't need to be presented. This is preferred overC.BUFFER_FLAG_DECODE_ONLY
that will be deprecated. - Add
Decoder.setOutputStartTimeUs
andSimpleDecoder.isAtLeastOutputStartTimeUs
to allow decoders to drop decode-only samples before the start time. This should be preferred toBuffer.isDecodeOnly
that 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
ArithmeticException
in Leanback code ( #617 ).
- Fix bug where disabling a surface can cause an
- Test Utilities:
- Make
TestExoPlayerBuilder
andFakeClock
compatible 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 theComposition
toTransformer.start(Composition, String)
instead. - Remove deprecated
DownloadNotificationHelper.buildProgressNotification
method, use a non deprecated method that takes anotMetRequirements
parameter instead.
- Remove
Version 1.2.0-rc01
1 نوامبر 2023
Use the 1.2.0 stable version .
Version 1.2.0-beta01
19 اکتبر 2023
Use the 1.2.0 stable version .
Version 1.2.0-alpha02
29 سپتامبر 2023
Use the 1.2.0 stable version .
Version 1.2.0-alpha01
17 آگوست 2023
Use the 1.2.0 stable version .
Version 1.1.0
Version 1.1.1
16 آگوست 2023
- Common Library:
- Remove accidentally added
multidex
dependency from all modules ( #499 ).
- Remove accidentally added
- ExoPlayer:
- Fix issue in
PlaybackStatsListener
where spuriousPlaybackStats
are 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
- صوتی:
- Fix a bug where
Player.getState()
never transitioned toSTATE_ENDED
when 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.
- ویدئو:
- H.265/HEVC: Fix parsing SPS short and long term reference picture info.
- متن:
- 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.onCustomLayoutChanged
is called. Apps that want to send different custom layouts to different Media3 controller can do this inMediaSession.Callback.onConnect
by using anAcceptedResultBuilder
to make sure the custom layout is available to the controller when connection completes. - Fix cases where
MediaLibraryServiceLegacyStub
sent an error to aResult
that didn't support this which produced anUnsupportedOperationException
( #78 ). - Fix the way
PlayerWrapper
creates aVolumeProviderCompat
by determiningvolumeControlType
through both legacy commands (COMMAND_ADJUST_DEVICE_VOLUME
andCOMMAND_SET_DEVICE_VOLUME
) and new commands (COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS
andCOMMAND_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
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_METADATA
-
COMMAND_SET_PLAYLIST_METADATA
-
COMMAND_SET_DEVICE_VOLUME_WITH_FLAGS
-
COMMAND_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
Builder
forDeviceInfo
and deprecate existing constructor. - Add
DeviceInfo.routingControllerId
to 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.setDeviceVolumeControlEnabled
to have access to:-
getDeviceVolume()
-
isDeviceMuted()
-
setDeviceVolume(int)
andsetDeviceVolume(int, int)
-
increaseDeviceVolume(int)
andincreaseDeviceVolume(int, int)
-
decreaseDeviceVolume(int)
anddecreaseDeviceVolume(int, int)
-
- Add
FilteringMediaSource
that 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.json
file ( #439 ). - Add
ExoPlayer.setVideoEffects()
for usingEffect
during video playback. - Update
SampleQueue
to storesourceId
as along
rather than anint
. This changes the signatures of public methodsSampleQueue.sourceId
andSampleQueue.peekSourceId
. - Add parameters to
LoadControl
methodsshouldStartPlayback
andonTracksSelected
that 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 themediaTimeOffsetUs
can be called instead. Note that even for the deprecated variants, the offset is not anymore added tostartTimeUs
andendTimeUs
of theMediaLoadData
objects that are dispatched by the dispatcher. - Rename
ExoTrackSelection.blacklist
toexcludeTrack
andisBlacklisted
toisTrackExcluded
. - 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
- ترانسفورماتور:
- 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
MediaCodecList
instead of usingfindDecoder/EncoderForFormat
utilities, to expand support. - Remove B-frame configuration in
DefaultEncoderFactory
because it doesn't work on some devices.
- Remove
- Track selection:
- Add
DefaultTrackSelector.Parameters.allowInvalidateSelectionsForRendererCapabilitiesChange
which is disabled by default. When enabled, theDefaultTrackSelector
will trigger a new track selection when the renderer capabilities changed.
- Add
- Extractors:
- صوتی:
- Fix bug where some playbacks fail when tunneling is enabled and
AudioProcessors
are active, eg 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 parametercontext
in the constructor ofDefaultAudioSink
, with which theDefaultAudioSink
will register as the listener to theAudioCapabilitiesReceiver
and update itsaudioCapabilities
property when informed with a capabilities change. - Propagate audio capabilities changes via a new event
onAudioCapabilitiesChanged
inAudioSink.Listener
interface, and a new interfaceRendererCapabilities.Listener
which triggersonRendererCapabilitiesChanged
events. - Add
ChannelMixingAudioProcessor
for applying scaling/mixing to audio channels. - Add new int value
DISCARD_REASON_AUDIO_BYPASS_POSSIBLE
toDecoderDiscardReasons
to 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
- ویدئو:
- Make
MediaCodecVideoRenderer
report aVideoSize
with a width and height of 0 when the renderer is disabled.Player.Listener.onVideoSizeChanged
is called accordingly whenPlayer.getVideoSize()
changes. With this change, ExoPlayer's video size withMediaCodecVideoRenderer
has a width and height of 0 whenPlayer.getCurrentTracks
does 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
DefaultDrmSession
that 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.getControllerForCurrentRequest
to obtain information about the controller that is currently calling aPlayer
method. - Add
androidx.media3.session.MediaButtonReceiver
to enable apps to implement playback resumption with media button events sent by, for example, a Bluetooth headset ( #167 ). - Add default implementation to
MediaSession.Callback.onAddMediaItems
to allow requestedMediaItems
to be passed ontoPlayer
if they haveLocalConfiguration
(eg 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.onAddMediaItems
to allow requestedMediaItems
to be passed ontoPlayer
if they haveLocalConfiguration
(eg 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
shouldShowPlayButton
andhandlePlayPauseButtonAction
to write custom UI elements with a play/pause button.
- Add Util methods
- RTSP Extension:
- DASH Extension:
- Remove the media time offset from
MediaLoadData.startTimeMs
andMediaLoadData.endTimeMs
for 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 theTimestampAdjuster
to initialize. If the initialization doesn't complete before the timeout, aPlaybackException
is 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
DefaultAudioSink
constructors, useDefaultAudioSink.Builder
instead. - Remove
HlsMasterPlaylist
, useHlsMultivariantPlaylist
instead. - Remove
Player.stop(boolean)
. UsePlayer.stop()
andPlayer.clearMediaItems()
(ifreset
istrue
) instead. - Remove two deprecated
SimpleCache
constructors, use a non-deprecated constructor that takes aDatabaseProvider
instead for better performance. - Remove
DefaultBandwidthMeter
constructor, useDefaultBandwidthMeter.Builder
instead. - Remove
DefaultDrmSessionManager
constructors, useDefaultDrmSessionManager.Builder
instead. - Remove two deprecated
HttpDataSource.InvalidResponseCodeException
constructors, 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.forMediaItem
instead. - Remove deprecated
DownloadService
constructor, use a non deprecated constructor that includes the option to provide achannelDescriptionResourceId
parameter. - Remove deprecated String constants for Charsets (
ASCII_NAME
,UTF8_NAME
,ISO88591_NAME
,UTF16_NAME
andUTF16LE_NAME
), use Kotlin Charsets from thekotlin.text
package, thejava.nio.charset.StandardCharsets
or thecom.google.common.base.Charsets
instead. - Remove deprecated
WorkManagerScheduler
constructor, use a non deprecated constructor that includes the option to provide aContext
parameter instead. - Remove the deprecated methods
createVideoSampleFormat
,createAudioSampleFormat
,createContainerFormat
, andcreateSampleFormat
, which were used to instantiate theFormat
class. Instead useFormat.Builder
for creating instances ofFormat
. - Remove the deprecated methods
copyWithMaxInputSize
,copyWithSubsampleOffsetUs
,copyWithLabel
,copyWithManifestFormatInfo
,copyWithGaplessInfo
,copyWithFrameRate
,copyWithDrmInitData
,copyWithMetadata
,copyWithBitrate
andcopyWithVideoSize
, useFormat.buildUpon()
and setter methods instead. - Remove deprecated
ExoPlayer.retry()
, useprepare()
instead. - Remove deprecated zero-arg
DefaultTrackSelector
constructor, useDefaultTrackSelector(Context)
instead. - Remove deprecated
OfflineLicenseHelper
constructor, useOfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)
instead. - Remove deprecated
DownloadManager
constructor, use the constructor that takes anExecutor
instead. - Remove deprecated
Cue
constructors, useCue.Builder
instead. - Remove deprecated
OfflineLicenseHelper
constructor, useOfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)
instead. - Remove four deprecated
AnalyticsListener
methods:-
onDecoderEnabled
, useonAudioEnabled
and/oronVideoEnabled
instead. -
onDecoderInitialized
, useonAudioDecoderInitialized
and/oronVideoDecoderInitialized
instead. -
onDecoderInputFormatChanged
, useonAudioInputFormatChanged
and/oronVideoInputFormatChanged
instead. -
onDecoderDisabled
, useonAudioDisabled
and/oronVideoDisabled
instead.
-
- Remove the deprecated
Player.Listener.onSeekProcessed
andAnalyticsListener.onSeekProcessed
, useonPositionDiscontinuity
withDISCONTINUITY_REASON_SEEK
instead. - Remove
ExoPlayer.setHandleWakeLock(boolean)
, usesetWakeMode(int)
instead. - Remove deprecated
DefaultLoadControl.Builder.createDefaultLoadControl()
, usebuild()
instead. - Remove deprecated
MediaItem.PlaybackProperties
, useMediaItem.LocalConfiguration
instead. Deprecated fieldMediaItem.playbackProperties
is now of typeMediaItem.LocalConfiguration
.
- Remove
Version 1.1.0-rc01
21 ژوئن 2023
Use the 1.1.0 stable version .
Version 1.1.0-beta01
7 ژوئن 2023
Use the 1.1.0 stable version .
Version 1.1.0-alpha01
10 مه 2023
Use the 1.1.0 stable version .
نسخه 1.0.0
Version 1.0.2
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 ifBuffer
contains 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 ).
- متن:
- SSA: Add support for UTF-16 files if they start with a byte order mark ( #319 ).
- Session:
- Fix issue where
MediaController
doesn't update its available commands when connected to a legacyMediaSessionCompat
that updates its actions. - Fix bug that prevented the
MediaLibraryService
from returning null for a call from System UI toCallback.onGetLibraryRoot
withparams.isRecent == true
on API 30 ( #355 ). - Fix memory leak of
MediaSessionService
orMediaLibraryService
( #346 ). - Fix bug where a combined
Timeline
and position update in aMediaSession
may cause aMediaController
to throw anIllegalStateException
.
- Fix issue where
Version 1.0.1
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
MediaSessionCompat
result in an exception inMediaController
( #290 ). - Add missing forwarding of
MediaSession.broadcastCustomCommand
to the legacyMediaControllerCompat.Callback.onSessionEvent
( #293 ). - Fix bug where calling
MediaSession.setPlayer
doesn't update the available commands. - Fix issue that
TrackSelectionOverride
instances sent from aMediaController
are ignored if they reference a group withFormat.metadata
( #296 ). - Fix issue where
Player.COMMAND_GET_CURRENT_MEDIA_ITEM
needs to be available to access metadata via the legacyMediaSessionCompat
. - Fix issue where
MediaSession
instances 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 ).
نسخه 1.0.0
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
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:
- دانلودها:
- Make the maximum difference of the start time of two segments to be merged configurable in
SegmentDownloader
and subclasses ( #248 ).
- Make the maximum difference of the start time of two segments to be merged configurable in
- صوتی:
- ویدئو:
- Map HEVC HDR10 format to
HEVCProfileMain10HDR10
instead 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
- بازیگران:
- Fix transient
STATE_IDLE
when 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)
LOADED
event 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
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.setPlaybackLooper
that sets a pre-existing playback thread for a new ExoPlayer instance. - Allow download manager helpers to be cleared ( #10776 ).
- Add parameter to
BasePlayer.seekTo
to also indicate the command used for seeking. - Use theme when loading drawables on API 21+ ( #220 ).
- Add
ConcatenatingMediaSource2
that allows combining multiple media items into a single window ( #247 ).
- Tweak the renderer's decoder ordering logic to uphold the
- Extractors:
- Throw a
ParserException
instead of aNullPointerException
if 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
- صوتی:
- Use the compressed audio format bitrate to calculate the min buffer size for
AudioTrack
in direct playbacks (passthrough).
- Use the compressed audio format bitrate to calculate the min buffer size for
- متن:
- Fix
TextRenderer
passing an invalid (negative) index toSubtitle.getEventTime
if a subtitle file contains no cues. - SubRip: Add support for UTF-16 files if they start with a byte order mark.
- Fix
- فراداده:
- Parse multiple null-separated values from ID3 frames, as permitted by ID3 v2.4.
- Add
MediaMetadata.mediaType
to denote the type of content or the type of folder described by the metadata. - Add
MediaMetadata.isBrowsable
as 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
SimpleBasePlayer
to help implement thePlayer
interface for custom players. - Add helper method to convert platform session token to Media3
SessionToken
( #171 ). - Use
onMediaMetadataChanged
to trigger updates of the platform media session ( #219 ). - Add the media session as an argument of
getMediaButtons()
of theDefaultMediaNotificationProvider
and use immutable lists for clarity ( #216 ). - Add
onSetMediaItems
callback listener to provide means to modify/setMediaItem
list, starting index and position by session before setting onto Player ( #156 ). - Avoid double tap detection for non-Bluetooth media button events ( #233 ).
- Make
QueueTimeline
more robust in case of a shady legacy session state ( #241 ).
- Add abstract
- فراداده:
- Parse multiple null-separated values from ID3 frames, as permitted by ID3 v2.4.
- Add
MediaMetadata.mediaType
to denote the type of content or the type of folder described by the metadata. - Add
MediaMetadata.isBrowsable
as 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
ImaServerSideAdInsertionMediaSource
on the application thread to avoid threading issues. - Add a property
focusSkipButtonWhenAvailable
to theImaServerSideAdInsertionMediaSource.AdsLoader.Builder
to request focusing the skip button on TV devices and set it to true by default. - Add a method
focusSkipButton()
to theImaServerSideAdInsertionMediaSource.AdsLoader
to 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
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.isTunnelingEnabled
to check if tunneling is enabled for the currently selected tracks ( #2518 ). - Add
WrappingMediaSource
to 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
onMediaItemTransition
callback when callingseekToNext
orseekToPrevious
in a single-item playlist ( #10667 ). - Add
Player.getSurfaceSize
that 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
compileSdkVersion
to 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 ).
- دانلودها:
- ویدئو:
- Try alternative decoder for Dolby Vision if display does not support it. ( #9794 ).
- صوتی:
- Use
SingleThreadExecutor
for releasingAudioTrack
instances to avoid OutOfMemory errors when releasing multiple players at the same time ( #10057 ). - Adds
AudioOffloadListener.onExperimentalOffloadedPlayback
for the AudioTrack offload state. ( #134 ). - Make
AudioTrackBufferSizeProvider
a public interface. - Add
ExoPlayer.setPreferredAudioDevice
to set the preferred audio output device ( #135 ). - Rename
androidx.media3.exoplayer.audio.AudioProcessor
toandroidx.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
- فراداده:
-
MetadataRenderer
can 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 opened
error when switching between DRM schemes in a playlist (eg Widevine to ClearKey).
- متن:
- CEA-608: Ensure service switch commands on field 2 are handled correctly ( #10666 ).
- DASH:
- Parse
EventStream.presentationTimeOffset
from 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.Builder
to buildDefaultMediaNotificationProvider
instances. 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 ). -
SimpleBitmapLoader
can load bitmap fromfile://
URIs ( #108 ). - Fix assertion that prevents
MediaController
to seek over an ad in a period ( #122 ). - When playback ends, the
MediaSessionService
is 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
DefaultNotificationProvider
on 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 identifyCastPlayer
when controlling playback with aMediaController
( #142 ).
- Implement
- ترانسفورماتور:
- 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
ShuffleOrder
withExoPlayer.setShuffleOrder
results in a call toPlayer.Listener#onTimelineChanged
withreason=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
setDataSourceFactory
inDefaultMediaSourceFactory
, 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
playWhenReady
changes inLeanbackAdapter
( 10420 ).
- Listen to
- بازیگران:
Version 1.0.0-beta01
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
null
toMediaSource.Factory.setDrmSessionManagerProvider
andMediaSource.Factory.setLoadErrorHandlingPolicy
. Instances ofDefaultDrmSessionManagerProvider
andDefaultLoadErrorHandlingPolicy
can be passed explicitly if required. - Add
MediaItem.RequestMetadata
to represent metadata needed to play media when the exactLocalConfiguration
is not known. Also removeMediaMetadata.mediaUrl
as this is now included inRequestMetadata
. - Add
Player.Command.COMMAND_SET_MEDIA_ITEM
to enable players to allow setting a single item.
- Enable support for Android platform diagnostics via
- Track selection:
- Flatten
TrackSelectionOverrides
class intoTrackSelectionParameters
, and promoteTrackSelectionOverride
to a top level class. - Rename
TracksInfo
toTracks
andTracksInfo.TrackGroupInfo
toTracks.Group
.Player.getCurrentTracksInfo
andPlayer.Listener.onTracksInfoChanged
have also been renamed toPlayer.getCurrentTracks
andPlayer.Listener.onTracksChanged
. This includes 'un-deprecating' thePlayer.Listener.onTracksChanged
method name, but with different parameter types. - Change
DefaultTrackSelector.buildUponParameters
andDefaultTrackSelector.Parameters.buildUpon
to returnDefaultTrackSelector.Parameters.Builder
instead of the deprecatedDefaultTrackSelector.ParametersBuilder
. - Add
DefaultTrackSelector.Parameters.constrainAudioChannelCountToDeviceCapabilities
which is enabled by default. When enabled, theDefaultTrackSelector
will prefer audio tracks whose channel count does not exceed the device output capabilities. On handheld devices, theDefaultTrackSelector
will 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, theDefaultTrackSelector
will monitor for changes in the Spatializer properties and trigger a new track selection upon these. Devices with atelevision
UI mode are excluded from these constraints and the format with the highest channel count will be preferred. To enable this feature, theDefaultTrackSelector
instance must be constructed with aContext
.
- Flatten
- ویدئو:
- Rename
DummySurface
toPlaceholderSurface
. - Add AV1 support to the
MediaCodecVideoRenderer.getCodecMaxInputSize
.
- Rename
- صوتی:
- Use LG AC3 audio decoder advertising non-standard MIME type.
- Change the return type of
AudioAttributes.getAudioAttributesV21()
fromandroid.media.AudioAttributes
to a newAudioAttributesV21
wrapper 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
AudioTrack
with channel maskAudioFormat.CHANNEL_OUT_7POINT1POINT4
if 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 ).
- متن:
- Change
Player.getCurrentCues()
to returnCueGroup
instead ofList<Cue>
. - SSA: Support
OutlineColour
style setting whenBorderStyle == 3
(ieOutlineColour
sets 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
OnClickListener
s set onPlayerView
in the case thatuseController=false
( #9605 ). Also fix delivery of events toOnLongClickListener
for all view configurations. - Fix incorrectly treating a sequence of touch events that exit the bounds of
PlayerView
beforeACTION_UP
as a click ( #9861 ). - Fix
PlayerView
accessibility issue where tapping might toggle playback rather than hiding the controls ( #8627 ). - Rewrite
TrackSelectionView
andTrackSelectionDialogBuilder
to work with thePlayer
interface rather thanExoPlayer
. This allows the views to be used with otherPlayer
implementations, 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
PlayerView
track 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
AudioChannelConfiguration
elements. This re-enables audio passthrough for DTS streams ( #10159 ). - Disallow passing
null
toDashMediaSource.Factory.setCompositeSequenceableLoaderFactory
. Instances ofDefaultCompositeSequenceableLoaderFactory
can 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
null
toHlsMediaSource.Factory.setCompositeSequenceableLoaderFactory
,HlsMediaSource.Factory.setPlaylistParserFactory
, andHlsMediaSource.Factory.setPlaylistTrackerFactory
. Instances ofDefaultCompositeSequenceableLoaderFactory
,DefaultHlsPlaylistParserFactory
, or a reference toDefaultHlsPlaylistTracker.FACTORY
can be passed explicitly if required.
- Smooth Streaming:
- Disallow passing
null
toSsMediaSource.Factory.setCompositeSequenceableLoaderFactory
. Instances ofDefaultCompositeSequenceableLoaderFactory
can 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 ).
- منابع داده:
- Rename
DummyDataSource
toPlaceholderDataSource
. - Workaround OkHttp interrupt handling.
- Rename
- Session:
- Replace
MediaSession.MediaItemFiller
withMediaSession.Callback.onAddMediaItems
to allow asynchronous resolution of requests. - Support
setMediaItems(s)
methods whenMediaController
connects to a legacy media session. - Remove
MediaController.setMediaUri
andMediaSession.Callback.onSetMediaUri
. The same functionality can be achieved by usingMediaController.setMediaItem
andMediaSession.Callback.onAddMediaItems
. - Forward legacy
MediaController
calls to play media toMediaSession.Callback.onAddMediaItems
instead ofonSetMediaUri
. - Add
MediaNotification.Provider
andDefaultMediaNotificationProvider
to provide customization of the notification. - Add
BitmapLoader
andSimpleBitmapLoader
for 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.MediaSessionCallback
toMediaSession.Callback
,MediaLibrarySession.MediaLibrarySessionCallback
toMediaLibrarySession.Callback
andMediaSession.Builder.setSessionCallback
tosetCallback
. - Fix NPE in
MediaControllerImplLegacy
( #59 ). - Update session position info on timeline change( #51 ).
- Fix NPE in
MediaControllerImplBase
after 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.getCurrentTrackGroups
andPlayer.getCurrentTrackSelections
. UsePlayer.getCurrentTracks
instead. You can also continue to useExoPlayer.getCurrentTrackGroups
andExoPlayer.getCurrentTrackSelections
, although these methods remain deprecated. - Remove
DownloadHelper
DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_VIEWPORT
andDEFAULT_TRACK_SELECTOR_PARAMETERS
constants. UsegetDefaultTrackSelectorParameters(Context)
instead when possible, andDEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_CONTEXT
otherwise. - Remove constructor
DefaultTrackSelector(ExoTrackSelection.Factory)
. UseDefaultTrackSelector(Context, ExoTrackSelection.Factory)
instead. - Remove
Transformer.Builder.setContext
. TheContext
should be passed to theTransformer.Builder
constructor instead.
- Remove
Version 1.0.0-alpha03
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 .
- صوتی:
- 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 ).
- متن:
- Fix the interaction of
SingleSampleMediaSource.Factory.setTrackId
andMediaItem.SubtitleConfiguration.Builder.setId
to prioritise theSubtitleConfiguration
field and fall back to theFactory
value 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
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 ofDefaultRenderersFactory
that overridebuildVideoRenderers()
orbuildAudioRenderers()
can access the codec adapter factory and pass it toMediaCodecRenderer
instances they create. - Propagate ICY header fields
name
andgenre
toMediaMetadata.station
andMediaMetadata.genre
respectively so that they reach the app viaPlayer.Listener.onMediaMetadataChanged()
( #9677 ). - Remove null keys from
DefaultHttpDataSource#getResponseHeaders
. - Sleep and retry when creating a
MediaCodec
instance 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#inputBufferCount
toqueuedInputBufferCount
. - Make
SimpleExoPlayer.renderers
private. Renderers can be accessed viaExoPlayer.getRenderer
. - Updated some
AnalyticsListener.EventFlags
constant values to match values inPlayer.EventFlags
. - Split
AnalyticsCollector
into 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
TrackGroup
s in aTrackGroupArray
.TrackGroup
s can always be made distinguishable by setting anid
in theTrackGroup
constructor. This fixes a crash when resuming playback after backgrounding the app with an active track override ( #9718 ). - Amend logic in
AdaptiveTrackSelection
to allow a quality increase under sufficient network bandwidth even if playback is very close to the live edge ( #9784 ).
- ویدئو:
- Fix decoder fallback logic for Dolby Vision to use a compatible H264/H265 decoder if needed.
- صوتی:
- Fix decoder fallback logic for Dolby Atmos (E-AC3-JOC) to use a compatible E-AC3 decoder if needed.
- Change
AudioCapabilities
APIs to require passing explicitlyAudioCapabilities.DEFAULT_AUDIO_CAPABILITIES
instead ofnull
. - Allow customization of the
AudioTrack
buffer size calculation by injecting anAudioTrackBufferSizeProvider
toDefaultAudioSink
. ( #8891 ). - Retry
AudioTrack
creation if the requested buffer size was > 1MB. ( #9712 ).
- Extractors:
- متن:
- Add a
MediaItem.SubtitleConfiguration.id
field which is propagated to theFormat.id
field of the subtitle track created from the configuration ( #9673 ). - Add basic support for WebVTT subtitles in Matroska containers ( #9886 ).
- Prevent
Cea708Decoder
from reading more than the declared size of a service block.
- Add a
- DRM:
- Remove
playbackLooper
fromDrmSessionManager.(pre)acquireSession
. When aDrmSessionManager
is used by an app in a customMediaSource
, theplaybackLooper
needs to be passed toDrmSessionManager.setPlayer
instead.
- Remove
- Ad playback / IMA:
- Add support for IMA Dynamic Ad Insertion (DAI) ( #8213 ).
- Add a method to
AdPlaybackState
to 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-subtitle
track role ( #9727 ). - Stop interpreting the
main
track role asC.SELECTION_FLAG_DEFAULT
. - Fix base URL exclusion logic for manifests that do not declare the DVB namespace ( #9856 ).
- Support relative
MPD.Location
URLs ( #9939 ).
- Add parsed essential and supplemental properties to the
- HLS:
- Correctly populate
Format.label
for 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:
- ترانسفورماتور:
- Increase required min API version to 21.
-
TransformationException
is now used to describe errors that occur during a transformation. - Add
TransformationRequest
for 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.getProgress
when releasing the muxer throws. - Add a demo app for applying transformations.
- MediaSession extension:
- By default,
MediaSessionConnector
now 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.sh
depend 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-framework
are not compatible with apps targeting Android 12, and will crash with anIllegalArgumentException
when creatingPendingIntent
s ( #9528 ).
- Upgrade the Cast extension to depend on
- Remove deprecated symbols:
- Remove
Player.EventListener
. UsePlayer.Listener
instead. - Remove
MediaSourceFactory#setDrmSessionManager
,MediaSourceFactory#setDrmHttpDataSourceFactory
, andMediaSourceFactory#setDrmUserAgent
. UseMediaSourceFactory#setDrmSessionManagerProvider
instead. - Remove
MediaSourceFactory#setStreamKeys
. UseMediaItem.Builder#setStreamKeys
instead. - Remove
MediaSourceFactory#createMediaSource(Uri)
. UseMediaSourceFactory#createMediaSource(MediaItem)
instead. - Remove
setTag
fromDashMediaSource
,HlsMediaSource
andSsMediaSource
. UseMediaItem.Builder#setTag
instead. - Remove
DashMediaSource#setLivePresentationDelayMs(long, boolean)
. UseMediaItem.Builder#setLiveConfiguration
andMediaItem.LiveConfiguration.Builder#setTargetOffsetMs
to override the manifest, orDashMediaSource#setFallbackTargetLiveOffsetMs
to provide a fallback value. - Remove
(Simple)ExoPlayer.setThrowsWhenUsingWrongThread
. Opting out of the thread enforcement is no longer possible. - Remove
ActionFile
andActionFileUpgradeUtil
. Use ExoPlayer 2.16.1 or before to useActionFileUpgradeUtil
to merge legacy action files intoDefaultDownloadIndex
. - Remove
ProgressiveMediaSource#setExtractorsFactory
. UseProgressiveMediaSource.Factory(DataSource.Factory, ExtractorsFactory)
constructor instead. - Remove
ProgressiveMediaSource.Factory#setTag
and, andProgressiveMediaSource.Factory#setCustomCacheKey
. UseMediaItem.Builder#setTag
andMediaItem.Builder#setCustomCacheKey
instead. - Remove
DefaultRenderersFactory(Context, @ExtensionRendererMode int)
andDefaultRenderersFactory(Context, @ExtensionRendererMode int, long)
constructors. Use theDefaultRenderersFactory(Context)
constructor,DefaultRenderersFactory#setExtensionRendererMode
, andDefaultRenderersFactory#setAllowedVideoJoiningTimeMs
instead. - Remove all public
CronetDataSource
constructors. UseCronetDataSource.Factory
instead.
- Remove
- Change the following
IntDefs
to@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.flac
package) -
@FlacExtractor.Flags
(incom.google.android.exoplayer2.extractor.flac
package) -
@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
27 اکتبر 2021
androidx.media3:media3-*:1.0.0-alpha01
is released. Version 1.0.0-alpha01 contains these commits.
ویژگی های جدید
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
Player
interface 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.
Media3
Latest Update | Stable Release | Release Candidate | Beta Release | Alpha Release |
---|---|---|---|---|
10 سپتامبر 2024 | 1.4.1 | - | - | 1.5.0-alpha01 |
Declaring dependencies
To add a dependency on Media3, you must add the Google Maven repository to your project. برای اطلاعات بیشتر ، مخزن Maven Google را بخوانید.
Add the dependencies for the artifacts you need in the build.gradle
file for your app or module:
شیار
dependencies { def media3_version = "1.4.1" // 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 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" // 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" }
کاتلین
dependencies { val media3_version = "1.4.1" // 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 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") // 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 .
بازخورد
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.5
Version 1.5.0-alpha01
10 سپتامبر 2024
This release includes the following changes since the 1.4.1 release :
- Common Library:
- Add
ForwardingSimpleBasePlayer
that allows forwarding to another player with small adjustments while ensuring full consistency and listener handling ( #1183 ). - Replace
SimpleBasePlayer.State.playlist
bygetPlaylist()
method. - Add override for
SimpleBasePlayer.State.Builder.setPlaylist()
to directly specify aTimeline
and currentTracks
andMetadata
instead of building a playlist structure. - Increase
minSdk
to 21 (Android Lollipop). This is aligned with all other AndroidX libraries. - Add
androidx.media3:media3-common-ktx
artifact which provides Kotlin-specific functionality built on top of the Common library - Add
Player.listen
suspending extension function to spin a coroutine to listen toPlayer.Events
to themedia3-common-ktx
library.
- 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.onPreloadError
to allowPreloadMediaSource.PreloadControl
implementations to take actions when error occurs. - Add
BasePreloadManager.Listener
to propagate preload events to apps. - Allow changing SNTP client timeout and retry alternative addresses on timeout ( #1540 ).
- Remove
MediaCodecAdapter.Configuration.flags
as 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.
-
- ترانسفورماتور:
- Add
SurfaceAssetLoader
, which supports queueing video data to Transformer via aSurface
. -
ImageAssetLoader
reports unsupported input viaAssetLoader.onError
instead of throwing anIllegalStateException
.
- Add
- Extractors:
- Allow
Mp4Extractor
andFragmentedMp4Extractor
to 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
HttpEngineDataSource
to allow use starting at version S extension 7 instead of API level 34 ( #1262 ).
- Update
- صوتی:
- Automatically configure CTA-2075 loudness metadata on the codec if present in the media.
- Ensure smooth volume ramp down when seeking.
- ویدئو:
-
MediaCodecVideoRenderer
avoids decoding samples that are neither rendered nor used as reference by other samples. - On API 35 and above,
MediaCodecAdapter
may now receive anull
Surface
inconfigure
and calls to a new methoddetachOutputSurface
to remove a previously setSurface
if the codec supports this (MediaCodecInfo.detachedSurfaceSupported
). - Use
MediaCodecAdapter
supplied pixel aspect ratio values if provided when processingonOutputFormatChanged
( #1371 ).
-
- متن:
- Add a custom
VoiceSpan
and populate it for WebVTT voice spans ( #1632 ).
- Add a custom
- تصویر:
- Add
ExternallyLoadedImageDecoder
for simplified integration with external image loading libraries like Glide or Coil.
- Add
- DataSource:
- Add
FileDescriptorDataSource
, a newDataSource
that can be used to read from aFileDescriptor
( #3757 ).
- Add
- اثر:
- Add
DefaultVideoFrameProcessor
workaround for minorSurfaceTexture
scaling.SurfaceTexture
may 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 withTransformer
is faster.
- Add
- IMA extension:
- Fix bug where clearing the playlist may cause an
ArrayIndexOutOfBoundsException
inImaServerSideAdInsertionMediaSource
.
- 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
DeviceInfo
when aContext
is provided. This enables linking theMediaSession
to aRoutingSession
, which is necessary for integrating Output Switcher ( #1056 ).
- Test Utilities:
-
DataSourceContractTest
now includes tests to verify:- Input stream
read position
is updated. - Output buffer
offset
is 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.onDrmSessionAcquired
method.
- Remove deprecated
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 bytes
error by correctly ignoring trailing non-MP3 data based on the length field in anInfo
frame ( #1480 ).
- MP3: Fix
- متن:
- TTML: Fix handling of percentage
tts:fontSize
values to ensure they are correctly inherited from parent nodes with percentagetts:fontSize
values. - Fix
IndexOutOfBoundsException
inLegacySubtitleUtil
due 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_HANDLE
error on API 31+ devices playing L1 Widevine content. This error is caused by an incomplete implementation of the frameworkMediaDrm.requiresSecureDecoder
method ( #1603 ).
- Fix
- اثر:
- Add a
release()
method toGlObjectsProvider
.
- Add a
- Session:
- Transform a double-tap of
KEYCODE_HEADSETHOOK
into a 'seek to next' action, as documented ( #1493 ). - Handle
KEYCODE_HEADSETHOOK
as a 'play' command inMediaButtonReceiver
when 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
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.customData
to store app-provided custom information aboutFormat
instances.
- Forward presumed no-op seek calls to the protected
- ExoPlayer:
- Add
BasePreloadManager
which coordinates the preloading for multiple sources based on the priorities defined by theirrankingData
. Customization is possible by extending this class. AddDefaultPreloadManager
which usesPreloadMediaSource
to preload media samples of the sources into memory, and uses an integerrankingData
that indicates the index of an item on the UI. - Add
PlayerId
to most methods ofLoadControl
to enableLoadControl
implementations 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. CustomRenderer
implementations should check if the buffer time is at leastBaseRenderer.getLastResetPositionUs()
to decide whether a sample should be shown. CustomSimpleDecoder
implementations can checkisAtLeastOutputStartTimeUs()
if needed or mark other buffers withDecoderOutputBuffer.shouldBeSkipped
to skip them. - Allow a null value to be returned by
TargetPreloadStatusControl.getTargetPreloadStatus(T)
to indicate not to preload aMediaSource
with the givenrankingData
. - Add
remove(MediaSource)
toBasePreloadManager
. - Add
reset()
toBasePreloadManager
to release all the holding sources while keep the preload manager instance. - Add
ExoPlayer.setPriority()
(andBuilder.setPriority()
) to define the priority value used inPriorityTaskManager
and 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 theDefaultPreloadManager
and the customPreloadMediaSource.PreloadControl
implementations 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
clear
toPreloadMediaSource
to discard the preloading period. - Add new error code
PlaybackException.ERROR_CODE_DECODING_RESOURCES_RECLAIMED
that is used when codec resources are reclaimed for higher priority tasks. - Let
AdsMediaSource
load preroll ads before initial content media preparation completes ( #1358 ). - Fix bug where playback moved to
STATE_ENDED
when 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.Stage
accordingly. - 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()
. ARenderer
can implement this method to return to ExoPlayer the duration that playback must advance for the renderer to progress. IfExoPlayer
is set withexperimentalSetDynamicSchedulingEnabled()
thenExoPlayer
will call this method when calculating the time to schedule its work task. - Add
MediaCodecAdapter#OnBufferAvailableListener
to alert when input and output buffers are available for use byMediaCodecRenderer
.MediaCodecRenderer
will signalExoPlayer
when receiving these callbacks and ifExoPlayer
is set withexperimentalSetDynamicSchedulingEnabled()
, thenExoPlayer
will schedule its work loop as renderers can make progress. - Use data class for
LoadControl
methods 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, eg not reporting full or transient focus loss while the player is paused ( #1436 ).
- Fix potential
IndexOutOfBoundsException
caused by extractors reporting additional tracks after the initial preparation step ( #1476 ). -
Effects
inExoPlayer.setVideoEffect()
will receive the timestamps with the renderer offset removed ( #1098 ). - Fix potential
IllegalArgumentException
when handling player error that happened while reading ahead into another playlist item ( #1483 ).
- Add
- ترانسفورماتور:
- Add
audioConversionProcess
andvideoConversionProcess
toExportResult
indicating 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
DefaultAudioMixer
does 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.Muxer
interface withandroidx.media3.muxer.Muxer
and removeandroidx.media3.transformer.Muxer
. - Fix HEIC image loading from content URI schemes. ( #1373 ).
- Adjust audio track duration in
AudioGraphInput
to improve AV sync. - Remove
ExportResult.processedInputs
field. If you use this field for codec details, then useDefaultDecoderFactory.listener
instead. 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
Info
frame over the size reported by the underlying stream (eg file size, or HTTPContent-Length
header). This helps to exclude non-playable trailer data (eg album artwork) from constant bitrate seeking calculations, making seeks more accurate ( #1376 ). - MP3: Use the frame count and other data in an
Info
frame (if present) to compute an average bitrate for constant bitrate seeking, rather than extrapolating from the bitrate of the frame after theInfo
frame, which may be artificially small, egPCUT
frame ( #1376 ). - Fix PCM audio format extraction in AVI containers.
- صوتی:
- Fix DTS:X Profile 2 encoding attributes for passthrough playback ( #1299 ).
- For offloaded playback, reset the tracking field for stream completion in
DefaultAudioSink
prior to callingAudioTrack.stop()
so thatAudioTrack.StreamEventCallback#onPresentationEnded
correctly identifies when all pending data has been played. - Fix bug in
SilenceSkippingAudioProcessor
where 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.
- ویدئو:
- 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
- متن:
- 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 anExoPlayer
instance. These methods (and all support for legacy subtitle decoding) will be removed in a future release. - Apps with custom
SubtitleDecoder
implementations need to update them to implementSubtitleParser
instead (andSubtitleParser.Factory
instead ofSubtitleDecoderFactory
).
- This change can be overridden by calling both
- PGS: Fix run-length decoding to resolve
0
as a color index, instead of a literal color value ( #1367 ). - CEA-708: Ignore
rowLock
value. The CEA-708-E S-2023 spec states thatrowLock
andcolumnLock
should both be assumed to be true, regardless of the values present in the stream (columnLock
support is not implemented, so it's effectively assumed to always be false).- This was originally included in the
1.3.0-alpha01
release notes, but the change was accidentally reverted before the1.3.0-rc01
release. 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
IllegalArgumentException
fromLegacySubtitleUtil
when a WebVTT subtitle sample contains no cues, eg as part of a DASH stream ( #1516 ).
- فراداده:
- 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
,TSOA
andTSOP
ID3 tags ( #1302 ). - Fix reading of MP4 (/iTunes) numeric
gnre
(genre) andtmpo
(tempo) tags when the value is more than one byte long. - Propagate ID3
TCON
frame toMediaMetadata.genre
( #1305 ).
- Fix mapping of MP4 to ID3 sort tags. Previously the 'album sort' (
- تصویر:
- Add support for non-square DASH thumbnail grids ( #1300 ).
- Add support for AVIF for API 34+.
- Allow
null
as parameter forExoPlayer.setImageOutput()
to clear a previously setImageOutput
.
- DataSource:
- Implement support for
android.resource://package/id
raw resource URIs wherepackage
is 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
url
is non-null in theDataSpec
constructors. This parameter was already annotated to be non-null. - Allow
ByteArrayDataSource
to resolve a URI to a byte array duringopen()
, instead of being hard-coded at construction ( #1405 ).
- Implement support for
- DRM:
- Allow setting a
LoadErrorHandlingPolicy
onDefaultDrmSessionManagerProvider
( #1271 ).
- Allow setting a
- اثر:
- Support multiple speed changes within the same
EditedMediaItem
orComposition
inSpeedChangeEffect
. - 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
TimestampWrapper
crashes 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
SeparableConvolution
effects to be used before API 26. - Remove unused
OverlaySettings.useHdr
since 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.AdLoader
that 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
NullPointerException
when usingdata://
ad tag URIs ( #700 ).
- Session:
- Change default of
CommandButton.enabled
totrue
and ensure the value can stay false for controllers even if the associated command is available. - Add icon constants for
CommandButton
that 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
MediaMetadata
toMediaDescriptionCompat
, 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 thePlaybackState
of 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
SessionError
and use it inSessionResult
andLibraryResult
instead 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
PlaybackException
is mapped to a fatal error state of thePlaybackStateCompat
. ASessionError
sent to the media notification controller withMediaSession.sendError(ControllerInfo, SessionError)
is mapped to a non-fatal error inPlaybackStateCompat
which 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
ConnectionResult
withAcceptedResultBuilder.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
PlayerView
when connected to anExoPlayer
( #1144 ). - Add customization of various icons in
PlayerControlView
through xml attributes to allow different drawables perPlayerView
instance, rather than global overrides ( #1200 ). - Work around a platform bug causing stretched/cropped video when using
SurfaceView
inside a ComposeAndroidView
on API 34 ( #1237 ).
- Add image display support to
- دانلودها:
- Ensure that
DownloadHelper
does not leak unreleasedRenderer
instances, which can eventually result in an app crashing withIllegalStateException: Too many receivers, total of 1000, registered for pid
( #1224 ).
- Ensure that
- Cronet Extension:
- Fix
SocketTimeoutException
inCronetDataSource
. 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
HlsSampleStreamWrapper
with an incorrect offset causing anIndexOutOfBoundsException
or 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 Error
andIllegalArgumentException
. - 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
MediaQueueItem
to 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 (eg those reported toAnalyticsListener.onVideoCodecError()
). Use the newTestPlayerRunHelper.run(player).ignoringNonFatalErrors().untilXXX()
method chain to disable this behavior.
- Implement
- Demo app:
- Use
DefaultPreloadManager
in the short form demo app. - Allow setting repeat mode with
Intent
arguments from command line ( #1266 ). - Use
HttpEngineDataSource
as theHttpDataSource
when supported by the device.
- Use
- Remove deprecated symbols:
- Remove
CronetDataSourceFactory
. UseCronetDataSource.Factory
instead. - Remove some
DataSpec
constructors. UseDataSpec.Builder
instead. - Remove
setContentTypePredicate(Predicate)
method fromDefaultHttpDataSource
,OkHttpDataSource
andCronetDataSource
. Use the equivalent method on eachXXXDataSource.Factory
instead. - Remove
OkHttpDataSource
constructors andOkHttpDataSourceFactory
. UseOkHttpDataSource.Factory
instead. - Remove
PlayerMessage.setHandler(Handler)
. UsesetLooper(Looper)
instead. - Remove
Timeline.Window.isLive
field. Use theisLive()
method instead. - Remove
DefaultHttpDataSource
constructors. UseDefaultHttpDataSource.Factory
instead. - Remove
DashMediaSource.DEFAULT_LIVE_PRESENTATION_DELAY_MS
. UseDashMediaSource.DEFAULT_FALLBACK_TARGET_LIVE_OFFSET_MS
instead. - Remove
MediaCodecInfo.isSeamlessAdaptationSupported(Format, Format, boolean)
. UseMediaCodecInfo.canReuseCodec(Format, Format)
instead. - Remove
DrmSessionManager.DUMMY
andgetDummyDrmSessionManager()
method. UseDrmSessionManager.DRM_UNSUPPORTED
instead. - Remove
AnalyticsListener.onAudioInputFormatChanged(EventTime, Format)
,AnalyticsListener.onVideoInputFormatChanged(EventTime, Format)
,AudioRendererEventListener.onAudioInputFormatChanged(Format)
,VideoRendererEventListener.onVideoInputFormatChanged(Format)
. Use the overloads that take aDecoderReuseEvaluation
instead. - Remove
RendererSupport.FormatSupport
IntDef andFORMAT_HANDLED
,FORMAT_EXCEEDS_CAPABILITIES
,FORMAT_UNSUPPORTED_DRM
,FORMAT_UNSUPPORTED_SUBTYPE
,FORMAT_UNSUPPORTED_TYPE
constants. Use the equivalent IntDef and constants inandroidx.media3.common.C
instead (egC.FORMAT_HANDLED
). - Remove
Bundleable
interface. This includes removing allBundleable.Creator<Foo> CREATOR
constant fields. Callers should use theBundle toBundle()
andstatic Foo fromBundle(Bundle)
methods on each type instead.
- Remove
Version 1.4.0-rc01
10 جولای 2024
Use the 1.4.0 stable version .
Version 1.4.0-beta01
26 ژوئن 2024
Use the 1.4.0 stable version .
Version 1.4.0-alpha02
07 ژوئن 2024
Use the 1.4.0 stable version .
Version 1.4.0-alpha01
17 آوریل 2024
Use the 1.4.0 stable version .
Version 1.3.0
Version 1.3.1
11 آوریل 2024
androidx.media3:media3-*:1.3.1
is released. Version 1.3.1 contains these commits .
- Common Library:
- Add
Format.labels
to allow localized or other alternative labels.
- Add
- ExoPlayer:
- Fix issue where
PreloadMediaPeriod
cannot retain the streams when it is preloaded again. - Apply the correct corresponding
TrackSelectionResult
to 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
-keepclasseswithmembers
rule forDefaultVideoFrameProcessor.Factory.Builder.build()
( #1187 ).
- Fix issue where
- ترانسفورماتور:
- Add workaround for exception thrown due to
MediaMuxer
not 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.averageBitrate
from metadata frames such asXING
andVBRI
. - 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 ).
- صوتی:
- Allow renderer recovery by disabling offload if audio track fails to initialize in offload mode.
- ویدئو:
- 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 ).
- متن:
- WebVTT: Prevent directly consecutive cues from creating spurious additional
CuesWithTiming
instances fromWebvttParser.parse
( #1177 ).
- WebVTT: Prevent directly consecutive cues from creating spurious additional
- DRM:
- Work around a
NoSuchMethodError
which can be thrown by theMediaDrm
framework instead ofResourceBusyException
orNotProvisionedException
on some Android 14 devices ( #1145 ).
- Work around a
- اثر:
- Improved PQ to SDR tone-mapping by converting color spaces.
- Session:
- UI:
- Fallback to include audio track language name if
Locale
cannot identify a display name ( #988 ).
- Fallback to include audio track language name if
- DASH Extension:
- Populate all
Label
elements 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
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/]name
raw resource URIs wherepackage
is 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
MediaItem
instead of a singleUri
inAdPlaybackState
. - Increase
minSdk
to 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
artworkUri
andartworkData
inMediaMetadata.Builder.populate(MediaMetadata)
when at least one of them is non-null ( #964 ).
- Implement support for
- ExoPlayer:
- Add
PreloadMediaSource
andPreloadMediaPeriod
that allows apps to preload a content media source at a specific start position before playback.PreloadMediaSource
takes 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.PreloadControl
and set the preloaded source to the player for playback. - Add
ExoPlayer.setImageOutput
that allows apps to setImageRenderer.ImageOutput
. -
DefaultRenderersFactory
now provides anImageRenderer
to the player by default with nullImageOutput
andImageDecoder.Factory.DEFAULT
. - Emit
Player.Listener.onPositionDiscontinuity
event 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
, anHttpDataSource
using 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
experimentalSetSubtitleParserFactory
methods onBundledChunkExtractor.Factory
andDefaultHlsExtractorFactory
tosetSubtitleParserFactory
and disallow passingnull
. Use the newexperimentalParseSubtitlesDuringExtraction(boolean)
methods to control parsing behaviour. - Add support for customising the
SubtitleParser.Factory
used during extraction. This can be achieved withMediaSource.Factory.setSubtitleParserFactory()
. - Add source prefix to all
Format.id
fields 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
- ترانسفورماتور:
- 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.selectImageTrack
to enable image track selection. - Add
TrackSelectionParameters.isPrioritizeImageOverVideoEnabled
to determine whether to select an image track if both an image track and a video track are available. The default value isfalse
which means selecting a video track is prioritized.
- Add
- Extractors:
- Add additional AV1C parsing to MP4 extractor to retrieve
ColorInfo.colorSpace
,ColorInfo.colorTransfer
, andColorInfo.colorRange
values ( #692 ). - MP3: Use constant bitrate (CBR) seeking for files with an
Info
header (the CBR equivalent of theXing
header). Previously we used the seek table from theInfo
header, 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
- صوتی:
- ویدئو:
- Change the
MediaCodecVideoRenderer
constructor that takes aVideoFrameProcessor.Factory
argument and replace it with a constructor that takes aVideoSinkProvider
argument. Apps that want to inject a customVideoFrameProcessor.Factory
can instantiate aCompositingVideoSinkProvider
that uses the customVideoFrameProcessor.Factory
and pass the video sink provider toMediaCodecVideoRenderer
.
- Change the
- متن:
- Fix serialization of bitmap cues to resolve
Tried to marshall a Parcel that contained Binder objects
error when usingDefaultExtractorsFactory.setTextTrackTranscodingEnabled
( #836 ). - CEA-708: Ignore
rowLock
value. The CEA-708-E S-2023 spec states thatrowLock
andcolumnLock
should both be assumed to be true, regardless of the values present in the stream (columnLock
support is not implemented, so it's effectively assumed to always be false).
- Fix serialization of bitmap cues to resolve
- تصویر:
- Add support for DASH thumbnails. Grid images are cropped and individual thumbnails are provided to
ImageOutput
close 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.setPlayClearContentWithoutKey
orDefaultDrmSessionManager.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.RequestMetadata
with just non-null extras is not transmitted between media controllers and sessions. - Add constructor to
MediaLibrarySession.Builder
that only takes aContext
instead of aMediaLibraryService
.
- HLS Extension:
- Reduce
HlsMediaPeriod
to 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
PreloadMediaSource
with the short-form content use case.
- Add a shortform demo module to demo the usage of
Version 1.3.0-rc01
22 فوریه 2024
Use the 1.3.0 stable version .
Version 1.3.0-beta01
7 فوریه 2024
Use the 1.3.0 stable version .
Version 1.3.0-alpha01
15 ژانویه 2024
Use the 1.3.0 stable version .
Version 1.2.0
Version 1.2.1
9 ژانویه 2024
- ExoPlayer:
- Fix issue where manual seeks outside of the
LiveConfiguration.min/maxOffset
range 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.Factory
were receiving negative values forbufferedDurationUs
from chunk sources, resulting in anIllegalArgumentException
( #888 ).
- Fix issue where manual seeks outside of the
- ترانسفورماتور:
- 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_ALTERNATE
to 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
- صوتی:
- Fix handling of EOS for
SilenceSkippingAudioProcessor
when called multiple times ( #712 ).
- Fix handling of EOS for
- ویدئو:
- 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 ).
- فراداده:
- Fix bug where
MediaMetadata
was only populated from Vorbis comments with upper-case keys ( #876 ). - Catch
OutOfMemoryError
when 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.url
license URL to API 33+ (previously the workaround only applied on API 33 exactly) ( #837 ). - Fix
ERROR_DRM_SESSION_NOT_OPENED
when 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
MediaMetadataCompat
toMediaMetadata.extras
andMediaMetadata.extras
toMediaMetadataCompat
( #756 , #802 ). - Fix broadcasting
notifyChildrenChanged
for legacy controllers ( #644 ). - Fix a bug where setting a negative time for a disabled
setWhen
timer of the notification caused a crash on some devices ( #903 ). - Fix
IllegalStateException
when 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
Timeline
to not crash the app when loading media fails on the cast device ( #708 ).
- Sanitize creation of a
Version 1.2.0
15 نوامبر 2023
- Common Library:
- Add a
@Nullable Throwable
parameter to the methods in theLog.Logger
interface. Themessage
parameter to these methods no longer contains any information about theThrowable
passed 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
TrackSelectorResult
andSimpleDecoder
method parameters ( #6792 ). - Change default UI and notification behavior in
Util.shouldShowPlayButton
to show a "play" button while playback is temporarily suppressed (eg 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-experimental
to1.3.1
to fix https://issuetracker.google.com/251172715. - Move
ExoPlayer.setAudioAttributes
to thePlayer
interface.
- 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 (eg 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_OUTPUT
if 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.canUpdateMediaItem
andMediaSource.updateMediaItem
to acceptMediaItem
updates after creation viaPlayer.replaceMediaItem(s)
. - Allow
MediaItem
updates for allMediaSource
classes provided by the library viaPlayer.replaceMediaItem(s)
( #33 , #9978 ). - Rename
MimeTypes.TEXT_EXOPLAYER_CUES
toMimeTypes.APPLICATION_MEDIA3_CUES
. - Add
PngExtractor
that sends and reads a whole PNG file into theTrackOutput
as one sample. - Enhance
SequenceableLoader.continueLoading(long)
method in theSequenceableLoader
interface toSequenceableLoader.continueLoading(LoadingInfo loadingInfo)
.LoadingInfo
contains additional parameters, includingplaybackSpeed
andlastRebufferRealtimeMs
in addition to the existingplaybackPositionUs
. - Enhance
ChunkSource.getNextChunk(long, long, List, ChunkHolder)
method in theChunkSource
interface 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
ConcurrentModificationException
inExperimentalBandwidthMeter
( #612 ). - Add
MediaPeriodId
parameter toCompositeMediaSource.getMediaTimeForChildMediaTime
. - Support
ClippingMediaSource
(and other sources with period/window time offsets) inConcatenatingMediaSource2
( #11226 ). - Change
BaseRenderer.onStreamChanged()
to also receive aMediaPeriodId
argument.
- ترانسفورماتور:
- Parse EXIF rotation data for image inputs.
- Remove
TransformationRequest.HdrMode
annotation type and its associated constants. UseComposition.HdrMode
and its associated constants instead. - Simplify the
OverlaySettings
to fix rotation issues. - Changed
frameRate
anddurationUs
parameters ofSampleConsumer.queueInputBitmap
toTimestampIterator
.
- Track Selection:
- Add
DefaultTrackSelector.Parameters.allowAudioNonSeamlessAdaptiveness
to 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
. ChangedprojectionPosePitch
toprojectionPoseRoll
( #461 ). - Remove the assumption that
Extractor
instances can be directly inspected withinstanceof
. If you want runtime access to the implementation details of anExtractor
you must first callExtractor.getUnderlyingInstance
. - Add
BmpExtractor
. - Add
WebpExtractor
. - Add
HeifExtractor
. - Add QuickTime classic support to
Mp4Extractor
.
- صوتی:
- Add support for 24/32-bit big-endian PCM in MP4 and Matroska, and parse PCM encoding for
lpcm
in 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 newAudioOffloadSupport
that 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
setAudioOffloadPreference
inTrackSelectionParameters
. 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
audioOffloadModePreference
is set toAUDIO_OFFLOAD_MODE_PREFERENCE_REQUIRED
, then theDefaultTrackSelector
will 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
enableOffload
fromDefaultRenderersFactory.buildAudioSink
method 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.experimentalSetOffloadSchedulingEnabled
andAudioOffloadListener.onExperimentalOffloadSchedulingEnabledChanged
. - Renamed
onExperimentalSleepingForOffloadChanged
asonSleepingForOffloadChanged
andonExperimentalOffloadedPlayback
asonOffloadedPlayback
. - Move audio offload mode related
TrackSelectionParameters
interfaces and definitions to an innerAudioOffloadPreferences
class. - Add
onAudioTrackInitialized
andonAudioTrackReleased
callbacks toAnalyticsListener
,AudioRendererEventListener
andAudioSink.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
- ویدئو:
- Allow
MediaCodecVideoRenderer
to use a customVideoFrameProcessor.Factory
. - Fix bug where the first frame couldn't be rendered if the audio stream starts with negative timestamps ( #291 ).
- Allow
- متن:
- Remove
ExoplayerCuesDecoder
. Text tracks withsampleMimeType = application/x-media3-cues
are now directly handled byTextRenderer
without needing aSubtitleDecoder
instance.
- Remove
- فراداده:
-
MetadataDecoder.decode
will no longer be called for "decode-only" samples as the implementation must return null anyway.
-
- اثر:
- Add
VideoFrameProcessor.queueInputBitmap(Bitmap, Iterator<Long>)
queuing bitmap input by timestamp. - Change
VideoFrameProcessor.registerInputStream()
to be non-blocking. Apps must implementVideoFrameProcessor.Listener#onInputStreamRegistered()
. - Changed
frameRate
anddurationUs
parameters ofVideoFrameProcessor.queueInputBitmap
toTimestampIterator
.
- 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_IMMEDIATE
inDefaultMediaNotificationProvider
( #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_TIMELINE
is not available for the media notification controller. With Android Auto as the client controller reading from the framework session, this has the effect that thequeue
button in the UI of Android Auto is not displayed ( #339 ). - Use
DataSourceBitmapLoader
by 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.Listener
implementation for Wear OS devices that handles playback suppression due toPlayer.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUT
by launching a system dialog to allow a user to connect a suitable audio output (eg bluetooth headphones). The listener will auto-resume playback if a suitable device is connected within a configurable timeout (default is 5 minutes).
- Add a
- دانلودها:
- Declare "data sync" foreground service type for
DownloadService
for Android 14 compatibility. When using this service, the app also needs to adddataSync
asforegroundServiceType
in the manifest and add theFOREGROUND_SERVICE_DATA_SYNC
permission ( #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
IndexOutOfBoundsException
when 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.shouldBeSkipped
to directly mark output buffers that don't need to be presented. This is preferred overC.BUFFER_FLAG_DECODE_ONLY
that will be deprecated. - Add
Decoder.setOutputStartTimeUs
andSimpleDecoder.isAtLeastOutputStartTimeUs
to allow decoders to drop decode-only samples before the start time. This should be preferred toBuffer.isDecodeOnly
that 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
ArithmeticException
in Leanback code ( #617 ).
- Fix bug where disabling a surface can cause an
- Test Utilities:
- Make
TestExoPlayerBuilder
andFakeClock
compatible 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 theComposition
toTransformer.start(Composition, String)
instead. - Remove deprecated
DownloadNotificationHelper.buildProgressNotification
method, use a non deprecated method that takes anotMetRequirements
parameter instead.
- Remove
Version 1.2.0-rc01
1 نوامبر 2023
Use the 1.2.0 stable version .
Version 1.2.0-beta01
19 اکتبر 2023
Use the 1.2.0 stable version .
Version 1.2.0-alpha02
29 سپتامبر 2023
Use the 1.2.0 stable version .
Version 1.2.0-alpha01
17 آگوست 2023
Use the 1.2.0 stable version .
Version 1.1.0
Version 1.1.1
16 آگوست 2023
- Common Library:
- Remove accidentally added
multidex
dependency from all modules ( #499 ).
- Remove accidentally added
- ExoPlayer:
- Fix issue in
PlaybackStatsListener
where spuriousPlaybackStats
are 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
- صوتی:
- Fix a bug where
Player.getState()
never transitioned toSTATE_ENDED
when 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.
- ویدئو:
- H.265/HEVC: Fix parsing SPS short and long term reference picture info.
- متن:
- 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.onCustomLayoutChanged
is called. Apps that want to send different custom layouts to different Media3 controller can do this inMediaSession.Callback.onConnect
by using anAcceptedResultBuilder
to make sure the custom layout is available to the controller when connection completes. - Fix cases where
MediaLibraryServiceLegacyStub
sent an error to aResult
that didn't support this which produced anUnsupportedOperationException
( #78 ). - Fix the way
PlayerWrapper
creates aVolumeProviderCompat
by determiningvolumeControlType
through both legacy commands (COMMAND_ADJUST_DEVICE_VOLUME
andCOMMAND_SET_DEVICE_VOLUME
) and new commands (COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS
andCOMMAND_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
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_METADATA
-
COMMAND_SET_PLAYLIST_METADATA
-
COMMAND_SET_DEVICE_VOLUME_WITH_FLAGS
-
COMMAND_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
Builder
forDeviceInfo
and deprecate existing constructor. - Add
DeviceInfo.routingControllerId
to 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.setDeviceVolumeControlEnabled
to have access to:-
getDeviceVolume()
-
isDeviceMuted()
-
setDeviceVolume(int)
andsetDeviceVolume(int, int)
-
increaseDeviceVolume(int)
andincreaseDeviceVolume(int, int)
-
decreaseDeviceVolume(int)
anddecreaseDeviceVolume(int, int)
-
- Add
FilteringMediaSource
that 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.json
file ( #439 ). - Add
ExoPlayer.setVideoEffects()
for usingEffect
during video playback. - Update
SampleQueue
to storesourceId
as along
rather than anint
. This changes the signatures of public methodsSampleQueue.sourceId
andSampleQueue.peekSourceId
. - Add parameters to
LoadControl
methodsshouldStartPlayback
andonTracksSelected
that 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 themediaTimeOffsetUs
can be called instead. Note that even for the deprecated variants, the offset is not anymore added tostartTimeUs
andendTimeUs
of theMediaLoadData
objects that are dispatched by the dispatcher. - Rename
ExoTrackSelection.blacklist
toexcludeTrack
andisBlacklisted
toisTrackExcluded
. - 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
- ترانسفورماتور:
- 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
MediaCodecList
instead of usingfindDecoder/EncoderForFormat
utilities, to expand support. - Remove B-frame configuration in
DefaultEncoderFactory
because it doesn't work on some devices.
- Remove
- Track selection:
- Add
DefaultTrackSelector.Parameters.allowInvalidateSelectionsForRendererCapabilitiesChange
which is disabled by default. When enabled, theDefaultTrackSelector
will trigger a new track selection when the renderer capabilities changed.
- Add
- Extractors:
- صوتی:
- Fix bug where some playbacks fail when tunneling is enabled and
AudioProcessors
are active, eg 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 parametercontext
in the constructor ofDefaultAudioSink
, with which theDefaultAudioSink
will register as the listener to theAudioCapabilitiesReceiver
and update itsaudioCapabilities
property when informed with a capabilities change. - Propagate audio capabilities changes via a new event
onAudioCapabilitiesChanged
inAudioSink.Listener
interface, and a new interfaceRendererCapabilities.Listener
which triggersonRendererCapabilitiesChanged
events. - Add
ChannelMixingAudioProcessor
for applying scaling/mixing to audio channels. - Add new int value
DISCARD_REASON_AUDIO_BYPASS_POSSIBLE
toDecoderDiscardReasons
to 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
- ویدئو:
- Make
MediaCodecVideoRenderer
report aVideoSize
with a width and height of 0 when the renderer is disabled.Player.Listener.onVideoSizeChanged
is called accordingly whenPlayer.getVideoSize()
changes. With this change, ExoPlayer's video size withMediaCodecVideoRenderer
has a width and height of 0 whenPlayer.getCurrentTracks
does 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
DefaultDrmSession
that 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.getControllerForCurrentRequest
to obtain information about the controller that is currently calling aPlayer
method. - Add
androidx.media3.session.MediaButtonReceiver
to enable apps to implement playback resumption with media button events sent by, for example, a Bluetooth headset ( #167 ). - Add default implementation to
MediaSession.Callback.onAddMediaItems
to allow requestedMediaItems
to be passed ontoPlayer
if they haveLocalConfiguration
(eg 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.onAddMediaItems
to allow requestedMediaItems
to be passed ontoPlayer
if they haveLocalConfiguration
(eg 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
shouldShowPlayButton
andhandlePlayPauseButtonAction
to write custom UI elements with a play/pause button.
- Add Util methods
- RTSP Extension:
- DASH Extension:
- Remove the media time offset from
MediaLoadData.startTimeMs
andMediaLoadData.endTimeMs
for 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 theTimestampAdjuster
to initialize. If the initialization doesn't complete before the timeout, aPlaybackException
is 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
DefaultAudioSink
constructors, useDefaultAudioSink.Builder
instead. - Remove
HlsMasterPlaylist
, useHlsMultivariantPlaylist
instead. - Remove
Player.stop(boolean)
. UsePlayer.stop()
andPlayer.clearMediaItems()
(ifreset
istrue
) instead. - Remove two deprecated
SimpleCache
constructors, use a non-deprecated constructor that takes aDatabaseProvider
instead for better performance. - Remove
DefaultBandwidthMeter
constructor, useDefaultBandwidthMeter.Builder
instead. - Remove
DefaultDrmSessionManager
constructors, useDefaultDrmSessionManager.Builder
instead. - Remove two deprecated
HttpDataSource.InvalidResponseCodeException
constructors, 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.forMediaItem
instead. - Remove deprecated
DownloadService
constructor, use a non deprecated constructor that includes the option to provide achannelDescriptionResourceId
parameter. - Remove deprecated String constants for Charsets (
ASCII_NAME
,UTF8_NAME
,ISO88591_NAME
,UTF16_NAME
andUTF16LE_NAME
), use Kotlin Charsets from thekotlin.text
package, thejava.nio.charset.StandardCharsets
or thecom.google.common.base.Charsets
instead. - Remove deprecated
WorkManagerScheduler
constructor, use a non deprecated constructor that includes the option to provide aContext
parameter instead. - Remove the deprecated methods
createVideoSampleFormat
,createAudioSampleFormat
,createContainerFormat
, andcreateSampleFormat
, which were used to instantiate theFormat
class. Instead useFormat.Builder
for creating instances ofFormat
. - Remove the deprecated methods
copyWithMaxInputSize
,copyWithSubsampleOffsetUs
,copyWithLabel
,copyWithManifestFormatInfo
,copyWithGaplessInfo
,copyWithFrameRate
,copyWithDrmInitData
,copyWithMetadata
,copyWithBitrate
andcopyWithVideoSize
, useFormat.buildUpon()
and setter methods instead. - Remove deprecated
ExoPlayer.retry()
, useprepare()
instead. - Remove deprecated zero-arg
DefaultTrackSelector
constructor, useDefaultTrackSelector(Context)
instead. - Remove deprecated
OfflineLicenseHelper
constructor, useOfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)
instead. - Remove deprecated
DownloadManager
constructor, use the constructor that takes anExecutor
instead. - Remove deprecated
Cue
constructors, useCue.Builder
instead. - Remove deprecated
OfflineLicenseHelper
constructor, useOfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)
instead. - Remove four deprecated
AnalyticsListener
methods:-
onDecoderEnabled
, useonAudioEnabled
and/oronVideoEnabled
instead. -
onDecoderInitialized
, useonAudioDecoderInitialized
and/oronVideoDecoderInitialized
instead. -
onDecoderInputFormatChanged
, useonAudioInputFormatChanged
and/oronVideoInputFormatChanged
instead. -
onDecoderDisabled
, useonAudioDisabled
and/oronVideoDisabled
instead.
-
- Remove the deprecated
Player.Listener.onSeekProcessed
andAnalyticsListener.onSeekProcessed
, useonPositionDiscontinuity
withDISCONTINUITY_REASON_SEEK
instead. - Remove
ExoPlayer.setHandleWakeLock(boolean)
, usesetWakeMode(int)
instead. - Remove deprecated
DefaultLoadControl.Builder.createDefaultLoadControl()
, usebuild()
instead. - Remove deprecated
MediaItem.PlaybackProperties
, useMediaItem.LocalConfiguration
instead. Deprecated fieldMediaItem.playbackProperties
is now of typeMediaItem.LocalConfiguration
.
- Remove
Version 1.1.0-rc01
21 ژوئن 2023
Use the 1.1.0 stable version .
Version 1.1.0-beta01
7 ژوئن 2023
Use the 1.1.0 stable version .
Version 1.1.0-alpha01
10 مه 2023
Use the 1.1.0 stable version .
نسخه 1.0.0
Version 1.0.2
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 ifBuffer
contains 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 ).
- متن:
- SSA: Add support for UTF-16 files if they start with a byte order mark ( #319 ).
- Session:
- Fix issue where
MediaController
doesn't update its available commands when connected to a legacyMediaSessionCompat
that updates its actions. - Fix bug that prevented the
MediaLibraryService
from returning null for a call from System UI toCallback.onGetLibraryRoot
withparams.isRecent == true
on API 30 ( #355 ). - Fix memory leak of
MediaSessionService
orMediaLibraryService
( #346 ). - Fix bug where a combined
Timeline
and position update in aMediaSession
may cause aMediaController
to throw anIllegalStateException
.
- Fix issue where
Version 1.0.1
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
MediaSessionCompat
result in an exception inMediaController
( #290 ). - Add missing forwarding of
MediaSession.broadcastCustomCommand
to the legacyMediaControllerCompat.Callback.onSessionEvent
( #293 ). - Fix bug where calling
MediaSession.setPlayer
doesn't update the available commands. - Fix issue that
TrackSelectionOverride
instances sent from aMediaController
are ignored if they reference a group withFormat.metadata
( #296 ). - Fix issue where
Player.COMMAND_GET_CURRENT_MEDIA_ITEM
needs to be available to access metadata via the legacyMediaSessionCompat
. - Fix issue where
MediaSession
instances 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 ).
نسخه 1.0.0
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
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:
- دانلودها:
- Make the maximum difference of the start time of two segments to be merged configurable in
SegmentDownloader
and subclasses ( #248 ).
- Make the maximum difference of the start time of two segments to be merged configurable in
- صوتی:
- ویدئو:
- Map HEVC HDR10 format to
HEVCProfileMain10HDR10
instead 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
- بازیگران:
- Fix transient
STATE_IDLE
when 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)
LOADED
event 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
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.setPlaybackLooper
that sets a pre-existing playback thread for a new ExoPlayer instance. - Allow download manager helpers to be cleared ( #10776 ).
- Add parameter to
BasePlayer.seekTo
to also indicate the command used for seeking. - Use theme when loading drawables on API 21+ ( #220 ).
- Add
ConcatenatingMediaSource2
that allows combining multiple media items into a single window ( #247 ).
- Tweak the renderer's decoder ordering logic to uphold the
- Extractors:
- Throw a
ParserException
instead of aNullPointerException
if 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
- صوتی:
- Use the compressed audio format bitrate to calculate the min buffer size for
AudioTrack
in direct playbacks (passthrough).
- Use the compressed audio format bitrate to calculate the min buffer size for
- متن:
- Fix
TextRenderer
passing an invalid (negative) index toSubtitle.getEventTime
if a subtitle file contains no cues. - SubRip: Add support for UTF-16 files if they start with a byte order mark.
- Fix
- فراداده:
- Parse multiple null-separated values from ID3 frames, as permitted by ID3 v2.4.
- Add
MediaMetadata.mediaType
to denote the type of content or the type of folder described by the metadata. - Add
MediaMetadata.isBrowsable
as 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
SimpleBasePlayer
to help implement thePlayer
interface for custom players. - Add helper method to convert platform session token to Media3
SessionToken
( #171 ). - Use
onMediaMetadataChanged
to trigger updates of the platform media session ( #219 ). - Add the media session as an argument of
getMediaButtons()
of theDefaultMediaNotificationProvider
and use immutable lists for clarity ( #216 ). - Add
onSetMediaItems
callback listener to provide means to modify/setMediaItem
list, starting index and position by session before setting onto Player ( #156 ). - Avoid double tap detection for non-Bluetooth media button events ( #233 ).
- Make
QueueTimeline
more robust in case of a shady legacy session state ( #241 ).
- Add abstract
- فراداده:
- Parse multiple null-separated values from ID3 frames, as permitted by ID3 v2.4.
- Add
MediaMetadata.mediaType
to denote the type of content or the type of folder described by the metadata. - Add
MediaMetadata.isBrowsable
as 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
ImaServerSideAdInsertionMediaSource
on the application thread to avoid threading issues. - Add a property
focusSkipButtonWhenAvailable
to theImaServerSideAdInsertionMediaSource.AdsLoader.Builder
to request focusing the skip button on TV devices and set it to true by default. - Add a method
focusSkipButton()
to theImaServerSideAdInsertionMediaSource.AdsLoader
to 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
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.isTunnelingEnabled
to check if tunneling is enabled for the currently selected tracks ( #2518 ). - Add
WrappingMediaSource
to 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
onMediaItemTransition
callback when callingseekToNext
orseekToPrevious
in a single-item playlist ( #10667 ). - Add
Player.getSurfaceSize
that 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
compileSdkVersion
to 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 ).
- دانلودها:
- ویدئو:
- Try alternative decoder for Dolby Vision if display does not support it. ( #9794 ).
- صوتی:
- Use
SingleThreadExecutor
for releasingAudioTrack
instances to avoid OutOfMemory errors when releasing multiple players at the same time ( #10057 ). - Adds
AudioOffloadListener.onExperimentalOffloadedPlayback
for the AudioTrack offload state. ( #134 ). - Make
AudioTrackBufferSizeProvider
a public interface. - Add
ExoPlayer.setPreferredAudioDevice
to set the preferred audio output device ( #135 ). - Rename
androidx.media3.exoplayer.audio.AudioProcessor
toandroidx.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
- فراداده:
-
MetadataRenderer
can 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 opened
error when switching between DRM schemes in a playlist (eg Widevine to ClearKey).
- متن:
- CEA-608: Ensure service switch commands on field 2 are handled correctly ( #10666 ).
- DASH:
- Parse
EventStream.presentationTimeOffset
from 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.Builder
to buildDefaultMediaNotificationProvider
instances. 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 ). -
SimpleBitmapLoader
can load bitmap fromfile://
URIs ( #108 ). - Fix assertion that prevents
MediaController
to seek over an ad in a period ( #122 ). - When playback ends, the
MediaSessionService
is 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
DefaultNotificationProvider
on 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 identifyCastPlayer
when controlling playback with aMediaController
( #142 ).
- Implement
- ترانسفورماتور:
- 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
ShuffleOrder
withExoPlayer.setShuffleOrder
results in a call toPlayer.Listener#onTimelineChanged
withreason=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
setDataSourceFactory
inDefaultMediaSourceFactory
, 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
playWhenReady
changes inLeanbackAdapter
( 10420 ).
- Listen to
- بازیگران:
Version 1.0.0-beta01
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
null
toMediaSource.Factory.setDrmSessionManagerProvider
andMediaSource.Factory.setLoadErrorHandlingPolicy
. Instances ofDefaultDrmSessionManagerProvider
andDefaultLoadErrorHandlingPolicy
can be passed explicitly if required. - Add
MediaItem.RequestMetadata
to represent metadata needed to play media when the exactLocalConfiguration
is not known. Also removeMediaMetadata.mediaUrl
as this is now included inRequestMetadata
. - Add
Player.Command.COMMAND_SET_MEDIA_ITEM
to enable players to allow setting a single item.
- Enable support for Android platform diagnostics via
- Track selection:
- Flatten
TrackSelectionOverrides
class intoTrackSelectionParameters
, and promoteTrackSelectionOverride
to a top level class. - Rename
TracksInfo
toTracks
andTracksInfo.TrackGroupInfo
toTracks.Group
.Player.getCurrentTracksInfo
andPlayer.Listener.onTracksInfoChanged
have also been renamed toPlayer.getCurrentTracks
andPlayer.Listener.onTracksChanged
. This includes 'un-deprecating' thePlayer.Listener.onTracksChanged
method name, but with different parameter types. - Change
DefaultTrackSelector.buildUponParameters
andDefaultTrackSelector.Parameters.buildUpon
to returnDefaultTrackSelector.Parameters.Builder
instead of the deprecatedDefaultTrackSelector.ParametersBuilder
. - Add
DefaultTrackSelector.Parameters.constrainAudioChannelCountToDeviceCapabilities
which is enabled by default. When enabled, theDefaultTrackSelector
will prefer audio tracks whose channel count does not exceed the device output capabilities. On handheld devices, theDefaultTrackSelector
will 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, theDefaultTrackSelector
will monitor for changes in the Spatializer properties and trigger a new track selection upon these. Devices with atelevision
UI mode are excluded from these constraints and the format with the highest channel count will be preferred. To enable this feature, theDefaultTrackSelector
instance must be constructed with aContext
.
- Flatten
- ویدئو:
- Rename
DummySurface
toPlaceholderSurface
. - Add AV1 support to the
MediaCodecVideoRenderer.getCodecMaxInputSize
.
- Rename
- صوتی:
- Use LG AC3 audio decoder advertising non-standard MIME type.
- Change the return type of
AudioAttributes.getAudioAttributesV21()
fromandroid.media.AudioAttributes
to a newAudioAttributesV21
wrapper 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
AudioTrack
with channel maskAudioFormat.CHANNEL_OUT_7POINT1POINT4
if 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 ).
- متن:
- Change
Player.getCurrentCues()
to returnCueGroup
instead ofList<Cue>
. - SSA: Support
OutlineColour
style setting whenBorderStyle == 3
(ieOutlineColour
sets 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
OnClickListener
s set onPlayerView
in the case thatuseController=false
( #9605 ). Also fix delivery of events toOnLongClickListener
for all view configurations. - Fix incorrectly treating a sequence of touch events that exit the bounds of
PlayerView
beforeACTION_UP
as a click ( #9861 ). - Fix
PlayerView
accessibility issue where tapping might toggle playback rather than hiding the controls ( #8627 ). - Rewrite
TrackSelectionView
andTrackSelectionDialogBuilder
to work with thePlayer
interface rather thanExoPlayer
. This allows the views to be used with otherPlayer
implementations, 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
PlayerView
track 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
AudioChannelConfiguration
elements. This re-enables audio passthrough for DTS streams ( #10159 ). - Disallow passing
null
toDashMediaSource.Factory.setCompositeSequenceableLoaderFactory
. Instances ofDefaultCompositeSequenceableLoaderFactory
can 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
null
toHlsMediaSource.Factory.setCompositeSequenceableLoaderFactory
,HlsMediaSource.Factory.setPlaylistParserFactory
, andHlsMediaSource.Factory.setPlaylistTrackerFactory
. Instances ofDefaultCompositeSequenceableLoaderFactory
,DefaultHlsPlaylistParserFactory
, or a reference toDefaultHlsPlaylistTracker.FACTORY
can be passed explicitly if required.
- Smooth Streaming:
- Disallow passing
null
toSsMediaSource.Factory.setCompositeSequenceableLoaderFactory
. Instances ofDefaultCompositeSequenceableLoaderFactory
can 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 ).
- منابع داده:
- Rename
DummyDataSource
toPlaceholderDataSource
. - Workaround OkHttp interrupt handling.
- Rename
- Session:
- Replace
MediaSession.MediaItemFiller
withMediaSession.Callback.onAddMediaItems
to allow asynchronous resolution of requests. - Support
setMediaItems(s)
methods whenMediaController
connects to a legacy media session. - Remove
MediaController.setMediaUri
andMediaSession.Callback.onSetMediaUri
. The same functionality can be achieved by usingMediaController.setMediaItem
andMediaSession.Callback.onAddMediaItems
. - Forward legacy
MediaController
calls to play media toMediaSession.Callback.onAddMediaItems
instead ofonSetMediaUri
. - Add
MediaNotification.Provider
andDefaultMediaNotificationProvider
to provide customization of the notification. - Add
BitmapLoader
andSimpleBitmapLoader
for 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.MediaSessionCallback
toMediaSession.Callback
,MediaLibrarySession.MediaLibrarySessionCallback
toMediaLibrarySession.Callback
andMediaSession.Builder.setSessionCallback
tosetCallback
. - Fix NPE in
MediaControllerImplLegacy
( #59 ). - Update session position info on timeline change( #51 ).
- Fix NPE in
MediaControllerImplBase
after 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.getCurrentTrackGroups
andPlayer.getCurrentTrackSelections
. UsePlayer.getCurrentTracks
instead. You can also continue to useExoPlayer.getCurrentTrackGroups
andExoPlayer.getCurrentTrackSelections
, although these methods remain deprecated. - Remove
DownloadHelper
DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_VIEWPORT
andDEFAULT_TRACK_SELECTOR_PARAMETERS
constants. UsegetDefaultTrackSelectorParameters(Context)
instead when possible, andDEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_CONTEXT
otherwise. - Remove constructor
DefaultTrackSelector(ExoTrackSelection.Factory)
. UseDefaultTrackSelector(Context, ExoTrackSelection.Factory)
instead. - Remove
Transformer.Builder.setContext
. TheContext
should be passed to theTransformer.Builder
constructor instead.
- Remove
Version 1.0.0-alpha03
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 .
- صوتی:
- 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 ).
- متن:
- Fix the interaction of
SingleSampleMediaSource.Factory.setTrackId
andMediaItem.SubtitleConfiguration.Builder.setId
to prioritise theSubtitleConfiguration
field and fall back to theFactory
value 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
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 ofDefaultRenderersFactory
that overridebuildVideoRenderers()
orbuildAudioRenderers()
can access the codec adapter factory and pass it toMediaCodecRenderer
instances they create. - Propagate ICY header fields
name
andgenre
toMediaMetadata.station
andMediaMetadata.genre
respectively so that they reach the app viaPlayer.Listener.onMediaMetadataChanged()
( #9677 ). - Remove null keys from
DefaultHttpDataSource#getResponseHeaders
. - Sleep and retry when creating a
MediaCodec
instance 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#inputBufferCount
toqueuedInputBufferCount
. - Make
SimpleExoPlayer.renderers
private. Renderers can be accessed viaExoPlayer.getRenderer
. - Updated some
AnalyticsListener.EventFlags
constant values to match values inPlayer.EventFlags
. - Split
AnalyticsCollector
into 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
TrackGroup
s in aTrackGroupArray
.TrackGroup
s can always be made distinguishable by setting anid
in theTrackGroup
constructor. This fixes a crash when resuming playback after backgrounding the app with an active track override ( #9718 ). - Amend logic in
AdaptiveTrackSelection
to allow a quality increase under sufficient network bandwidth even if playback is very close to the live edge ( #9784 ).
- ویدئو:
- Fix decoder fallback logic for Dolby Vision to use a compatible H264/H265 decoder if needed.
- صوتی:
- Fix decoder fallback logic for Dolby Atmos (E-AC3-JOC) to use a compatible E-AC3 decoder if needed.
- Change
AudioCapabilities
APIs to require passing explicitlyAudioCapabilities.DEFAULT_AUDIO_CAPABILITIES
instead ofnull
. - Allow customization of the
AudioTrack
buffer size calculation by injecting anAudioTrackBufferSizeProvider
toDefaultAudioSink
. ( #8891 ). - Retry
AudioTrack
creation if the requested buffer size was > 1MB. ( #9712 ).
- Extractors:
- متن:
- Add a
MediaItem.SubtitleConfiguration.id
field which is propagated to theFormat.id
field of the subtitle track created from the configuration ( #9673 ). - Add basic support for WebVTT subtitles in Matroska containers ( #9886 ).
- Prevent
Cea708Decoder
from reading more than the declared size of a service block.
- Add a
- DRM:
- Remove
playbackLooper
fromDrmSessionManager.(pre)acquireSession
. When aDrmSessionManager
is used by an app in a customMediaSource
, theplaybackLooper
needs to be passed toDrmSessionManager.setPlayer
instead.
- Remove
- Ad playback / IMA:
- Add support for IMA Dynamic Ad Insertion (DAI) ( #8213 ).
- Add a method to
AdPlaybackState
to 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-subtitle
track role ( #9727 ). - Stop interpreting the
main
track role asC.SELECTION_FLAG_DEFAULT
. - Fix base URL exclusion logic for manifests that do not declare the DVB namespace ( #9856 ).
- Support relative
MPD.Location
URLs ( #9939 ).
- Add parsed essential and supplemental properties to the
- HLS:
- Correctly populate
Format.label
for 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:
- ترانسفورماتور:
- Increase required min API version to 21.
-
TransformationException
is now used to describe errors that occur during a transformation. - Add
TransformationRequest
for 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.getProgress
when releasing the muxer throws. - Add a demo app for applying transformations.
- MediaSession extension:
- By default,
MediaSessionConnector
now 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.sh
depend 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-framework
are not compatible with apps targeting Android 12, and will crash with anIllegalArgumentException
when creatingPendingIntent
s ( #9528 ).
- Upgrade the Cast extension to depend on
- Remove deprecated symbols:
- Remove
Player.EventListener
. UsePlayer.Listener
instead. - Remove
MediaSourceFactory#setDrmSessionManager
,MediaSourceFactory#setDrmHttpDataSourceFactory
, andMediaSourceFactory#setDrmUserAgent
. UseMediaSourceFactory#setDrmSessionManagerProvider
instead. - Remove
MediaSourceFactory#setStreamKeys
. UseMediaItem.Builder#setStreamKeys
instead. - Remove
MediaSourceFactory#createMediaSource(Uri)
. UseMediaSourceFactory#createMediaSource(MediaItem)
instead. - Remove
setTag
fromDashMediaSource
,HlsMediaSource
andSsMediaSource
. UseMediaItem.Builder#setTag
instead. - Remove
DashMediaSource#setLivePresentationDelayMs(long, boolean)
. UseMediaItem.Builder#setLiveConfiguration
andMediaItem.LiveConfiguration.Builder#setTargetOffsetMs
to override the manifest, orDashMediaSource#setFallbackTargetLiveOffsetMs
to provide a fallback value. - Remove
(Simple)ExoPlayer.setThrowsWhenUsingWrongThread
. Opting out of the thread enforcement is no longer possible. - Remove
ActionFile
andActionFileUpgradeUtil
. Use ExoPlayer 2.16.1 or before to useActionFileUpgradeUtil
to merge legacy action files intoDefaultDownloadIndex
. - Remove
ProgressiveMediaSource#setExtractorsFactory
. UseProgressiveMediaSource.Factory(DataSource.Factory, ExtractorsFactory)
constructor instead. - Remove
ProgressiveMediaSource.Factory#setTag
and, andProgressiveMediaSource.Factory#setCustomCacheKey
. UseMediaItem.Builder#setTag
andMediaItem.Builder#setCustomCacheKey
instead. - Remove
DefaultRenderersFactory(Context, @ExtensionRendererMode int)
andDefaultRenderersFactory(Context, @ExtensionRendererMode int, long)
constructors. Use theDefaultRenderersFactory(Context)
constructor,DefaultRenderersFactory#setExtensionRendererMode
, andDefaultRenderersFactory#setAllowedVideoJoiningTimeMs
instead. - Remove all public
CronetDataSource
constructors. UseCronetDataSource.Factory
instead.
- Remove
- Change the following
IntDefs
to@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.flac
package) -
@FlacExtractor.Flags
(incom.google.android.exoplayer2.extractor.flac
package) -
@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
27 اکتبر 2021
androidx.media3:media3-*:1.0.0-alpha01
is released. Version 1.0.0-alpha01 contains these commits.
ویژگی های جدید
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
Player
interface 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.