رسانه 3

از کتابخانه ها برای موارد استفاده از رسانه پشتیبانی کنید.
آخرین به روز رسانی انتشار پایدار کاندید را آزاد کنید نسخه بتا انتشار آلفا
13 نوامبر 2024 1.4.1 1.5.0-rc01 - -

اعلام وابستگی ها

برای افزودن یک وابستگی به 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-rc02 (19-11-2024)

androidx.media3:media3-*:1.5.0-rc02 منتشر شد.

نسخه 1.5.0-rc02 حاوی این commit ها است.

این نسخه شامل تغییرات زیر از نسخه 1.5.0-rc01 است:

  • استخراج کننده ها:
    • پشتیبانی از فرمت فایل رسانه پایه ISO AC-4 Level-4 ( #1265 ) را اضافه کنید.
  • متن:
    • زیرنویس‌های آشفته CEA-608 را در محتوایی که بیش از یک پیام SEI در هر نمونه دارند، رفع کنید.
    • هنگامی که زیرنویس‌های CEA-608 فعال هستند، تعلیق پخش در جریان‌های چند دوره‌ای DASH را برطرف کنید ( #1863 ).
    • زیرنویس‌های آشفته CEA-608 را در فایل‌های MP4 که به اشتباه هر نمونه را به‌عنوان نمونه همگام‌سازی علامت‌گذاری می‌کنند، برطرف کنید ( #1863 ).
  • برنامه نمایشی
    • نشت حافظه را در برنامه فرم کوتاه نمایشی ( #1839 ) حل کنید.

1.5.0-rc01 (13-11-2024)

androidx.media3:media3-*:1.5.0-rc01 منتشر شد.

نسخه 1.5.0-rc01 حاوی این commit ها است.

این نسخه شامل تغییرات زیر از نسخه 1.5.0-beta01 است:

  • ExoPlayer:
    • رفع اشکال که آیتم‌های فهرست پخش یا دوره‌های جریان‌های چند دوره‌ای DASH با مدت‌زمان‌هایی که با محتوای واقعی مطابقت ندارند، می‌توانند باعث توقف فریم در انتهای مورد شوند ( #1698 ).
    • یک تنظیم کننده به SntpClient اضافه کنید تا حداکثر زمان سپری شده از آخرین به روز رسانی که پس از آن کلاینت مجدداً مقداردهی می شود تنظیم شود ( #1794 ).
  • استخراج کننده ها:
    • تجزیه مدت زمان رسانه را در جعبه mdhd فایل های MP4 برای رسیدگی به مقادیر -1 ( #1819 ) برطرف کنید.
    • پشتیبانی برای شناسایی جعبه h263 در فایل های MP4 برای ویدیوی H.263 ( #1821 ) اضافه کنید.
  • منبع داده:
    • DataSourceContractTest : ادعا کنید که DataSource.getUri() URI حل شده را برمی گرداند (طبق مستند). در مواردی که این با URI درخواستی متفاوت است، آزمایش‌ها می‌توانند با استفاده از روش جدید DataSourceContractTest.TestResource.Builder.setResolvedUri() این را نشان دهند.
    • DataSourceContractTest : ادعا کنید که DataSource.getUri() و getResponseHeaders() مقدار باز خود را پس از یک فراخوان ناموفق به open() (به دلیل منبع «یافت نشد») و قبل از فراخوانی close() بعدی برمی گردانند.
      • نادیده گرفتن DataSourceContractTest.getNotFoundResources() به کلاس های فرعی آزمایشی اجازه می دهد چندین منبع «یافت نشد» را ارائه کنند و همچنین سرصفحه های مورد انتظار را نیز ارائه دهند. این اجازه می دهد تا بین HTTP 404 (با سرصفحه) و "سرور پیدا نشد" (بدون هدر) تمایز قائل شوید.
  • متن:
    • زیرنویس‌های CEA-608 در جریان‌های H.264 MPEG-TS را برطرف کنید که خروجی ندارند (این در 1.5.0-alpha01 توسط https://github.com/androidx/media/commit/03a205f220ecf7681f85f8a752227e37ff86 شکسته شد).
    • از زیرنویس‌های CEA-608 در محتوای Dolby Vision ( #1820 ) پشتیبانی کنید.
  • پسوند RTSP:
    • رفع خرابی هنگام تجزیه بسته های RTP با پسوند هدر ( #1225 ).

نسخه 1.5.0-beta01

30 اکتبر 2024

androidx.media3:media3-*:1.5.0-beta01 منتشر شد. نسخه 1.5.0-beta01 حاوی این تعهدات است.

  • کتابخانه مشترک:
    • حاشیه‌نویسی‌های @DoNotInline را از کلاس‌های داخلی خارج از خط دستی که برای جلوگیری از خرابی تأیید کلاس در زمان اجرا طراحی شده‌اند، حذف کنید. نسخه‌های اخیر R8 اکنون به‌طور خودکار خارج از خط مانند اینها تماس می‌گیرد تا از خرابی‌های زمان اجرا جلوگیری شود (بنابراین دیگر نیازی به خارج کردن خط دستی نیست). همه کاربران Gradle کتابخانه باید قبلاً یک نسخه استفاده کننده از پلاگین Gradle Android باشند که از نسخه R8 استفاده می کند که این کار را انجام می دهد، به دلیل compileSdk = 35 . کاربران کتابخانه با سیستم‌های ساخت غیر Gradle باید اطمینان حاصل کنند که مرحله کوچک کردن/مبهم‌سازی معادل R8 آن‌ها یک فرآیند خودکار خارج از خط را انجام می‌دهد تا از خرابی تأیید کلاس در زمان اجرا جلوگیری کنند. این تغییر قبلاً در سایر کتابخانه های AndroidX انجام شده است .
  • ExoPlayer:
    • وقتی MediaCodec در حالت ناهمزمان کار می‌کند (رفتار پیش‌فرض در API 31+) گاهی اوقات MediaCodec.CryptoException به‌عنوان یک «خطای زمان اجرا غیرمنتظره» گزارش می‌شود.
    • با PreloadMediaSource.PreloadControl.onContinueLoadingRequested() به جای bufferedPositionUs bufferedDurationUs ارسال کنید. همچنین DefaultPreloadManager.Status.STAGE_LOADED_TO_POSITION_MS به DefaultPreloadManager.Status.STAGE_LOADED_FOR_DURATION_MS تغییر می‌دهد، سپس برنامه‌ها باید مقداری را ارسال کنند که نشان‌دهنده مدت زمان مشخصی از موقعیت شروع پیش‌فرض است که منبع رسانه مربوطه باید به‌جای یک موقعیت از پیش بارگذاری شود.
    • پیاده سازی ForwardingRenderer اضافه کنید که همه فراخوانی های متد را به رندر دیگری هدایت می کند ( 1703 ).
    • اضافه کردن پیش بارگذاری لیست پخش برای مورد بعدی در لیست پخش. برنامه‌ها می‌توانند با فراخوانی ExoPlayer.setPreloadConfiguration(PreloadConfiguration) پیش‌بارگیری را فعال کنند. به طور پیش فرض بارگیری از قبل غیرفعال است. هنگام انتخاب و عدم تداخل در پخش، DefaultLoadControl بارگذاری اولیه را محدود می کند تا فقط زمانی که پخش کننده برای پخش بارگیری نمی شود شروع شود و ادامه یابد. برنامه‌ها می‌توانند با اجرای LoadControl.shouldContinuePreloading() بر این اساس این رفتار را تغییر دهند (مانند زمانی که این روش را در DefaultLoadControl نادیده می‌گیریم). اجرای پیش‌فرض LoadControl در صورتی که برنامه‌ای از پیاده‌سازی سفارشی LoadControl استفاده می‌کند، بارگذاری پیش‌بار را غیرفعال می‌کند.
    • روش MediaSourceEventListener.EventDispatcher.dispatchEvent() را اضافه کنید تا امکان فراخوانی رویدادهای شنوندگان زیر کلاس ( 1736 ) فراهم شود.
    • DefaultPreloadManager.Builder را اضافه کنید که نمونه های DefaultPreloadManager و ExoPlayer را با پیکربندی های به اشتراک گذاشته شده پیوسته می سازد.
    • پارامتر Renderer[] از LoadControl.onTracksSelected() حذف کنید زیرا اجرای DefaultLoadControl می تواند انواع جریان را از ExoTrackSelection[] بازیابی کند.
    • DefaultLoadControl.calculateTargetBufferBytes(Renderer[], ExoTrackSelection[]) منسوخ شد و برای جلوگیری از لغو، روش به عنوان نهایی علامت گذاری شد. به جای آن باید از DefaultLoadControl.calculateTargetBufferBytes(ExoTrackSelection[]) جدید استفاده شود.
    • گزارش رویدادهای MediaSourceEventListener از منابع ثانویه در MergingMediaSource . این باعث می‌شود که رویدادهای شروع/خطا/لغو/تکمیل بار برای زیرنویس‌های جانبی (آنهایی که با MediaItem.LocalConfiguration.subtitleConfigurations اضافه شده‌اند) گزارش شود، که ممکن است به‌عنوان رویدادهای بار تکراری منتشر شده از AnalyticsListener ظاهر شوند.
    • از توقف کامل پخش توسط خطاهای زیرنویس و ابرداده جلوگیری کنید. در عوض آهنگ مشکل دار غیرفعال شده و پخش آهنگ های باقی مانده ادامه می یابد ( #1722 ).
      • در مدیریت جدید زیرنویس (در حین استخراج)، خطاهای تجزیه مرتبط (مثلاً داده‌های زیرنویس نامعتبر) و خطاهای بارگذاری (مانند HTTP 404) از طریق تماس‌های onLoadError منتشر می‌شوند.
      • در مدیریت زیرنویس قدیمی (در طول رندر)، فقط خطاهای بار مرتبط از طریق تماس‌های onLoadError منتشر می‌شوند در حالی که خطاهای تجزیه بی‌صدا نادیده گرفته می‌شوند (این یک رفتار از قبل موجود است).
  • ترانسفورماتور:
    • تنظیم مدت زمان تصویر را با استفاده از MediaItem.Builder.setImageDurationMs برای صادرات تصویر اجباری کنید.
    • اضافه کردن پشتیبانی صادرات برای شکاف در دنباله های صوتی EditedMediaItems.
  • انتخاب آهنگ:
    • DefaultTrackSelector : هنگامی که سایر عوامل برابر هستند، صدای مبتنی بر شی را به صدای مبتنی بر کانال ترجیح دهید.
  • استخراج کننده ها:
    • هنگام پردازش فهرست‌های ویرایش در فایل‌های MP4 ( #1659 ) مدیریت نمونه پیش‌پرول را برای موقعیت‌های شروع رسانه‌های غیرکلیدی برطرف کنید.
    • بهبود محاسبه نرخ فریم با استفاده از مدت زمان رسانه از جعبه mdhd در Mp4Extractor و FragmentedMp4Extractor ( #1531 ).
    • اصلاح مقیاس نادرست media_time در لیست های ویرایش MP4. در حالی که segment_duration قبلاً با استفاده از مقیاس زمانی فیلم به درستی مقیاس‌بندی شده بود، media_time اکنون با استفاده از مقیاس زمانی مسیر به درستی مقیاس‌بندی می‌شود، همانطور که توسط استاندارد فرمت MP4 ( #1792 ) مشخص شده است.
    • فریم های نامرتب را در محاسبه endIndices برای MP4 با لیست ویرایش ( #1797 ) مدیریت کنید.
  • صوتی:
    • صداهای پاپ را که ممکن است در حین جستجوها ایجاد شود برطرف کنید.
    • انباشتگی خطای برش را برای الگوریتم کشش/تغییر زمان Sonic برطرف کنید.
    • رفع اشکال در SpeedChangingAudioProcessor که باعث افت فریم های خروجی می شود.
  • ویدئو:
    • راه‌حلی برای مشکل دستگاه در Galaxy Tab S7 FE اضافه کنید که باعث می‌شود جریان‌های H264 ایمن 60 فریم بر ثانیه به‌عنوان پشتیبانی‌نشده علامت‌گذاری شوند ( #1619 ).
    • برای کدک هایی که پس از آخرین نمونه بدون بازگشت سیگنال پایان جریان گیر می کنند، راه حلی اضافه کنید.
  • متن:
    • اطمینان حاصل کنید که WebVTT در HLS با مهرهای زمانی زیرنویس بسیار بزرگ (که زمانی که به صورت میکروثانیه نمایش داده می‌شوند 64 long سرریز می‌کنند و در پایگاه زمانی 90,000 MPEG ضرب می‌شوند) نمایش داده می‌شوند ( #1763 ).
  • فراداده:
    • نوع C.TRACK_TYPE_METADATA را به آهنگ های حاوی محتوای یخی یا vnd.dvb.ait اختصاص دهید.
  • DRM:
    • رفع IllegalStateException از DefaultDrmSession.requiresSecureDecoder پس از باز کردن یک جلسه DRM شکست خورد. این موضوع در 1.5.0-alpha01 معرفی شد.
  • موکسرها:
  • پسوند IMA:
    • رفع اشکالی که در آن جریان‌های DAI درج‌شده در سمت سرور بدون پیش‌پرول می‌تواند منجر به ArrayIndexOutOfBoundsException در هنگام پخش گذشته از آخرین میان‌افزار ( #1741 ) شود.
  • جلسه:
    • رفع اشکالی که باعث می‌شود دستورات سفارشی ارسال شده از MediaBrowser به MediaSessionCompat.Callback به جای نوع MediaBrowserServiceCompat روش هنگام اتصال به یک سرویس قدیمی ارسال شود. این امر باعث شد MediaBrowser نتواند مقدار بازگشتی واقعی را که توسط سرویس قدیمی ارسال شده است ( #1474 ) دریافت کند.
    • کنترل IllegalArgumentException پرتاب شده توسط دستگاه های سازنده خاص هنگام تنظیم گیرنده پخش برای اهداف دکمه رسانه ( #1730 ).
    • دکمه های فرمان را برای آیتم های رسانه اضافه کنید. این API Media3 را برای آنچه به عنوان Custom browse actions با کتابخانه قدیمی با MediaBrowserCompat شناخته می‌شود، اضافه می‌کند. توجه داشته باشید که با Media3 دکمه های فرمان برای آیتم های رسانه برای هر دو، MediaBrowser و MediaController در دسترس هستند. اقدامات مرور سفارشی AAOS را ببینید.
    • رفع اشکال که در آن یک کنترلر Media3 گاهی اوقات نمی توانست به برنامه جلسه اجازه دهد پس از درخواست play() سرویس پیش زمینه را شروع کند.
    • CommandButton.Builder.setIconUri را محدود کنید تا فقط Uris محتوا را بپذیرد.
    • هنگام اتصال به MediaBrowserCompat قدیمی، نکات اتصال مرورگر Media3 را به MediaBrowserCompat اولیه منتقل کنید. این سرویس می‌تواند راهنمایی‌های اتصال را که به‌عنوان راهنمایی ریشه ارسال می‌شود، با اولین تماس با onGetRoot() دریافت کند.
    • رفع اشکالی که در آن MediaBrowser به یک سرویس مرورگر قدیمی متصل است، پس از اینکه مرورگر در یک parentid مشترک شد، خطایی توسط سرویس ارسال نشده است.
    • رفتار قابلیت همکاری را بهبود بخشید، به طوری که مرورگر Media3 که به یک MediaBrowserService قدیمی متصل است، هنگام اشتراک در یک والدین، دو بار از فرزندان یک parentId درخواست نکند.
  • UI:
    • به دلیل مشکلات مربوط به انتقال مشترک مبتنی بر XML، ویدیوی کشیده/برش‌شده را در PlayerView -in-Compose- راه‌حل AndroidView انتخاب کنید. برنامه‌هایی که از PlayerView در AndroidView استفاده می‌کنند، باید با PlayerView.setEnableComposeSurfaceSyncWorkaround تماس بگیرند تا بتوانند شرکت کنند ( #1237 ، #1594 ).
    • setFullscreenButtonState به PlayerView اضافه کنید تا به‌روزرسانی نماد دکمه تمام‌صفحه در صورت تقاضا، یعنی خارج از باند و نه به صورت واکنش‌گرا در تعامل کلیکی امکان‌پذیر باشد ( #1590 ، #184 ).
    • اگر تنظیمات برگزیده انتخاب آهنگ متنی تعریف شده توسط برنامه وجود داشته باشد، اشکالی را که در آن گزینه «هیچ‌کدام» در انتخاب متن کار نمی‌کند، برطرف کنید.
  • پسوند جریان روان:
    • هنگام پخش جریان‌های SmoothStreaming با آهنگ‌های متنی، یک Bad magic number for Bundle برطرف کنید ( #1779 ).
  • پسوند RTSP:
    • رفع اطلاعات کاربر برای URL هایی که حاوی نویسه های @ رمزگذاری شده هستند ( #1138 ).
  • پسوندهای رمزگشا (FFmpeg، VP9، AV1، و غیره):
    • پشتیبانی از صفحه 16 کیلوبایتی برای برنامه‌های افزودنی رمزگشا در Android 15 ( #1685 ) اضافه کنید.
  • پسوند بازیگران:
    • پس از قطع ارتباط CastSession، تمیز کردن جدول زمانی را متوقف کنید، که به برنامه فرستنده امکان می‌دهد پس از قطع ارتباط، پخش را به صورت محلی از سر بگیرد.
    • هنگامی که یک Context ارائه می شود، DeviceInfo CastPlayer را پر کنید. این امکان پیوند MediaSession را به RoutingSession می‌دهد، که برای یکپارچه کردن خروجی سوئیچر ( #1056 ) ضروری است.
  • حذف نمادهای منسوخ شده:
    • سازنده های DefaultEncoderFactory منسوخ شده را حذف کنید. به جای آن از DefaultEncoderFactory.Builder استفاده کنید.

نسخه 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 را در configure دریافت کند detachOutputSurface در صورتی که کدک Surface این مورد پشتیبانی کند ( MediaCodecInfo.detachedSurfaceSupported ).
    • اگر هنگام پردازش onOutputFormatChanged ( #1371 ) از مقادیر نسبت تصویر ارائه شده توسط MediaCodecAdapter استفاده کنید.
  • متن:
  • تصویر:
    • 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 با فضایی سازی همراه با ردیابی سر اختیاری فعال است، اما پشتیبانی از پخش دو گوش در حال حاضر در دسترس نیست.
  • پسوند بازیگران:
    • پس از قطع ارتباط 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:
    • در PreloadMediaSource ( #1568 ) تماس‌های پیش‌بارگذاری را به‌صورت ناهمزمان مدیریت کنید.
    • اجازه پخش بدون در نظر گرفتن مدت زمان بافر در هنگام بارگیری ناموفق ( #1571 ).
  • استخراج کننده ها:
    • MP3: با نادیده گرفتن صحیح داده های غیر MP3 دنباله بر اساس طول فیلد در یک قاب Info ( #1480 ) خطای Searched too many bytes برطرف کنید.
  • متن:
    • TTML: رسیدگی به مقادیر درصد tts:fontSize را برطرف کنید تا مطمئن شوید که آنها به درستی از گره های والد با مقادیر درصد tts:fontSize به ارث برده شده اند.
    • IndexOutOfBoundsException در LegacySubtitleUtil به دلیل مدیریت نادرست مورد زمان شروع خروجی درخواستی بزرگتر یا مساوی با زمان رویداد نهایی در Subtitle ( #1516 ) برطرف کنید.
  • 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 MediaSource.Factory.experimentalParseSubtitlesDuringExtraction(false) و TextRenderer.experimentalSetLegacyDecodingEnabled(true) لغو کرد. برای نحوه وارد کردن این اجزا به یک نمونه ExoPlayer ، به اسناد سفارشی‌سازی مراجعه کنید. این روش ها (و همه پشتیبانی از رمزگشایی زیرنویس قدیمی) در نسخه بعدی حذف خواهند شد.
      • برنامه‌های دارای پیاده‌سازی سفارشی SubtitleDecoder باید برای پیاده‌سازی SubtitleParserSubtitleParser.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 ) منتشر کنید.
  • تصویر:
    • پشتیبانی از شبکه‌های تصویر کوچک 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 را که برای برنامه ها برای پخش جریان های AD DAI به پایدار لازم است ، تبلیغ کنید.
    • اضافه کردن replaceAdTagParameters(Map <String, String>) به ImaServerSideAdInsertionMediaSource.AdLoader اضافه کنید که اجازه می دهد تا پارامترهای برچسب تبلیغاتی را در زمان اجرا جایگزین کنید.
    • رفع اشکال در جایی که VideoAdPlayer.VideoAdPlayerCallback.onError() هنگامی که خطای بازیکن در حین پخش آگهی اتفاق افتاد ( شماره 1334 ) فراخوانده نشد.
    • Bump IMA SDK نسخه به 3.33.0 برای رفع یک NullPointerException هنگام استفاده data:// ad tag uris ( شماره 700 ).
  • جلسه:
    • تغییر پیش فرض CommandButton.enabled to true و اطمینان حاصل کنید که مقدار می تواند برای کنترل کننده ها نادرست بماند حتی اگر دستور مرتبط در دسترس باشد.
    • ثابت های نماد را برای CommandButton اضافه کنید که باید به جای منابع نماد سفارشی استفاده شود.
    • اضافه کردن MediaSessionService.isPlaybackOngoing() برای اینکه برنامه ها را بپرسید که آیا این سرویس باید در onTaskRemoved() ( #1219 ) متوقف شود.
    • اضافه کردن MediaSessionService.pauseAllPlayersAndStopSelf() که به راحتی امکان مکث پخش همه جلسات را فراهم می کند و stopSelf() برای خاتمه چرخه عمر MediaSessionService .
    • Override MediaSessionService.onTaskRemoved(Intent) برای ارائه یک پیش فرض ایمن که در صورت ادامه پخش یا سرویس ، سرویس را در پیش زمینه نگه می دارد یا سرویس را متوقف می کند.
    • Hide Seekbar را در اعلان رسانه برای جریان های زنده با تنظیم مدت زمان در ابرداده جلسه سکو ( #1256 ) پنهان کنید.
    • تبدیل MediaMetadata به MediaDescriptionCompat ، برای استفاده از همان ترتیب و منطق ارجح هنگام انتخاب خصوصیات ابرداده مانند Media1.
    • اضافه کردن MediaSession.sendError() که امکان ارسال خطاهای غیر کشنده به Media3 Controller را فراهم می کند. هنگام استفاده از کنترل کننده اعلان (به MediaSession.getMediaNotificationControllerInfo() ) مراجعه کنید ، از خطای سفارشی برای به روزرسانی PlaybackState جلسه پلتفرم به حالت خطا با اطلاعات خطای داده شده استفاده می شود ( شماره 543 ).
    • اضافه کردن MediaSession.Callback.onPlayerInteractionFinished() برای اطلاع از جلسات هنگامی که یک سری از تعامل پخش کننده از یک کنترلر خاص به پایان رسید.
    • SessionError اضافه کنید و از آن در SessionResult و LibraryResult به جای کد خطا استفاده کنید تا اطلاعات بیشتری در مورد خطا و نحوه حل خطا در صورت امکان ارائه دهید.
    • کد برنامه کنترلر Media3 را منتشر کنید که می تواند برای آزمایش تعامل با برنامه های انتشار یک جلسه رسانه ای استفاده شود.
    • موارد اضافی تبلیغاتی که به Media3 PlaybackStateCompat.getExtras() MediaSession[Builder].setSessionExtras() منتقل شده است.
    • خطاهای مهلک و غیر کشنده را به جلسه سکو و از آن ترسیم کنید. یک PlaybackException به حالت خطای مهلک از PlaybackStateCompat نقشه برداری می شود. SessionError ارسال شده به کنترل کننده اعلان رسانه با MediaSession.sendError(ControllerInfo, SessionError) در PlaybackStateCompat با خطای غیر کشنده نقشه برداری می شود ، این بدان معنی است که کد خطا و پیام تنظیم شده است اما وضعیت جلسه پلتفرم با STATE_ERROR متفاوت است.
    • اجازه دهید فعالیت جلسه در هر کنترلر تنظیم شود تا فعالیت جلسه جهانی را نادیده بگیرد. فعالیت جلسه را می توان برای یک کنترلر در زمان اتصال با ایجاد یک ConnectionResult با پذیرفته شده با AcceptedResultBuilder.setSessionActivivty(PendingIntent) تعریف کرد. پس از اتصال ، فعالیت جلسه را می توان با MediaSession.setSessionActivity(ControllerInfo, PendingIntent) به روز کرد.
    • بهبود خطا در تماس با MediaLibrarySession.Callback را بهبود بخشید. تکثیر خطا اکنون می تواند با استفاده از MediaLibrarySession.Builder.setLibraryErrorReplicationMode() برای انتخاب نوع خطا یا انتخاب خارج از تکرار خطا که به طور پیش فرض روشن است ، پیکربندی شود.
  • UI:
    • پشتیبانی از صفحه نمایش تصویر را به PlayerView هنگام اتصال به یک ExoPlayer اضافه کنید ( شماره 1144 ).
    • سفارشی سازی نمادهای مختلف را در PlayerControlView از طریق ویژگی های XML اضافه کنید تا به جای غلبه های جهانی ( #1200 ) ، در هر نمونه PlayerView امکان پذیر باشد.
    • در اطراف یک اشکال پلتفرم ایجاد کنید که باعث ایجاد فیلم کشیده و بریده شده هنگام استفاده از SurfaceView در داخل AndroidView در API 34 ( #1237 ) می شود.
  • دانلودها:
    • اطمینان حاصل کنید که DownloadHelper نمونه های Renderer منتشر نشده را نشت نمی کند ، که در نهایت می تواند منجر به خراب شدن برنامه با IllegalStateException: Too many receivers, total of 1000, registered for pid ( شماره 1224 ).
  • پسوند cronet:
    • رفع SocketTimeoutException در CronetDataSource . در برخی از نسخه های Cronet ، درخواست ارائه شده توسط پاسخ به تماس همیشه یکسان نیست. این منجر به تکمیل پاسخ به تماس و درخواست زمان بندی می شود (https://issuetracker.google.com/328442628).
  • پسوند HLS:
    • رفع اشکال در جایی که در انتظار نمونه های EMSG در انتظار ناپیوستگی در HlsSampleStreamWrapper با یک جبران نادرست ایجاد شد و باعث ایجاد IndexOutOfBoundsException یا IllegalArgumentException ( #1002 ) شد.
    • رفع اشکال در جایی که لیست های پخش غیر مقدماتی بارگذاری مجدد برای جریان های LL-HLS ( #1240 ).
    • رفع اشکال در جایی که فعال کردن CMCD برای HLS با بخش های اولیه سازی منجر به Source Error و IllegalArgumentException .
    • رفع اشکال در جایی که لیست های پخش غیرقانونی در هنگام پخش زنده تازه نشود ( #1240 ).
    • رفع اشکال در جایی که فعال کردن CMCD برای HLS Live Live باعث ایجاد ArrayIndexOutOfBoundsException ( #1395 ) می شود.
  • پسوند داش:
    • رفع اشکال در جایی که دوباره یک جریان زنده چند دوره ای را آماده کنید می تواند یک IndexOutOfBoundsException ( #1329 ) را پرتاب کند.
    • پشتیبانی از dashif:Laurl ( شماره 1345 ) را اضافه کنید.
  • پسوند بازیگران:
    • رفع اشکالی که عنوان آلبوم MediaQueueItem را به این هنرمند در مورد Media3 Media ( شماره 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_TYPE FORMAT_UNSUPPORTED_SUBTYPE به جای آن از 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 شامل این تعهدات است.

  • کتابخانه مشترک:
    • Format.labels اضافه کنید تا به برچسب های جایگزین یا سایر گزینه های جایگزین دیگر اجازه دهید.
  • سیارات فراتر:
    • مسئله ای را که PreloadMediaPeriod نمی تواند جریان ها را در هنگام بارگذاری مجدد دوباره حفظ کند ، رفع کنید.
    • True TrackSelectionResult مربوطه را در دوره بازی در انتخاب مجدد آهنگ اعمال کنید.
    • رندرهای فعال شده را فقط پس از پیشبرد دوره بازی هنگام انتقال بین موارد رسانه ای ( شماره 1017 ) شروع کنید.
    • اضافه کردن نوع بازگشت از دست رفته به قانون proguard -keepclasseswithmembers برای DefaultVideoFrameProcessor.Factory.Builder.build() ( #1187 ).
  • ترانسفورماتور:
    • راه حل را برای استثنائی که به دلیل MediaMuxer پشتیبانی از زمان بندی منفی ارائه منفی قبل از API 30 پشتیبانی نمی کند ، اضافه کنید.
  • انتخاب آهنگ:
    • DefaultTrackSelector : آهنگ های ویدیویی را با نرخ فریم "معقول" (> = 10fps) نسبت به کسانی که نرخ فریم پایین تر یا UNT را ترجیح می دهند ، ترجیح دهید. این تضمین می کند که پخش کننده آهنگ ویدیویی "واقعی" را در MP4 های استخراج شده از عکس های حرکتی انتخاب می کند که می تواند شامل دو آهنگ HEVC باشد که در آن یک وضوح بالاتری دارد اما تعداد بسیار کمی از فریم ( #1051 ).
  • استخراج کننده ها:
    • مسئله ای را که در آن هنگام خواندن تکه های به اندازه عجیب و غریب از پرونده های WAV ( شماره 1117 ) پرش نشده است ، رفع کنید.
    • MP3: Forment Format.averageBitrate از فریم های ابرداده مانند XING و VBRI .
    • MPEG-TS: با انتقال آخرین واحد دسترسی یک جریان به صف نمونه ( شماره 7909 ) ، تغییری را که هدف آن اطمینان از آخرین قاب است ، برگردانید. این به دلیل تغییر ایجاد مشکلات جدید با جریان های I-Fame فقط HLS ( #1150 ) و جریان H.262 HLS ( #1126 ) است.
  • صوتی:
    • اگر آهنگ صوتی نتواند در حالت Offload اولیه شود ، بازیابی رندر را با غیرفعال کردن بار امکان پذیر کنید.
  • ویدئو:
    • راه حل را برای مسئله دستگاه در Galaxy Tab S7 Fe ، Chromecast با Google TV و Lenovo M10 FHD Plus اضافه کنید که باعث می شود جریان های 60fps H265 به صورت پشتیبانی نشده مشخص شود
    • راه حل را اضافه کنید که تضمین می کند که قاب اول همیشه در حین تونل سازی ارائه می شود حتی اگر دستگاه این کار را به طور خودکار مطابق آنچه توسط API مورد نیاز است ( #1169 ) انجام ندهد. ( شماره 966 ).
    • مسئله را برطرف کنید که در آن اطلاعات مربوط به رنگ آمیزی HDR باعث نادرست کدک می شود و از سوئیچ های فرمت سازگار برای آهنگ های ویدیویی SDR جلوگیری می کند ( #1158 ).
  • متن:
    • WebVTT: از ایجاد نشانه های مستقیم متوالی جلوگیری کنید و از ایجاد CuesWithTiming های اضافی اضافی از WebvttParser.parse ( #1177 ) استفاده کنید.
  • DRM:
    • در اطراف یک NoSuchMethodError کار کنید که می تواند توسط چارچوب MediaDrm به جای ResourceBusyException یا NotProvisionedException در برخی از دستگاه های Android 14 ( #1145 ) پرتاب شود.
  • اثر:
    • با تبدیل فضاهای رنگی ، PQ به SDR Tong Maging را بهبود بخشید.
  • جلسه:
    • مشکل را برطرف کنید که وقتی کنترل کننده جایگزین مورد فعلی می شود ، موقعیت فعلی به عقب می رود ( شماره 951 ).
    • مسئله ای را که MediaMetadata با extras غیر تهی بین کنترل کننده های رسانه و جلسات منتقل نمی شود ، رفع کنید ( شماره 1176 ).
  • 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 اکنون به طور پیش فرض با NULL ImageOutput و 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 اجرا نمی شود ، بنابراین به طور مؤثر فرض می شود که همیشه نادرست است).
  • تصویر:
    • پشتیبانی از تصاویر کوچک را اضافه کنید. تصاویر شبکه بریده شده و تصاویر کوچک به ImageOutput نزدیک به زمان ارائه آنها ارائه می شود.
  • DRM:
    • نمونه های رمزگذاری نشده "Clear Lead" را در محتوای DRM بلافاصله به طور پیش فرض بازی کنید ، حتی اگر کلیدهای نمونه های رمزگذاری شده بعدی هنوز آماده نباشند. این ممکن است به غرفه های بازی برگشت منجر شود اگر کلیدها هنوز آماده نباشند وقتی موقعیت پخش به نمونه های رمزگذاری شده برسد (اما قبلاً پخش تا این مرحله به هیچ وجه شروع نمی شد). این رفتار را می توان با MediaItem.DrmConfiguration.Builder.setPlayClearContentWithoutKey یا DefaultDrmSessionManager.Builder.setPlayClearSamplesWithoutKeys غیرفعال کرد.
  • پسوند 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 ) هستند را برطرف کنید.
  • صوتی:
    • رسیدگی به EOS را برای SilenceSkippingAudioProcessor هنگامی که چندین بار خوانده می شود ( شماره 712 ) برطرف کنید.
  • ویدئو:
    • راه حل را برای مسئله دستگاه در 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 برطرف کنید. این خطا به دلیل نادرست استفاده از یک رمزگذار ایمن برای پخش محتوای واضح بود.
  • جلسه:
    • کلیدها و مقادیر سفارشی را در MediaMetadataCompat به MediaMetadata.extras و MediaMetadata.extras به MediaMetadataCompat ( #756 ، #802 ) قرار دهید.
    • برای کنترل کننده های میراث ( شماره 644 ) notifyChildrenChanged را برطرف کنید.
    • رفع اشکال در جایی که تنظیم زمان منفی برای یک setWhen غیرفعال در زمان تایمر اعلان باعث خرابی در برخی از دستگاه ها شد ( شماره 903 ).
    • هنگامی که کنترل کننده اعلان رسانه در هنگام درخواست اولین به روزرسانی اعلان ، اتصال را تکمیل نکرده است ( شماره 917 ) IllegalStateException برطرف کنید.
  • UI:
    • مشکل را برطرف کنید که دکمه های رو به جلو و عقب در هنگام استفاده از طراحی مواد در قسمت زیرین صفحه ( #511 ) قابل مشاهده نیست.
    • مسئله را برطرف کنید که اعداد موجود در دکمه Fast Forward از PlayerControlView نادرست انجام شود ( شماره 547 ).
  • پسوند داش:
    • تجزیه و تحلیل "F800" به عنوان تعداد کانال 5 برای Dolby in Dash Misper ( #688 ).
  • پسوندهای رمزگشایی (FFMPEG ، VP9 ، AV1 ، MIDI و غیره):
    • MIDI: مسئله را برطرف کنید که در آن به دنبال پیشبرد برنامه های تغییر برنامه ( شماره 704 ) است.
    • به FFMPEG 6.0 مهاجرت کنید و NDK را به r26b ( #707 ، #867 ) پشتیبانی کنید.
  • پسوند بازیگران:
    • ایجاد یک 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 اضافه کنید.
    • AudioSink.getFormatOffloadSupport(Format) را که بازیابی سطح Offload پشتیبانی می کند DefaultAudioOffloadSupportProvider اضافه کنید. این 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 ) را پرتاب می کند.
  • ویدئو:
    • به 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() را نادیده بگیرید. If successful, the subscription is accepted and notifyChildrenChanged() 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 the queue button in the UI of Android Auto is not displayed ( #339 ).
    • Use DataSourceBitmapLoader by default instead of SimpleBitmapLoader ( #271 , #327 ).
    • Add MediaSession.Callback.onMediaButtonEvent(Intent) that allows apps to override the default media button event handling.
  • UI:
    • Add a Player.Listener implementation for Wear OS devices that handles playback suppression due to Player.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).
  • دانلودها:
    • Declare "data sync" foreground service type for DownloadService for Android 14 compatibility. When using this service, the app also needs to add dataSync as foregroundServiceType in the manifest and add the FOREGROUND_SERVICE_DATA_SYNC permission ( #11239 ).
  • 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 ).
  • 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 over C.BUFFER_FLAG_DECODE_ONLY that will be deprecated.
    • Add Decoder.setOutputStartTimeUs and SimpleDecoder.isAtLeastOutputStartTimeUs to allow decoders to drop decode-only samples before the start time. This should be preferred to Buffer.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 ).
  • Test Utilities:
    • Make TestExoPlayerBuilder and FakeClock compatible with Espresso UI tests and Compose UI tests. This fixes a bug where playback advances non-deterministically during Espresso or Compose view interactions.
  • Remove deprecated symbols:
    • Remove TransformationRequest.Builder.setEnableRequestSdrToneMapping(boolean) and TransformationRequest.Builder.experimental_setEnableHdrEditing(boolean) . Use Composition.Builder.setHdrMode(int) and pass the Composition to Transformer.start(Composition, String) instead.
    • Remove deprecated DownloadNotificationHelper.buildProgressNotification method, use a non deprecated method that takes a notMetRequirements parameter instead.

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 .

نسخه 1.1.0

نسخه 1.1.1

16 آگوست 2023

  • Common Library:
    • Remove accidentally added multidex dependency from all modules ( #499 ).
  • ExoPlayer:
    • Fix issue in PlaybackStatsListener where spurious PlaybackStats 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 a bug where Player.getState() never transitioned to STATE_ENDED when playing very short files ( #538 ).
  • 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 in MediaSession.Callback.onConnect by using an AcceptedResultBuilder to make sure the custom layout is available to the controller when connection completes.
    • Fix cases where MediaLibraryServiceLegacyStub sent an error to a Result that didn't support this which produced an UnsupportedOperationException ( #78 ).
    • Fix the way PlayerWrapper creates a VolumeProviderCompat by determining volumeControlType through both legacy commands ( COMMAND_ADJUST_DEVICE_VOLUME and COMMAND_SET_DEVICE_VOLUME ) and new commands ( COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS and COMMAND_SET_DEVICE_VOLUME_WITH_FLAGS ) ( #554 ).

نسخه 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 for DeviceInfo 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) and setDeviceVolume(int, int)
      • increaseDeviceVolume(int) and increaseDeviceVolume(int, int)
      • decreaseDeviceVolume(int) and decreaseDeviceVolume(int, int)
    • Add FilteringMediaSource that allows to filter available track types from a MediaSource .
    • 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 , and sid , 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.
    • 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 using Effect during video playback.
    • Update SampleQueue to store sourceId as a long rather than an int . This changes the signatures of public methods SampleQueue.sourceId and SampleQueue.peekSourceId .
    • Add parameters to LoadControl methods shouldStartPlayback and onTracksSelected that allow associating these methods with the relevant MediaPeriod .
    • 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) and BaseMediaSource.createEventDispatcher(..., long mediaTimeOffsetMs) . The variant of the methods without the mediaTimeOffsetUs can be called instead. Note that even for the deprecated variants, the offset is not anymore added to startTimeUs and endTimeUs of the MediaLoadData objects that are dispatched by the dispatcher.
    • Rename ExoTrackSelection.blacklist to excludeTrack and isBlacklisted to isTrackExcluded .
    • Fix inconsistent behavior between ExoPlayer.setMediaItem(s) and addMediaItem(s) when called on an empty playlist.
  • ترانسفورماتور:
    • Remove Transformer.Builder.setMediaSourceFactory(MediaSource.Factory) . Use ExoPlayerAssetLoader.Factory(MediaSource.Factory) and Transformer.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 using findDecoder/EncoderForFormat utilities, to expand support.
    • Remove B-frame configuration in DefaultEncoderFactory because it doesn't work on some devices.
  • Track selection:
    • Add DefaultTrackSelector.Parameters.allowInvalidateSelectionsForRendererCapabilitiesChange which is disabled by default. When enabled, the DefaultTrackSelector will trigger a new track selection when the renderer capabilities changed.
  • Extractors:
    • Ogg: Fix bug when seeking in files with a long duration ( #391 ).
    • FMP4: Fix issue where TimestampAdjuster initializes a wrong timestamp offset with metadata sample time from emsg atom ( #356 ).
  • صوتی:
    • 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() and AudioSink.release() for releasing the resources at the end of player's lifecycle.
    • Listen to audio capabilities changes in DefaultAudioSink . Add a required parameter context in the constructor of DefaultAudioSink , with which the DefaultAudioSink will register as the listener to the AudioCapabilitiesReceiver and update its audioCapabilities property when informed with a capabilities change.
    • Propagate audio capabilities changes via a new event onAudioCapabilitiesChanged in AudioSink.Listener interface, and a new interface RendererCapabilities.Listener which triggers onRendererCapabilitiesChanged events.
    • Add ChannelMixingAudioProcessor for applying scaling/mixing to audio channels.
    • Add new int value DISCARD_REASON_AUDIO_BYPASS_POSSIBLE to DecoderDiscardReasons 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 a VideoSize with a width and height of 0 when the renderer is disabled. Player.Listener.onVideoSizeChanged is called accordingly when Player.getVideoSize() changes. With this change, ExoPlayer's video size with MediaCodecVideoRenderer has a width and height of 0 when Player.getCurrentTracks does not support video, or the size of the supported video track is not yet determined.
  • 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)
  • 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 a Player 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 requested MediaItems to be passed onto Player if they have LocalConfiguration (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 requested MediaItems to be passed onto Player if they have LocalConfiguration (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 ).
  • UI:
    • Add Util methods shouldShowPlayButton and handlePlayPauseButtonAction to write custom UI elements with a play/pause button.
  • RTSP Extension:
    • For MPEG4-LATM, use default profile-level-id value if absent in Describe Response SDP message ( #302 ).
    • Use base Uri for relative path resolution from the RTSP session if present in DESCRIBE response header ( #11160 ).
  • DASH Extension:
    • Remove the media time offset from MediaLoadData.startTimeMs and MediaLoadData.endTimeMs for multi period DASH streams.
    • Fix a bug where re-preparing a multi-period live Dash media source produced a IndexOutOfBoundsException ( #10838 ).
  • HLS Extension:
    • Add HlsMediaSource.Factory.setTimestampAdjusterInitializationTimeoutMs(long) to set a timeout for the loading thread to wait for the TimestampAdjuster to initialize. If the initialization doesn't complete before the timeout, a PlaybackException is thrown to avoid the playback endless stalling. The timeout is set to zero by default ( #323 ).
  • Test Utilities:
    • Check for URI scheme case insensitivity in DataSourceContractTest .
  • Remove deprecated symbols:
    • Remove DefaultAudioSink constructors, use DefaultAudioSink.Builder instead.
    • Remove HlsMasterPlaylist , use HlsMultivariantPlaylist instead.
    • Remove Player.stop(boolean) . Use Player.stop() and Player.clearMediaItems() (if reset is true ) instead.
    • Remove two deprecated SimpleCache constructors, use a non-deprecated constructor that takes a DatabaseProvider instead for better performance.
    • Remove DefaultBandwidthMeter constructor, use DefaultBandwidthMeter.Builder instead.
    • Remove DefaultDrmSessionManager constructors, use DefaultDrmSessionManager.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 , and DownloadHelper.forSmoothStreaming , use DownloadHelper.forMediaItem instead.
    • Remove deprecated DownloadService constructor, use a non deprecated constructor that includes the option to provide a channelDescriptionResourceId parameter.
    • Remove deprecated String constants for Charsets ( ASCII_NAME , UTF8_NAME , ISO88591_NAME , UTF16_NAME and UTF16LE_NAME ), use Kotlin Charsets from the kotlin.text package, the java.nio.charset.StandardCharsets or the com.google.common.base.Charsets instead.
    • Remove deprecated WorkManagerScheduler constructor, use a non deprecated constructor that includes the option to provide a Context parameter instead.
    • Remove the deprecated methods createVideoSampleFormat , createAudioSampleFormat , createContainerFormat , and createSampleFormat , which were used to instantiate the Format class. Instead use Format.Builder for creating instances of Format .
    • Remove the deprecated methods copyWithMaxInputSize , copyWithSubsampleOffsetUs , copyWithLabel , copyWithManifestFormatInfo , copyWithGaplessInfo , copyWithFrameRate , copyWithDrmInitData , copyWithMetadata , copyWithBitrate and copyWithVideoSize , use Format.buildUpon() and setter methods instead.
    • Remove deprecated ExoPlayer.retry() , use prepare() instead.
    • Remove deprecated zero-arg DefaultTrackSelector constructor, use DefaultTrackSelector(Context) instead.
    • Remove deprecated OfflineLicenseHelper constructor, use OfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher) instead.
    • Remove deprecated DownloadManager constructor, use the constructor that takes an Executor instead.
    • Remove deprecated Cue constructors, use Cue.Builder instead.
    • Remove deprecated OfflineLicenseHelper constructor, use OfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher) instead.
    • Remove four deprecated AnalyticsListener methods:
      • onDecoderEnabled , use onAudioEnabled and/or onVideoEnabled instead.
      • onDecoderInitialized , use onAudioDecoderInitialized and/or onVideoDecoderInitialized instead.
      • onDecoderInputFormatChanged , use onAudioInputFormatChanged and/or onVideoInputFormatChanged instead.
      • onDecoderDisabled , use onAudioDisabled and/or onVideoDisabled instead.
    • Remove the deprecated Player.Listener.onSeekProcessed and AnalyticsListener.onSeekProcessed , use onPositionDiscontinuity with DISCONTINUITY_REASON_SEEK instead.
    • Remove ExoPlayer.setHandleWakeLock(boolean) , use setWakeMode(int) instead.
    • Remove deprecated DefaultLoadControl.Builder.createDefaultLoadControl() , use build() instead.
    • Remove deprecated MediaItem.PlaybackProperties , use MediaItem.LocalConfiguration instead. Deprecated field MediaItem.playbackProperties is now of type MediaItem.LocalConfiguration .

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

نسخه 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 if Buffer contains flag C.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 ).
  • 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 legacy MediaSessionCompat that updates its actions.
    • Fix bug that prevented the MediaLibraryService from returning null for a call from System UI to Callback.onGetLibraryRoot with params.isRecent == true on API 30 ( #355 ).
    • Fix memory leak of MediaSessionService or MediaLibraryService ( #346 ).
    • Fix bug where a combined Timeline and position update in a MediaSession may cause a MediaController to throw an IllegalStateException .

نسخه 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 in MediaController ( #290 ).
    • Add missing forwarding of MediaSession.broadcastCustomCommand to the legacy MediaControllerCompat.Callback.onSessionEvent ( #293 ).
    • Fix bug where calling MediaSession.setPlayer doesn't update the available commands.
    • Fix issue that TrackSelectionOverride instances sent from a MediaController are ignored if they reference a group with Format.metadata ( #296 ).
    • Fix issue where Player.COMMAND_GET_CURRENT_MEDIA_ITEM needs to be available to access metadata via the legacy MediaSessionCompat .
    • Fix issue where MediaSession instances on a background thread cause crashes when used in MediaSessionService ( #318 ).
    • Fix issue where a media button receiver was declared by the library without the app having intended this ( #314 ).
  • داش:
    • 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:
    • Fix network type detection on API 33 ( #10970 ).
    • Fix NullPointerException when calling ExoPlayer.isTunnelingEnabled ( #10977 ).
  • دانلودها:
    • Make the maximum difference of the start time of two segments to be merged configurable in SegmentDownloader and subclasses ( #248 ).
  • صوتی:
    • Fix broken gapless MP3 playback on Samsung devices ( #8594 ).
    • Fix bug where playback speeds set immediately after disabling audio may be overridden by a previous speed change ( #10882 ).
  • ویدئو:
    • Map HEVC HDR10 format to HEVCProfileMain10HDR10 instead of HEVCProfileMain10 .
    • 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.
  • بازیگران:
    • Fix transient STATE_IDLE when transitioning between media items ( #245 ).
  • 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.

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 ).
  • Extractors:
    • Throw a ParserException instead of a NullPointerException 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 ).
  • صوتی:
    • Use the compressed audio format bitrate to calculate the min buffer size for AudioTrack in direct playbacks (passthrough).
  • متن:
    • Fix TextRenderer passing an invalid (negative) index to Subtitle.getEventTime if a subtitle file contains no cues.
    • SubRip: Add support for UTF-16 files if they start with a byte order mark.
  • Metadata:
    • 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 for MediaMetadata.folderType . The folder type will be deprecated in the next release.
  • داش:
    • Add full parsing for image adaptation sets, including tile counts ( #3752 ).
  • UI:
    • Fix the deprecated PlayerView.setControllerVisibilityListener(PlayerControlView.VisibilityListener) to ensure visibility changes are passed to the registered listener ( #229 ).
    • Fix the ordering of the center player controls in PlayerView when using a right-to-left (RTL) layout ( #227 ).
  • Session:
    • Add abstract SimpleBasePlayer to help implement the Player 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 the DefaultMediaNotificationProvider and use immutable lists for clarity ( #216 ).
    • Add onSetMediaItems callback listener to provide means to modify/set MediaItem 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 ).
  • Metadata:
    • 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 for MediaMetadata.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 the ImaServerSideAdInsertionMediaSource.AdsLoader.Builder to request focusing the skip button on TV devices and set it to true by default.
    • Add a method focusSkipButton() to the ImaServerSideAdInsertionMediaSource.AdsLoader to programmatically request to focus the skip button.
    • Bump IMA SDK version to 3.29.0.
  • 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 single MediaSource ( #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 calling seekToNext or seekToPrevious 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 ).
  • ساخت:
    • Enforce minimum compileSdkVersion to avoid compilation errors ( #10684 ).
    • Avoid publishing block when included in another gradle build.
  • Track selection:
    • Prefer other tracks to Dolby Vision if display does not support it. ( #8944 ).
  • دانلودها:
    • Fix potential infinite loop in ProgressiveDownloader caused by simultaneous download and playback with the same PriorityTaskManager ( #10570 ).
    • Make download notification appear immediately ( #183 ).
    • Limit parallel download removals to 1 to avoid excessive thread creation ( #10458 ).
  • ویدئو:
    • Try alternative decoder for Dolby Vision if display does not support it. ( #9794 ).
  • صوتی:
    • Use SingleThreadExecutor for releasing AudioTrack 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 to androidx.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 ).
  • Metadata:
    • MetadataRenderer can now be configured to render metadata as soon as they are available. Create an instance with MetadataRenderer(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 ).
  • داش:
    • Parse EventStream.presentationTimeOffset from manifests ( #10460 ).
  • UI:
    • Use current overrides of the player as preset in TrackSelectionDialogBuilder ( #10429 ).
  • Session:
    • Ensure commands are always executed in the correct order even if some require asynchronous resolution ( #85 ).
    • Add DefaultMediaNotificationProvider.Builder to build DefaultMediaNotificationProvider instances. The builder can configure the notification ID, the notification channel ID and the notification channel name used by the provider. Also, add method DefaultMediaNotificationProvider.setSmallIcon(int) to set the notifications small icon. ( #104 ).
    • Ensure commands sent before MediaController.release() are not dropped ( #99 ).
    • SimpleBitmapLoader can load bitmap from file:// 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:
    • Add H263 fragmented packet handling ( #119 ).
    • Add support for MP4A-LATM ( #162 ).
  • 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 identify CastPlayer when controlling playback with a MediaController ( #142 ).
  • ترانسفورماتور:
    • 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.

Version 1.0.0-beta02

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 with ExoPlayer.setShuffleOrder results in a call to Player.Listener#onTimelineChanged with reason=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 in DefaultMediaSourceFactory , which was non-functional in some cases ( #116 ).
  • Extractors:
    • Fix parsing of H265 short term reference picture sets ( #10316 ).
    • Fix parsing of bitrates from esds boxes ( #10381 ).
  • داش:
    • 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 in LeanbackAdapter ( 10420 ).
  • بازیگران:
    • Use the MediaItem that has been passed to the playlist methods as Window.mediaItem in CastTimeline ( #25 , #8212 ).
    • Support Player.getMetadata() and Listener.onMediaMetadataChanged() with CastPlayer ( #25 ).

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 with ExoPlayer.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 to MediaSource.Factory.setDrmSessionManagerProvider and MediaSource.Factory.setLoadErrorHandlingPolicy . Instances of DefaultDrmSessionManagerProvider and DefaultLoadErrorHandlingPolicy can be passed explicitly if required.
    • Add MediaItem.RequestMetadata to represent metadata needed to play media when the exact LocalConfiguration is not known. Also remove MediaMetadata.mediaUrl as this is now included in RequestMetadata .
    • Add Player.Command.COMMAND_SET_MEDIA_ITEM to enable players to allow setting a single item.
  • Track selection:
    • Flatten TrackSelectionOverrides class into TrackSelectionParameters , and promote TrackSelectionOverride to a top level class.
    • Rename TracksInfo to Tracks and TracksInfo.TrackGroupInfo to Tracks.Group . Player.getCurrentTracksInfo and Player.Listener.onTracksInfoChanged have also been renamed to Player.getCurrentTracks and Player.Listener.onTracksChanged . This includes 'un-deprecating' the Player.Listener.onTracksChanged method name, but with different parameter types.
    • Change DefaultTrackSelector.buildUponParameters and DefaultTrackSelector.Parameters.buildUpon to return DefaultTrackSelector.Parameters.Builder instead of the deprecated DefaultTrackSelector.ParametersBuilder .
    • Add DefaultTrackSelector.Parameters.constrainAudioChannelCountToDeviceCapabilities which is enabled by default. When enabled, the DefaultTrackSelector will prefer audio tracks whose channel count does not exceed the device output capabilities. On handheld devices, the DefaultTrackSelector 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, the DefaultTrackSelector will monitor for changes in the Spatializer properties and trigger a new track selection upon these. Devices with a television UI mode are excluded from these constraints and the format with the highest channel count will be preferred. To enable this feature, the DefaultTrackSelector instance must be constructed with a Context .
  • ویدئو:
    • Rename DummySurface to PlaceholderSurface .
    • Add AV1 support to the MediaCodecVideoRenderer.getCodecMaxInputSize .
  • صوتی:
    • Use LG AC3 audio decoder advertising non-standard MIME type.
    • Change the return type of AudioAttributes.getAudioAttributesV21() from android.media.AudioAttributes to a new AudioAttributesV21 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 mask AudioFormat.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 return CueGroup instead of List<Cue> .
    • SSA: Support OutlineColour style setting when BorderStyle == 3 (ie OutlineColour 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.
  • Extractors:
    • Add support for AVI ( #2092 ).
    • Matroska: Parse DiscardPadding for Opus tracks.
    • MP4: Parse bitrates from esds boxes.
    • Ogg: Allow duplicate Opus ID and comment headers ( #10038 ).
  • UI:
    • Fix delivery of events to OnClickListener s set on PlayerView in the case that useController=false ( #9605 ). Also fix delivery of events to OnLongClickListener for all view configurations.
    • Fix incorrectly treating a sequence of touch events that exit the bounds of PlayerView before ACTION_UP as a click ( #9861 ).
    • Fix PlayerView accessibility issue where tapping might toggle playback rather than hiding the controls ( #8627 ).
    • Rewrite TrackSelectionView and TrackSelectionDialogBuilder to work with the Player interface rather than ExoPlayer . This allows the views to be used with other Player 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 ).
  • داش:
    • Parse channel count from DTS AudioChannelConfiguration elements. This re-enables audio passthrough for DTS streams ( #10159 ).
    • Disallow passing null to DashMediaSource.Factory.setCompositeSequenceableLoaderFactory . Instances of DefaultCompositeSequenceableLoaderFactory can be passed explicitly if required.
  • HLS:
    • Fallback to chunkful preparation if the playlist CODECS attribute does not contain the audio codec ( #10065 ).
    • Disallow passing null to HlsMediaSource.Factory.setCompositeSequenceableLoaderFactory , HlsMediaSource.Factory.setPlaylistParserFactory , and HlsMediaSource.Factory.setPlaylistTrackerFactory . Instances of DefaultCompositeSequenceableLoaderFactory , DefaultHlsPlaylistParserFactory , or a reference to DefaultHlsPlaylistTracker.FACTORY can be passed explicitly if required.
  • Smooth Streaming:
    • Disallow passing null to SsMediaSource.Factory.setCompositeSequenceableLoaderFactory . Instances of DefaultCompositeSequenceableLoaderFactory can be passed explicitly if required.
  • RTSP:
    • Add RTP reader for H263 ( #63 ).
    • Add RTP reader for MPEG4 ( #35 ).
    • Add RTP reader for HEVC ( #36 ).
    • Add RTP reader for AMR. Currently only mono-channel, non-interleaved AMR streams are supported. Compound AMR RTP payload is not supported. ( #46 )
    • Add RTP reader for VP8 ( #47 ).
    • Add RTP reader for WAV ( #56 ).
    • Fix RTSP basic authorization header. ( #9544 ).
    • Stop checking mandatory SDP fields as ExoPlayer doesn't need them ( #10049 ).
    • Throw checked exception when parsing RTSP timing ( #10165 ).
    • Add RTP reader for VP9 ( #47 ).
    • Add RTP reader for OPUS ( #53 ).
  • Data sources:
    • Rename DummyDataSource to PlaceholderDataSource .
    • Workaround OkHttp interrupt handling.
  • Session:
    • Replace MediaSession.MediaItemFiller with MediaSession.Callback.onAddMediaItems to allow asynchronous resolution of requests.
    • Support setMediaItems(s) methods when MediaController connects to a legacy media session.
    • Remove MediaController.setMediaUri and MediaSession.Callback.onSetMediaUri . The same functionality can be achieved by using MediaController.setMediaItem and MediaSession.Callback.onAddMediaItems .
    • Forward legacy MediaController calls to play media to MediaSession.Callback.onAddMediaItems instead of onSetMediaUri .
    • Add MediaNotification.Provider and DefaultMediaNotificationProvider to provide customization of the notification.
    • Add BitmapLoader and SimpleBitmapLoader 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 to MediaSession.Callback , MediaLibrarySession.MediaLibrarySessionCallback to MediaLibrarySession.Callback and MediaSession.Builder.setSessionCallback to setCallback .
    • Fix NPE in MediaControllerImplLegacy ( #59 ).
    • Update session position info on timeline change( #51 ).
    • Fix NPE in MediaControllerImplBase after releasing controller ( #74 ).
  • 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 ).
  • Remove deprecated symbols:
    • Remove Player.Listener.onTracksChanged(TrackGroupArray, TrackSelectionArray) . Use Player.Listener.onTracksChanged(Tracks) instead.
    • Remove Player.getCurrentTrackGroups and Player.getCurrentTrackSelections . Use Player.getCurrentTracks instead. You can also continue to use ExoPlayer.getCurrentTrackGroups and ExoPlayer.getCurrentTrackSelections , although these methods remain deprecated.
    • Remove DownloadHelper DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_VIEWPORT and DEFAULT_TRACK_SELECTOR_PARAMETERS constants. Use getDefaultTrackSelectorParameters(Context) instead when possible, and DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_CONTEXT otherwise.
    • Remove constructor DefaultTrackSelector(ExoTrackSelection.Factory) . Use DefaultTrackSelector(Context, ExoTrackSelection.Factory) instead.
    • Remove Transformer.Builder.setContext . The Context should be passed to the Transformer.Builder constructor instead.

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 and MediaItem.SubtitleConfiguration.Builder.setId to prioritise the SubtitleConfiguration field and fall back to the Factory value if it's not set ( #10016 ).
  • 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 of DefaultRenderersFactory that override buildVideoRenderers() or buildAudioRenderers() can access the codec adapter factory and pass it to MediaCodecRenderer instances they create.
    • Propagate ICY header fields name and genre to MediaMetadata.station and MediaMetadata.genre respectively so that they reach the app via Player.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 from MediaCodec . ( #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 to queuedInputBufferCount .
    • Make SimpleExoPlayer.renderers private. Renderers can be accessed via ExoPlayer.getRenderer .
    • Updated some AnalyticsListener.EventFlags constant values to match values in Player.EventFlags .
    • Split AnalyticsCollector into an interface and default implementation to allow it to be stripped by R8 if an app doesn't need it.
  • 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 a TrackGroupArray . TrackGroup s can always be made distinguishable by setting an id in the TrackGroup 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 explicitly AudioCapabilities.DEFAULT_AUDIO_CAPABILITIES instead of null .
    • Allow customization of the AudioTrack buffer size calculation by injecting an AudioTrackBufferSizeProvider to DefaultAudioSink . ( #8891 ).
    • Retry AudioTrack creation if the requested buffer size was > 1MB. ( #9712 ).
  • Extractors:
    • WAV: Add support for RF64 streams ( #9543 ).
    • Fix incorrect parsing of H.265 SPS NAL units ( #9719 ).
    • Parse Vorbis Comments (including METADATA_BLOCK_PICTURE ) in Ogg Opus and Ogg Vorbis files.
  • متن:
    • Add a MediaItem.SubtitleConfiguration.id field which is propagated to the Format.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.
  • DRM:
    • Remove playbackLooper from DrmSessionManager.(pre)acquireSession . When a DrmSessionManager is used by an app in a custom MediaSource , the playbackLooper needs to be passed to DrmSessionManager.setPlayer instead.
  • 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:
    • Fix the color of the numbers in StyledPlayerView rewind and fastforward buttons when using certain themes ( #9765 ).
    • Correctly translate playback speed strings ( #9811 ).
  • داش:
    • Add parsed essential and supplemental properties to the Representation ( #9579 ).
    • Support the forced-subtitle track role ( #9727 ).
    • Stop interpreting the main track role as C.SELECTION_FLAG_DEFAULT .
    • Fix base URL exclusion logic for manifests that do not declare the DVB namespace ( #9856 ).
    • Support relative MPD.Location URLs ( #9939 ).
  • 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 ).
  • RTSP:
    • Provide a client API to override the SocketFactory used for any server connection ( #9606 ).
    • Prefer DIGEST authentication method over BASIC if both are present ( #9800 ).
    • Handle when RTSP track timing is not available ( #9775 ).
    • Ignore invalid RTP-Info header values ( #9619 ).
  • ترانسفورماتور:
    • 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 call setClearMediaItemsOnStop(false) on the connector.
  • Cast extension:
    • Fix bug that prevented CastPlayer from calling onIsPlayingChanged correctly ( #9792 ).
    • Support audio metadata including artwork with DefaultMediaItemConverter ( #9663 ).
  • FFmpeg extension:
    • Make build_ffmpeg.sh depend on LLVM's bin utils instead of GNU's ( #9933 ).
  • Android 12 compatibility:
    • Upgrade the Cast extension to depend on com.google.android.gms:play-services-cast-framework:20.1.0 . Earlier versions of play-services-cast-framework are not compatible with apps targeting Android 12, and will crash with an IllegalArgumentException when creating PendingIntent s ( #9528 ).
  • Remove deprecated symbols:
    • Remove Player.EventListener . Use Player.Listener instead.
    • Remove MediaSourceFactory#setDrmSessionManager , MediaSourceFactory#setDrmHttpDataSourceFactory , and MediaSourceFactory#setDrmUserAgent . Use MediaSourceFactory#setDrmSessionManagerProvider instead.
    • Remove MediaSourceFactory#setStreamKeys . Use MediaItem.Builder#setStreamKeys instead.
    • Remove MediaSourceFactory#createMediaSource(Uri) . Use MediaSourceFactory#createMediaSource(MediaItem) instead.
    • Remove setTag from DashMediaSource , HlsMediaSource and SsMediaSource . Use MediaItem.Builder#setTag instead.
    • Remove DashMediaSource#setLivePresentationDelayMs(long, boolean) . Use MediaItem.Builder#setLiveConfiguration and MediaItem.LiveConfiguration.Builder#setTargetOffsetMs to override the manifest, or DashMediaSource#setFallbackTargetLiveOffsetMs to provide a fallback value.
    • Remove (Simple)ExoPlayer.setThrowsWhenUsingWrongThread . Opting out of the thread enforcement is no longer possible.
    • Remove ActionFile and ActionFileUpgradeUtil . Use ExoPlayer 2.16.1 or before to use ActionFileUpgradeUtil to merge legacy action files into DefaultDownloadIndex .
    • Remove ProgressiveMediaSource#setExtractorsFactory . Use ProgressiveMediaSource.Factory(DataSource.Factory, ExtractorsFactory) constructor instead.
    • Remove ProgressiveMediaSource.Factory#setTag and, and ProgressiveMediaSource.Factory#setCustomCacheKey . Use MediaItem.Builder#setTag and MediaItem.Builder#setCustomCacheKey instead.
    • Remove DefaultRenderersFactory(Context, @ExtensionRendererMode int) and DefaultRenderersFactory(Context, @ExtensionRendererMode int, long) constructors. Use the DefaultRenderersFactory(Context) constructor, DefaultRenderersFactory#setExtensionRendererMode , and DefaultRenderersFactory#setAllowedVideoJoiningTimeMs instead.
    • Remove all public CronetDataSource constructors. Use CronetDataSource.Factory instead.
  • 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 (in com.google.android.exoplayer2.ext.flac package)
    • @FlacExtractor.Flags (in com.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

Support libraries for media use cases.
آخرین به روز رسانی انتشار پایدار کاندید را آزاد کنید نسخه بتا Alpha Release
13 نوامبر 2024 1.4.1 1.5.0-rc01 - -

اعلام وابستگی ها

To add a dependency on Media3, you must add the Google Maven repository to your project. Read Google's Maven repository for more information.

Add the dependencies for the artifacts you need in the build.gradle file for your app or module:

شیار

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.

نسخه 1.5

1.5.0-rc02 (2024-11-19)

androidx.media3:media3-*:1.5.0-rc02 is released.

Version 1.5.0-rc02 contains these commits .

This release includes the following changes since the 1.5.0-rc01 release :

  • Extractors:
    • Add AC-4 Level-4 ISO base media file format support ( #1265 ).
  • متن:
    • Fix garbled CEA-608 subtitles in content with more than one SEI message per sample.
    • Fix playback hanging on DASH multi-period streams when CEA-608 subtitles are enabled ( #1863 ).
    • Fix garbled CEA-608 subtitles in MP4 files that incorrectly mark every sample as a sync sample ( #1863 ).
  • برنامه نمایشی
    • Resolve the memory leaks in demo short-form app ( #1839 ).

1.5.0-rc01 (2024-11-13)

androidx.media3:media3-*:1.5.0-rc01 is released.

Version 1.5.0-rc01 contains these commits .

This release includes the following changes since the 1.5.0-beta01 release :

  • ExoPlayer:
    • Fix bug where playlist items or periods in multi-period DASH streams with durations that don't match the actual content could cause frame freezes at the end of the item ( #1698 ).
    • Add a setter to SntpClient to set the max elapsed time since the last update after which the client is re-initialized ( #1794 ).
  • Extractors:
    • Fix media duration parsing in mdhd box of MP4 files to handle -1 values ( #1819 ).
    • Add support for identifying h263 box in MP4 files for H.263 video ( #1821 ).
  • DataSource:
    • DataSourceContractTest : Assert that DataSource.getUri() returns the resolved URI (as documented). Where this is different to the requested URI, tests can indicate this using the new DataSourceContractTest.TestResource.Builder.setResolvedUri() method.
    • DataSourceContractTest : Assert that DataSource.getUri() and getResponseHeaders() return their 'open' value after a failed call to open() (due to a 'not found' resource) and before a subsequent close() call.
      • Overriding DataSourceContractTest.getNotFoundResources() allows test sub-classes to provide multiple 'not found' resources, and to provide any expected headers too. This allows to distinguish between HTTP 404 (with headers) and "server not found" (no headers).
  • متن:
    • Fix CEA-608 subtitles in H.264 MPEG-TS streams not being output (this was broken in 1.5.0-alpha01 by https://github.com/androidx/media/commit/03a205f220ecf7681f85f8a752227e3986e257ff).
    • Support CEA-608 subtitles in Dolby Vision content ( #1820 ).
  • RTSP Extension:
    • Fix crashing when parsing of RTP packets with header extensions ( #1225 ).

Version 1.5.0-beta01

30 اکتبر 2024

androidx.media3:media3-*:1.5.0-beta01 is released. Version 1.5.0-beta01 contains these commits .

  • Common Library:
    • Remove @DoNotInline annotations from manually out-of-lined inner classes designed to avoid runtime class verification failures . Recent versions of R8 now automatically out-of-line calls like these to avoid the runtime failures (so the manual out-of-lining is no longer required). All Gradle users of the library must already be a using a version of the Android Gradle Plugin that uses a version of R8 which does this, due to compileSdk = 35 . Users of the library with non-Gradle build systems will need to ensure their R8-equivalent shrinking/obfuscating step does a similar automatic out-of-lining process in order to avoid runtime class verification failures. This change has already been done in other AndroidX libraries .
  • ExoPlayer:
    • Fix MediaCodec.CryptoException sometimes being reported as an "unexpected runtime error" when MediaCodec is operated in asynchronous mode (default behaviour on API 31+).
    • Pass bufferedDurationUs instead of bufferedPositionUs with PreloadMediaSource.PreloadControl.onContinueLoadingRequested() . Also changes DefaultPreloadManager.Status.STAGE_LOADED_TO_POSITION_MS to DefaultPreloadManager.Status.STAGE_LOADED_FOR_DURATION_MS , apps then need to pass a value representing a specific duration from the default start position for which the corresponding media source has to be preloaded with this IntDef, instead of a position.
    • Add ForwardingRenderer implementation that forwards all method calls to another renderer ( 1703 ).
    • Add playlist preloading for the next item in the playlist. Apps can enable preloading by calling ExoPlayer.setPreloadConfiguration(PreloadConfiguration) accordingly. By default preloading is disabled. When opted-in and to not interfere with playback, DefaultLoadControl restricts preloading to start and continue only when the player is not loading for playback. Apps can change this behaviour by implementing LoadControl.shouldContinuePreloading() accordingly (like when overriding this method in DefaultLoadControl ). The default implementation of LoadControl disables preloading in case an app is using a custom implementation of LoadControl .
    • Add method MediaSourceEventListener.EventDispatcher.dispatchEvent() to allow invoking events of subclass listeners ( 1736 ).
    • Add DefaultPreloadManager.Builder that builds the DefaultPreloadManager and ExoPlayer instances with consistently shared configurations.
    • Remove Renderer[] parameter from LoadControl.onTracksSelected() as DefaultLoadControl implementation can retrieve the stream types from ExoTrackSelection[] .
    • Deprecated DefaultLoadControl.calculateTargetBufferBytes(Renderer[], ExoTrackSelection[]) and marked method as final to prevent overrides. The new DefaultLoadControl.calculateTargetBufferBytes(ExoTrackSelection[]) should be used instead.
    • Report MediaSourceEventListener events from secondary sources in MergingMediaSource . This will result in load start/error/cancelled/completed events being reported for sideloaded subtitles (those added with MediaItem.LocalConfiguration.subtitleConfigurations ), which may appear as duplicate load events emitted from AnalyticsListener .
    • Prevent subtitle & metadata errors from completely stopping playback. Instead the problematic track is disabled and playback of the remaining tracks continues ( #1722 ).
      • In new subtitle handling (during extraction), associated parse (eg invalid subtitle data) and load errors (eg HTTP 404) are emitted via onLoadError callbacks.
      • In legacy subtitle handling (during rendering), only associated load errors are emitted via onLoadError callbacks while parse errors are silently ignored (this is pre-existing behaviour).
  • ترانسفورماتور:
    • Make setting the image duration using MediaItem.Builder.setImageDurationMs mandatory for image export.
    • Add export support for gaps in sequences of audio EditedMediaItems.
  • Track Selection:
    • DefaultTrackSelector : Prefer object-based audio over channel-based audio when other factors are equal.
  • Extractors:
    • Fix preroll sample handling for non-keyframe media start positions when processing edit lists in MP4 files ( #1659 ).
    • Improved frame rate calculation by using media duration from the mdhd box in Mp4Extractor and FragmentedMp4Extractor ( #1531 ).
    • Fix incorrect scaling of media_time in MP4 edit lists. While segment_duration was already correctly scaled using the movie timescale, media_time is now properly scaled using the track timescale, as specified by the MP4 format standard ( #1792 ).
    • Handle out-of-order frames in endIndices calculation for MP4 with edit list ( #1797 ).
  • صوتی:
    • Fix pop sounds that may occur during seeks.
    • Fix truncation error accumulation for Sonic's time-stretching/pitch-shifting algorithm.
    • Fix bug in SpeedChangingAudioProcessor that causes dropped output frames.
  • ویدئو:
    • Add workaround for a device issue on Galaxy Tab S7 FE that causes 60fps secure H264 streams to be marked as unsupported ( #1619 ).
    • Add workaround for codecs that get stuck after the last sample without returning an end-of-stream signal.
  • متن:
    • Ensure WebVTT in HLS with very large subtitle timestamps (which overflow a 64-bit long when represented as microseconds and multiplied by the 90,000 MPEG timebase) are displayed ( #1763 ).
  • Metadata:
    • Assign the C.TRACK_TYPE_METADATA type to tracks containing icy or vnd.dvb.ait content.
  • DRM:
    • Fix IllegalStateException from DefaultDrmSession.requiresSecureDecoder after opening a DRM session failed. This issue was introduced in 1.5.0-alpha01 .
  • Muxers:
  • IMA extension:
    • Fix bug where server-side inserted DAI streams without a preroll can result in an ArrayIndexOutOfBoundsException when playing past the last midroll ( #1741 ).
  • Session:
    • Fix bug that caused custom commands sent from a MediaBrowser being dispatched to the MediaSessionCompat.Callback instead of the MediaBrowserServiceCompat variant of the method when connected to a legacy service. This prevented the MediaBrowser to receive the actual return value sent back by the legacy service ( #1474 ).
    • Handle IllegalArgumentException thrown by devices of certain manufacturers when setting the broadcast receiver for media button intents ( #1730 ).
    • Add command buttons for media items. This adds the Media3 API for what was known as Custom browse actions with the legacy library with MediaBrowserCompat . Note that with Media3 command buttons for media items are available for both, MediaBrowser and MediaController . See Custom Browse actions of AAOS .
    • Fix bug where a Media3 controller was sometimes unable to let a session app start a foreground service after requesting play() .
    • Restrict CommandButton.Builder.setIconUri to only accept content Uris.
    • Pass connection hints of a Media3 browser to the initial MediaBrowserCompat when connecting to a legacy MediaBrowserCompat . The service can receive the connection hints passed in as root hints with the first call to onGetRoot() .
    • Fix bug where a MediaBrowser connected to a legacy browser service, didn't receive an error sent by the service after the browser has subscribed to a parentid .
    • Improve interoperability behavior, so that a Media3 browser that is connected to a legacy MediaBrowserService doesn't request the children of a parentId twice when subscribing to a parent.
  • UI:
    • Make the stretched/cropped video in PlayerView -in-Compose- AndroidView workaround opt-in, due to issues with XML-based shared transitions. Apps using PlayerView inside AndroidView need to call PlayerView.setEnableComposeSurfaceSyncWorkaround in order to opt-in ( #1237 , #1594 ).
    • Add setFullscreenButtonState to PlayerView to allow updates of fullscreen button's icon on demand, ie out-of-band and not reactively to a click interaction ( #1590 , #184 ).
    • Fix bug where the "None" choice in the text selection is not working if there are app-defined text track selection preferences.
  • Smooth Streaming Extension:
    • Fix a Bad magic number for Bundle error when playing SmoothStreaming streams with text tracks ( #1779 ).
  • RTSP Extension:
    • Fix user info removal for URLs that contain encoded @ characters ( #1138 ).
  • Decoder Extensions (FFmpeg, VP9, AV1, etc.):
    • Add 16 KB page support for decoder extensions on Android 15 ( #1685 ).
  • Cast Extension:
    • Stop cleaning the timeline after the CastSession disconnects, which enables the sender app to resume playback locally after a disconnection.
    • Populate CastPlayer's DeviceInfo when a Context is provided. This enables linking the MediaSession to a RoutingSession , which is necessary for integrating Output Switcher ( #1056 ).
  • Remove deprecated symbols:
    • Remove deprecated DefaultEncoderFactory constructors. Use DefaultEncoderFactory.Builder instead.

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 by getPlaylist() method.
    • Add override for SimpleBasePlayer.State.Builder.setPlaylist() to directly specify a Timeline and current Tracks and Metadata 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 to Player.Events to the media3-common-ktx library.
  • ExoPlayer:
    • MediaCodecRenderer.onProcessedStreamChange() can now be called for every media item. Previously it was not called for the first one. Use MediaCodecRenderer.experimentalEnableProcessedStreamChangedAtStart() to enable this.
    • Add PreloadMediaSource.PreloadControl.onPreloadError to allow PreloadMediaSource.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 a Surface .
    • ImageAssetLoader reports unsupported input via AssetLoader.onError instead of throwing an IllegalStateException .
  • Extractors:
    • Allow Mp4Extractor and FragmentedMp4Extractor 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 ).
  • DataSource:
    • Update HttpEngineDataSource to allow use starting at version S extension 7 instead of API level 34 ( #1262 ).
  • صوتی:
    • 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 a null Surface in configure and calls to a new method detachOutputSurface to remove a previously set Surface if the codec supports this ( MediaCodecInfo.detachedSurfaceSupported ).
    • Use MediaCodecAdapter supplied pixel aspect ratio values if provided when processing onOutputFormatChanged ( #1371 ).
  • متن:
  • تصویر:
    • Add ExternallyLoadedImageDecoder for simplified integration with external image loading libraries like Glide or Coil.
  • DataSource:
    • Add FileDescriptorDataSource , a new DataSource that can be used to read from a FileDescriptor ( #3757 ).
  • اثر:
    • Add DefaultVideoFrameProcessor workaround for minor SurfaceTexture 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 with Transformer is faster.
  • IMA extension:
    • Fix bug where clearing the playlist may cause an ArrayIndexOutOfBoundsException in ImaServerSideAdInsertionMediaSource .
  • 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 a ForegroundServiceDidNotStartInTimeException ( #1528 ).
  • 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.
  • 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 a Context is provided. This enables linking the MediaSession to a RoutingSession , 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.
  • Remove deprecated symbols:
    • Remove deprecated Player.hasPrevious , Player.hasPreviousWindow() . Use Player.hasPreviousMediaItem() instead.
    • Remove deprecated Player.previous() method. Use Player.seekToPreviousMediaItem() instead.
    • Remove deprecated DrmSessionEventListener.onDrmSessionAcquired method.

نسخه 1.4.0

نسخه 1.4.1

27 آگوست 2024

androidx.media3:media3-*:1.4.1 is released. Version 1.4.1 contains these commits .

  • ExoPlayer:
    • Handle preload callbacks asynchronously in PreloadMediaSource ( #1568 ).
    • Allow playback regardless of buffered duration when loading fails ( #1571 ).
  • Extractors:
    • MP3: Fix Searched too many bytes error by correctly ignoring trailing non-MP3 data based on the length field in an Info frame ( #1480 ).
  • متن:
    • TTML: Fix handling of percentage tts:fontSize values to ensure they are correctly inherited from parent nodes with percentage tts:fontSize values.
    • Fix IndexOutOfBoundsException in LegacySubtitleUtil due to incorrectly handling the case of the requested output start time being greater than or equal to the final event time in the Subtitle ( #1516 ).
  • 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 framework MediaDrm.requiresSecureDecoder method ( #1603 ).
  • اثر:
    • Add a release() method to GlObjectsProvider .
  • Session:
    • Transform a double-tap of KEYCODE_HEADSETHOOK into a 'seek to next' action, as documented ( #1493 ).
    • Handle KEYCODE_HEADSETHOOK as a 'play' command in MediaButtonReceiver when deciding whether to ignore it to avoid a ForegroundServiceDidNotStartInTimeException ( #1581 ).
  • RTSP Extension:
    • Skip invalid Media Descriptions in SDP parsing ( #1087 ).

نسخه 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() and SimpleBasePlayer.handleSeek() methods instead of ignoring them. If you are implementing these methods in a custom player, you may need to handle these additional calls with mediaItemIndex == 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-image MediaItem (as documented).
    • Add Format.customData to store app-provided custom information about Format instances.
  • ExoPlayer:
    • Add BasePreloadManager which coordinates the preloading for multiple sources based on the priorities defined by their rankingData . Customization is possible by extending this class. Add DefaultPreloadManager which uses PreloadMediaSource to preload media samples of the sources into memory, and uses an integer rankingData that indicates the index of an item on the UI.
    • Add PlayerId to most methods of LoadControl to enable LoadControl implementations to support multiple players.
    • Remove Buffer.isDecodeOnly() and C.BUFFER_FLAG_DECODE_ONLY . There is no need to set this flag as renderers and decoders will decide to skip buffers based on timestamp. Custom Renderer implementations should check if the buffer time is at least BaseRenderer.getLastResetPositionUs() to decide whether a sample should be shown. Custom SimpleDecoder implementations can check isAtLeastOutputStartTimeUs() if needed or mark other buffers with DecoderOutputBuffer.shouldBeSkipped to skip them.
    • Allow a null value to be returned by TargetPreloadStatusControl.getTargetPreloadStatus(T) to indicate not to preload a MediaSource with the given rankingData .
    • Add remove(MediaSource) to BasePreloadManager .
    • Add reset() to BasePreloadManager to release all the holding sources while keep the preload manager instance.
    • Add ExoPlayer.setPriority() (and Builder.setPriority() ) to define the priority value used in PriorityTaskManager 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 the DefaultPreloadManager and the custom PreloadMediaSource.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 to PreloadMediaSource 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() to onSourcePrepared() and onPrepared() to onTracksSelected() in PreloadMediaSource.PreloadControl . Also rename the IntDefs in DefaultPreloadManager.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() . A Renderer can implement this method to return to ExoPlayer the duration that playback must advance for the renderer to progress. If ExoPlayer is set with experimentalSetDynamicSchedulingEnabled() then ExoPlayer 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 by MediaCodecRenderer . MediaCodecRenderer will signal ExoPlayer when receiving these callbacks and if ExoPlayer is set with experimentalSetDynamicSchedulingEnabled() , then ExoPlayer 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 whether Exoplayer.release() has been called.
    • Add ExoPlayer.Builder.setMaxSeekToPreviousPositionMs() to configure the maximum position for which seekToPrevious() 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 in ExoPlayer.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 audioConversionProcess and videoConversionProcess to ExportResult 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 with androidx.media3.muxer.Muxer and remove androidx.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 use DefaultDecoderFactory.listener instead. In case of a codec exception, codec details will be available in the ExportException.codecInfo .
  • 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 HTTP Content-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 the Info frame, which may be artificially small, eg PCUT 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 calling AudioTrack.stop() so that AudioTrack.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 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) and TextRenderer.experimentalSetLegacyDecodingEnabled(true) . See the docs on customization for how to plumb these components into an ExoPlayer 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 implement SubtitleParser instead (and SubtitleParser.Factory instead of SubtitleDecoderFactory ).
    • 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 that rowLock and columnLock 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 the 1.3.0-rc01 release. This is now fixed, so the change is present again.
    • CEA-708: Avoid duplicate newlines being added by ExoPlayer's naive handling of the 'set pen location' command ( #1315 ).
    • Fix an IllegalArgumentException from LegacySubtitleUtil when a WebVTT subtitle sample contains no cues, eg as part of a DASH stream ( #1516 ).
  • Metadata:
    • Fix mapping of MP4 to ID3 sort tags. Previously the 'album sort' ( soal ), 'artist sort' ( soar ) and 'album artist sort' ( soaa ) MP4 tags were wrongly mapped to the TSO2 , TSOA and TSOP ID3 tags ( #1302 ).
    • Fix reading of MP4 (/iTunes) numeric gnre (genre) and tmpo (tempo) tags when the value is more than one byte long.
    • Propagate ID3 TCON frame to MediaMetadata.genre ( #1305 ).
  • تصویر:
    • Add support for non-square DASH thumbnail grids ( #1300 ).
    • Add support for AVIF for API 34+.
    • Allow null as parameter for ExoPlayer.setImageOutput() to clear a previously set ImageOutput .
  • DataSource:
    • Implement support for android.resource://package/id raw resource URIs where package 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 the DataSpec constructors. This parameter was already annotated to be non-null.
    • Allow ByteArrayDataSource to resolve a URI to a byte array during open() , instead of being hard-coded at construction ( #1405 ).
  • DRM:
    • Allow setting a LoadErrorHandlingPolicy on DefaultDrmSessionManagerProvider ( #1271 ).
  • اثر:
    • Support multiple speed changes within the same EditedMediaItem or Composition in SpeedChangeEffect .
    • 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 using OverlaySettings.Builder.setOverlayFrameAnchor() , flip their x and y values by multiplying them by -1 .
    • Fix bug where TimestampWrapper crashes when used with ExoPlayer#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 with OverlaySettings.Builder.setHdrLuminanceMultiplier() .
  • IMA extension:
    • Promote API that is required for apps to play DAI ad streams to stable.
    • Add replaceAdTagParameters(Map <String, String>) to ImaServerSideAdInsertionMediaSource.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 using data:// ad tag URIs ( #700 ).
  • Session:
    • Change default of CommandButton.enabled to true 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 in onTaskRemoved() ( #1219 ).
    • Add MediaSessionService.pauseAllPlayersAndStopSelf() that conveniently allows to pause playback of all sessions and call stopSelf() to terminate the lifecycle of the MediaSessionService .
    • 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 to MediaDescriptionCompat , 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 (see MediaSession.getMediaNotificationControllerInfo() ), the custom error is used to update the PlaybackState 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 in SessionResult and LibraryResult 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's PlaybackStateCompat.getExtras() .
    • Map fatal and non-fatal errors to and from the platform session. A PlaybackException is mapped to a fatal error state of the PlaybackStateCompat . A SessionError sent to the media notification controller with MediaSession.sendError(ControllerInfo, SessionError) is mapped to a non-fatal error in PlaybackStateCompat which means that error code and message are set but the state of the platform session remains different to STATE_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 with AcceptedResultBuilder.setSessionActivivty(PendingIntent) . Once connected, the session activity can be updated with MediaSession.setSessionActivity(ControllerInfo, PendingIntent) .
    • Improve error replication of calls to MediaLibrarySession.Callback . Error replication can now be configured by using MediaLibrarySession.Builder.setLibraryErrorReplicationMode() for choosing the error type or opt-ing out of error replication which is on by default.
  • UI:
    • Add image display support to PlayerView when connected to an ExoPlayer ( #1144 ).
    • Add customization of various icons in PlayerControlView through xml attributes to allow different drawables per PlayerView instance, rather than global overrides ( #1200 ).
    • Work around a platform bug causing stretched/cropped video when using SurfaceView inside a Compose AndroidView on API 34 ( #1237 ).
  • دانلودها:
    • Ensure that DownloadHelper does not leak unreleased Renderer instances, which can eventually result in an app crashing with IllegalStateException: Too many receivers, total of 1000, registered for pid ( #1224 ).
  • Cronet Extension:
    • Fix SocketTimeoutException in CronetDataSource . 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).
  • HLS Extension:
    • Fix bug where pending EMSG samples waiting for a discontinuity were delegated in HlsSampleStreamWrapper with an incorrect offset causing an IndexOutOfBoundsException or an IllegalArgumentException ( #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 and IllegalArgumentException .
    • 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 ).
  • DASH Extension:
    • Fix bug where re-preparing a multi-period live stream can throw an IndexOutOfBoundsException ( #1329 ).
    • Add support for dashif:Laurl license urls ( #1345 ).
  • Cast Extension:
    • Fix bug that converted the album title of the MediaQueueItem to the artist in the Media3 media item ( #1255 ).
  • Test Utilities:
    • Implement onInit() and onRelease() in FakeRenderer .
    • Change TestPlayerRunHelper.runUntil()/playUntil() methods to fail on nonfatal errors (eg those reported to AnalyticsListener.onVideoCodecError() ). Use the new TestPlayerRunHelper.run(player).ignoringNonFatalErrors().untilXXX() method chain to disable this behavior.
  • Demo app:
    • Use DefaultPreloadManager in the short form demo app.
    • Allow setting repeat mode with Intent arguments from command line ( #1266 ).
    • Use HttpEngineDataSource as the HttpDataSource when supported by the device.
  • Remove deprecated symbols:
    • Remove CronetDataSourceFactory . Use CronetDataSource.Factory instead.
    • Remove some DataSpec constructors. Use DataSpec.Builder instead.
    • Remove setContentTypePredicate(Predicate) method from DefaultHttpDataSource , OkHttpDataSource and CronetDataSource . Use the equivalent method on each XXXDataSource.Factory instead.
    • Remove OkHttpDataSource constructors and OkHttpDataSourceFactory . Use OkHttpDataSource.Factory instead.
    • Remove PlayerMessage.setHandler(Handler) . Use setLooper(Looper) instead.
    • Remove Timeline.Window.isLive field. Use the isLive() method instead.
    • Remove DefaultHttpDataSource constructors. Use DefaultHttpDataSource.Factory instead.
    • Remove DashMediaSource.DEFAULT_LIVE_PRESENTATION_DELAY_MS . Use DashMediaSource.DEFAULT_FALLBACK_TARGET_LIVE_OFFSET_MS instead.
    • Remove MediaCodecInfo.isSeamlessAdaptationSupported(Format, Format, boolean) . Use MediaCodecInfo.canReuseCodec(Format, Format) instead.
    • Remove DrmSessionManager.DUMMY and getDummyDrmSessionManager() method. Use DrmSessionManager.DRM_UNSUPPORTED instead.
    • Remove AnalyticsListener.onAudioInputFormatChanged(EventTime, Format) , AnalyticsListener.onVideoInputFormatChanged(EventTime, Format) , AudioRendererEventListener.onAudioInputFormatChanged(Format) , VideoRendererEventListener.onVideoInputFormatChanged(Format) . Use the overloads that take a DecoderReuseEvaluation instead.
    • Remove RendererSupport.FormatSupport IntDef and FORMAT_HANDLED , FORMAT_EXCEEDS_CAPABILITIES , FORMAT_UNSUPPORTED_DRM , FORMAT_UNSUPPORTED_SUBTYPE , FORMAT_UNSUPPORTED_TYPE constants. Use the equivalent IntDef and constants in androidx.media3.common.C instead (eg C.FORMAT_HANDLED ).
    • Remove Bundleable interface. This includes removing all Bundleable.Creator<Foo> CREATOR constant fields. Callers should use the Bundle toBundle() and static Foo fromBundle(Bundle) methods on each type instead.

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 .

نسخه 1.3.0

نسخه 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.
  • 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 for DefaultVideoFrameProcessor.Factory.Builder.build() ( #1187 ).
  • ترانسفورماتور:
    • Add workaround for exception thrown due to MediaMuxer not supporting negative presentation timestamps before API 30.
  • 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 as XING and VBRI .
    • 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 from WebvttParser.parse ( #1177 ).
  • DRM:
    • Work around a NoSuchMethodError which can be thrown by the MediaDrm framework instead of ResourceBusyException or NotProvisionedException on some Android 14 devices ( #1145 ).
  • اثر:
    • Improved PQ to SDR tone-mapping by converting color spaces.
  • Session:
    • Fix issue where the current position jumps back when the controller replaces the current item ( #951 ).
    • Fix issue where MediaMetadata with just non-null extras is not transmitted between media controllers and sessions ( #1176 ).
  • UI:
    • Fallback to include audio track language name if Locale cannot identify a display name ( #988 ).
  • DASH Extension:
    • Populate all Label elements from the manifest into Format.labels ( #1054 ).
  • 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 .

نسخه 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 where package 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 single Uri in AdPlaybackState .
    • 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 and artworkData in MediaMetadata.Builder.populate(MediaMetadata) when at least one of them is non-null ( #964 ).
  • ExoPlayer:
    • Add PreloadMediaSource and PreloadMediaPeriod 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 the Timeline , 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 implementing PreloadMediaSource.PreloadControl and set the preloaded source to the player for playback.
    • Add ExoPlayer.setImageOutput that allows apps to set ImageRenderer.ImageOutput .
    • DefaultRenderersFactory now provides an ImageRenderer to the player by default with null ImageOutput and ImageDecoder.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 , an HttpDataSource 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 custom CompositeSequenceableLoaderFactory .
    • Fix issue where repeating the same time causes metadata from this item to be cleared ( #1007 ).
    • Rename experimentalSetSubtitleParserFactory methods on BundledChunkExtractor.Factory and DefaultHlsExtractorFactory to setSubtitleParserFactory and disallow passing null . Use the new experimentalParseSubtitlesDuringExtraction(boolean) methods to control parsing behaviour.
    • Add support for customising the SubtitleParser.Factory used during extraction. This can be achieved with MediaSource.Factory.setSubtitleParserFactory() .
    • Add source prefix to all Format.id fields generated from MergingMediaSource . This helps to identify which source produced a Format ( #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 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 is false which means selecting a video track is prioritized.
  • Extractors:
    • Add additional AV1C parsing to MP4 extractor to retrieve ColorInfo.colorSpace , ColorInfo.colorTransfer , and ColorInfo.colorRange values ( #692 ).
    • MP3: Use constant bitrate (CBR) seeking for files with an Info header (the CBR equivalent of the Xing header). Previously we used the seek table from the Info 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 ).
  • صوتی:
    • Improve silence skipping algorithm with smooth volume ramp; retained minimal silence and more natural silence durations ( #7423 ).
    • Report the skipped silence more deterministically ( #1035 ).
  • ویدئو:
    • Change the MediaCodecVideoRenderer constructor that takes a VideoFrameProcessor.Factory argument and replace it with a constructor that takes a VideoSinkProvider argument. Apps that want to inject a custom VideoFrameProcessor.Factory can instantiate a CompositingVideoSinkProvider that uses the custom VideoFrameProcessor.Factory and pass the video sink provider to MediaCodecVideoRenderer .
  • متن:
    • Fix serialization of bitmap cues to resolve Tried to marshall a Parcel that contained Binder objects error when using DefaultExtractorsFactory.setTextTrackTranscodingEnabled ( #836 ).
    • CEA-708: Ignore rowLock value. The CEA-708-E S-2023 spec states that rowLock and columnLock 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).
  • تصویر:
    • Add support for DASH thumbnails. Grid images are cropped and individual thumbnails are provided to ImageOutput close to their presentation times.
  • DRM:
  • 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 a Context instead of a MediaLibraryService .
  • 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 ).
  • 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.
  • Demo app:
    • Add a shortform demo module to demo the usage of PreloadMediaSource with the short-form content use case.

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 .

نسخه 1.2.0

نسخه 1.2.1

9 ژانویه 2024

  • ExoPlayer:
    • Fix issue where manual seeks outside of the LiveConfiguration.min/maxOffset range keep adjusting the offset back to min/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 for bufferedDurationUs from chunk sources, resulting in an IllegalArgumentException ( #888 ).
  • ترانسفورماتور:
    • 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 ).
  • صوتی:
    • Fix handling of EOS for SilenceSkippingAudioProcessor when called multiple times ( #712 ).
  • ویدئو:
    • Add workaround for a device issue on Galaxy Tab S7 FE, Chromecast with Google TV, and Lenovo M10 FHD Plus that causes 60fps AVC streams to be marked as unsupported ( #693 ).
  • Metadata:
    • Fix bug where 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.
  • 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.
  • Session:
    • Put the custom keys and values in MediaMetadataCompat to MediaMetadata.extras and MediaMetadata.extras to MediaMetadataCompat ( #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 ).
  • UI:
    • Fix issue where forward and rewind buttons are not visible when used with Material Design in a BottomSheetDialogFragment ( #511 ).
    • Fix issue where the numbers in the fast forward button of the PlayerControlView were misaligned ( #547 ).
  • DASH Extension:
    • Parse "f800" as channel count of 5 for Dolby in DASH manifest ( #688 ).
  • Decoder Extensions (FFmpeg, VP9, AV1, MIDI, etc.):
    • MIDI: Fix issue where seeking forward skips the Program Change events ( #704 ).
    • Migrate to FFmpeg 6.0 and update supported NDK to r26b ( #707 , #867 ).
  • Cast Extension:
    • Sanitize creation of a Timeline to not crash the app when loading media fails on the cast device ( #708 ).

نسخه 1.2.0

15 نوامبر 2023

  • Common Library:
    • Add a @Nullable Throwable parameter to the methods in the Log.Logger interface. The message parameter to these methods no longer contains any information about the Throwable passed to the Log.{d,i,w,e}() methods, so implementations will need to manually append this information if desired (possibly using Logger.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 and SimpleDecoder 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 using PlayerView.setShowPlayButtonIfPlaybackIsSuppressed(false) or MediaSession.Builder.setShowPlayButtonIfPlaybackIsSuppressed(false) ( #11213 ).
    • Upgrade androidx.annotation:annotation-experimental to 1.3.1 to fix https://issuetracker.google.com/251172715.
    • Move ExoPlayer.setAudioAttributes to the Player interface.
  • 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 as Player.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 and MediaSource.updateMediaItem to accept MediaItem updates after creation via Player.replaceMediaItem(s) .
    • Allow MediaItem updates for all MediaSource classes provided by the library via Player.replaceMediaItem(s) ( #33 , #9978 ).
    • Rename MimeTypes.TEXT_EXOPLAYER_CUES to MimeTypes.APPLICATION_MEDIA3_CUES .
    • Add PngExtractor that sends and reads a whole PNG file into the TrackOutput as one sample.
    • Enhance SequenceableLoader.continueLoading(long) method in the SequenceableLoader interface to SequenceableLoader.continueLoading(LoadingInfo loadingInfo) . LoadingInfo contains additional parameters, including playbackSpeed and lastRebufferRealtimeMs in addition to the existing playbackPositionUs .
    • Enhance ChunkSource.getNextChunk(long, long, List, ChunkHolder) method in the ChunkSource interface to ChunkSource.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 in ExperimentalBandwidthMeter ( #612 ).
    • Add MediaPeriodId parameter to CompositeMediaSource.getMediaTimeForChildMediaTime .
    • Support ClippingMediaSource (and other sources with period/window time offsets) in ConcatenatingMediaSource2 ( #11226 ).
    • Change BaseRenderer.onStreamChanged() to also receive a MediaPeriodId argument.
  • ترانسفورماتور:
    • Parse EXIF rotation data for image inputs.
    • Remove TransformationRequest.HdrMode annotation type and its associated constants. Use Composition.HdrMode and its associated constants instead.
    • Simplify the OverlaySettings to fix rotation issues.
    • Changed frameRate and durationUs parameters of SampleConsumer.queueInputBitmap to TimestampIterator .
  • Track Selection:
    • Add DefaultTrackSelector.Parameters.allowAudioNonSeamlessAdaptiveness to explicitly allow or disallow non-seamless adaptation. The default stays at its current behavior of true .
  • 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 . Changed projectionPosePitch to projectionPoseRoll ( #461 ).
    • Remove the assumption that Extractor instances can be directly inspected with instanceof . If you want runtime access to the implementation details of an Extractor you must first call Extractor.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 a DefaultAudioOffloadSupportProvider . It returns the new AudioOffloadSupport that contains isFormatSupported , isGaplessSupported , and isSpeedChangeSupported .
    • Add AudioSink.setOffloadMode() through which the offload configuration on the audio sink is configured. Default is AudioSink.OFFLOAD_MODE_DISABLED .
    • Offload can be enabled through setAudioOffloadPreference in TrackSelectionParameters . 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 to AUDIO_OFFLOAD_MODE_PREFERENCE_REQUIRED , then the DefaultTrackSelector 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 from DefaultRenderersFactory.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 and AudioOffloadListener.onExperimentalOffloadSchedulingEnabledChanged .
    • Renamed onExperimentalSleepingForOffloadChanged as onSleepingForOffloadChanged and onExperimentalOffloadedPlayback as onOffloadedPlayback .
    • Move audio offload mode related TrackSelectionParameters interfaces and definitions to an inner AudioOffloadPreferences class.
    • Add onAudioTrackInitialized and onAudioTrackReleased callbacks to AnalyticsListener , AudioRendererEventListener and AudioSink.Listener .
    • Fix DTS Express audio buffer underflow issue ( #650 ).
    • Fix bug where the capabilities check for E-AC3-JOC throws an IllegalArgumentException ( #677 ).
  • ویدئو:
    • Allow MediaCodecVideoRenderer to use a custom VideoFrameProcessor.Factory .
    • Fix bug where the first frame couldn't be rendered if the audio stream starts with negative timestamps ( #291 ).
  • متن:
    • Remove ExoplayerCuesDecoder . Text tracks with sampleMimeType = application/x-media3-cues are now directly handled by TextRenderer without needing a SubtitleDecoder instance.
  • Metadata:
    • 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 implement VideoFrameProcessor.Listener#onInputStreamRegistered() .
    • Changed frameRate and durationUs parameters of VideoFrameProcessor.queueInputBitmap to TimestampIterator .
  • 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 in DefaultMediaNotificationProvider ( #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 legacy MediaSessionCompat .
    • 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 and notifyChildrenChanged() 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 the queue button in the UI of Android Auto is not displayed ( #339 ).
    • Use DataSourceBitmapLoader by default instead of SimpleBitmapLoader ( #271 , #327 ).
    • Add MediaSession.Callback.onMediaButtonEvent(Intent) that allows apps to override the default media button event handling.
  • UI:
    • Add a Player.Listener implementation for Wear OS devices that handles playback suppression due to Player.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).
  • دانلودها:
    • Declare "data sync" foreground service type for DownloadService for Android 14 compatibility. When using this service, the app also needs to add dataSync as foregroundServiceType in the manifest and add the FOREGROUND_SERVICE_DATA_SYNC permission ( #11239 ).
  • 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 ).
  • 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 over C.BUFFER_FLAG_DECODE_ONLY that will be deprecated.
    • Add Decoder.setOutputStartTimeUs and SimpleDecoder.isAtLeastOutputStartTimeUs to allow decoders to drop decode-only samples before the start time. This should be preferred to Buffer.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 ).
  • Test Utilities:
    • Make TestExoPlayerBuilder and FakeClock compatible with Espresso UI tests and Compose UI tests. This fixes a bug where playback advances non-deterministically during Espresso or Compose view interactions.
  • Remove deprecated symbols:
    • Remove TransformationRequest.Builder.setEnableRequestSdrToneMapping(boolean) and TransformationRequest.Builder.experimental_setEnableHdrEditing(boolean) . Use Composition.Builder.setHdrMode(int) and pass the Composition to Transformer.start(Composition, String) instead.
    • Remove deprecated DownloadNotificationHelper.buildProgressNotification method, use a non deprecated method that takes a notMetRequirements parameter instead.

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 .

نسخه 1.1.0

نسخه 1.1.1

16 آگوست 2023

  • Common Library:
    • Remove accidentally added multidex dependency from all modules ( #499 ).
  • ExoPlayer:
    • Fix issue in PlaybackStatsListener where spurious PlaybackStats 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 a bug where Player.getState() never transitioned to STATE_ENDED when playing very short files ( #538 ).
  • 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 in MediaSession.Callback.onConnect by using an AcceptedResultBuilder to make sure the custom layout is available to the controller when connection completes.
    • Fix cases where MediaLibraryServiceLegacyStub sent an error to a Result that didn't support this which produced an UnsupportedOperationException ( #78 ).
    • Fix the way PlayerWrapper creates a VolumeProviderCompat by determining volumeControlType through both legacy commands ( COMMAND_ADJUST_DEVICE_VOLUME and COMMAND_SET_DEVICE_VOLUME ) and new commands ( COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS and COMMAND_SET_DEVICE_VOLUME_WITH_FLAGS ) ( #554 ).

نسخه 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 for DeviceInfo 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) and setDeviceVolume(int, int)
      • increaseDeviceVolume(int) and increaseDeviceVolume(int, int)
      • decreaseDeviceVolume(int) and decreaseDeviceVolume(int, int)
    • Add FilteringMediaSource that allows to filter available track types from a MediaSource .
    • 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 , and sid , 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.
    • 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 using Effect during video playback.
    • Update SampleQueue to store sourceId as a long rather than an int . This changes the signatures of public methods SampleQueue.sourceId and SampleQueue.peekSourceId .
    • Add parameters to LoadControl methods shouldStartPlayback and onTracksSelected that allow associating these methods with the relevant MediaPeriod .
    • 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) and BaseMediaSource.createEventDispatcher(..., long mediaTimeOffsetMs) . The variant of the methods without the mediaTimeOffsetUs can be called instead. Note that even for the deprecated variants, the offset is not anymore added to startTimeUs and endTimeUs of the MediaLoadData objects that are dispatched by the dispatcher.
    • Rename ExoTrackSelection.blacklist to excludeTrack and isBlacklisted to isTrackExcluded .
    • Fix inconsistent behavior between ExoPlayer.setMediaItem(s) and addMediaItem(s) when called on an empty playlist.
  • ترانسفورماتور:
    • Remove Transformer.Builder.setMediaSourceFactory(MediaSource.Factory) . Use ExoPlayerAssetLoader.Factory(MediaSource.Factory) and Transformer.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 using findDecoder/EncoderForFormat utilities, to expand support.
    • Remove B-frame configuration in DefaultEncoderFactory because it doesn't work on some devices.
  • Track selection:
    • Add DefaultTrackSelector.Parameters.allowInvalidateSelectionsForRendererCapabilitiesChange which is disabled by default. When enabled, the DefaultTrackSelector will trigger a new track selection when the renderer capabilities changed.
  • Extractors:
    • Ogg: Fix bug when seeking in files with a long duration ( #391 ).
    • FMP4: Fix issue where TimestampAdjuster initializes a wrong timestamp offset with metadata sample time from emsg atom ( #356 ).
  • صوتی:
    • 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() and AudioSink.release() for releasing the resources at the end of player's lifecycle.
    • Listen to audio capabilities changes in DefaultAudioSink . Add a required parameter context in the constructor of DefaultAudioSink , with which the DefaultAudioSink will register as the listener to the AudioCapabilitiesReceiver and update its audioCapabilities property when informed with a capabilities change.
    • Propagate audio capabilities changes via a new event onAudioCapabilitiesChanged in AudioSink.Listener interface, and a new interface RendererCapabilities.Listener which triggers onRendererCapabilitiesChanged events.
    • Add ChannelMixingAudioProcessor for applying scaling/mixing to audio channels.
    • Add new int value DISCARD_REASON_AUDIO_BYPASS_POSSIBLE to DecoderDiscardReasons 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 a VideoSize with a width and height of 0 when the renderer is disabled. Player.Listener.onVideoSizeChanged is called accordingly when Player.getVideoSize() changes. With this change, ExoPlayer's video size with MediaCodecVideoRenderer has a width and height of 0 when Player.getCurrentTracks does not support video, or the size of the supported video track is not yet determined.
  • 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)
  • 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 a Player 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 requested MediaItems to be passed onto Player if they have LocalConfiguration (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 requested MediaItems to be passed onto Player if they have LocalConfiguration (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 ).
  • UI:
    • Add Util methods shouldShowPlayButton and handlePlayPauseButtonAction to write custom UI elements with a play/pause button.
  • RTSP Extension:
    • For MPEG4-LATM, use default profile-level-id value if absent in Describe Response SDP message ( #302 ).
    • Use base Uri for relative path resolution from the RTSP session if present in DESCRIBE response header ( #11160 ).
  • DASH Extension:
    • Remove the media time offset from MediaLoadData.startTimeMs and MediaLoadData.endTimeMs for multi period DASH streams.
    • Fix a bug where re-preparing a multi-period live Dash media source produced a IndexOutOfBoundsException ( #10838 ).
  • HLS Extension:
    • Add HlsMediaSource.Factory.setTimestampAdjusterInitializationTimeoutMs(long) to set a timeout for the loading thread to wait for the TimestampAdjuster to initialize. If the initialization doesn't complete before the timeout, a PlaybackException is thrown to avoid the playback endless stalling. The timeout is set to zero by default ( #323 ).
  • Test Utilities:
    • Check for URI scheme case insensitivity in DataSourceContractTest .
  • Remove deprecated symbols:
    • Remove DefaultAudioSink constructors, use DefaultAudioSink.Builder instead.
    • Remove HlsMasterPlaylist , use HlsMultivariantPlaylist instead.
    • Remove Player.stop(boolean) . Use Player.stop() and Player.clearMediaItems() (if reset is true ) instead.
    • Remove two deprecated SimpleCache constructors, use a non-deprecated constructor that takes a DatabaseProvider instead for better performance.
    • Remove DefaultBandwidthMeter constructor, use DefaultBandwidthMeter.Builder instead.
    • Remove DefaultDrmSessionManager constructors, use DefaultDrmSessionManager.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 , and DownloadHelper.forSmoothStreaming , use DownloadHelper.forMediaItem instead.
    • Remove deprecated DownloadService constructor, use a non deprecated constructor that includes the option to provide a channelDescriptionResourceId parameter.
    • Remove deprecated String constants for Charsets ( ASCII_NAME , UTF8_NAME , ISO88591_NAME , UTF16_NAME and UTF16LE_NAME ), use Kotlin Charsets from the kotlin.text package, the java.nio.charset.StandardCharsets or the com.google.common.base.Charsets instead.
    • Remove deprecated WorkManagerScheduler constructor, use a non deprecated constructor that includes the option to provide a Context parameter instead.
    • Remove the deprecated methods createVideoSampleFormat , createAudioSampleFormat , createContainerFormat , and createSampleFormat , which were used to instantiate the Format class. Instead use Format.Builder for creating instances of Format .
    • Remove the deprecated methods copyWithMaxInputSize , copyWithSubsampleOffsetUs , copyWithLabel , copyWithManifestFormatInfo , copyWithGaplessInfo , copyWithFrameRate , copyWithDrmInitData , copyWithMetadata , copyWithBitrate and copyWithVideoSize , use Format.buildUpon() and setter methods instead.
    • Remove deprecated ExoPlayer.retry() , use prepare() instead.
    • Remove deprecated zero-arg DefaultTrackSelector constructor, use DefaultTrackSelector(Context) instead.
    • Remove deprecated OfflineLicenseHelper constructor, use OfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher) instead.
    • Remove deprecated DownloadManager constructor, use the constructor that takes an Executor instead.
    • Remove deprecated Cue constructors, use Cue.Builder instead.
    • Remove deprecated OfflineLicenseHelper constructor, use OfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher) instead.
    • Remove four deprecated AnalyticsListener methods:
      • onDecoderEnabled , use onAudioEnabled and/or onVideoEnabled instead.
      • onDecoderInitialized , use onAudioDecoderInitialized and/or onVideoDecoderInitialized instead.
      • onDecoderInputFormatChanged , use onAudioInputFormatChanged and/or onVideoInputFormatChanged instead.
      • onDecoderDisabled , use onAudioDisabled and/or onVideoDisabled instead.
    • Remove the deprecated Player.Listener.onSeekProcessed and AnalyticsListener.onSeekProcessed , use onPositionDiscontinuity with DISCONTINUITY_REASON_SEEK instead.
    • Remove ExoPlayer.setHandleWakeLock(boolean) , use setWakeMode(int) instead.
    • Remove deprecated DefaultLoadControl.Builder.createDefaultLoadControl() , use build() instead.
    • Remove deprecated MediaItem.PlaybackProperties , use MediaItem.LocalConfiguration instead. Deprecated field MediaItem.playbackProperties is now of type MediaItem.LocalConfiguration .

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

نسخه 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 if Buffer contains flag C.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 ).
  • 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 legacy MediaSessionCompat that updates its actions.
    • Fix bug that prevented the MediaLibraryService from returning null for a call from System UI to Callback.onGetLibraryRoot with params.isRecent == true on API 30 ( #355 ).
    • Fix memory leak of MediaSessionService or MediaLibraryService ( #346 ).
    • Fix bug where a combined Timeline and position update in a MediaSession may cause a MediaController to throw an IllegalStateException .

نسخه 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 in MediaController ( #290 ).
    • Add missing forwarding of MediaSession.broadcastCustomCommand to the legacy MediaControllerCompat.Callback.onSessionEvent ( #293 ).
    • Fix bug where calling MediaSession.setPlayer doesn't update the available commands.
    • Fix issue that TrackSelectionOverride instances sent from a MediaController are ignored if they reference a group with Format.metadata ( #296 ).
    • Fix issue where Player.COMMAND_GET_CURRENT_MEDIA_ITEM needs to be available to access metadata via the legacy MediaSessionCompat .
    • Fix issue where MediaSession instances on a background thread cause crashes when used in MediaSessionService ( #318 ).
    • Fix issue where a media button receiver was declared by the library without the app having intended this ( #314 ).
  • داش:
    • 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:
    • Fix network type detection on API 33 ( #10970 ).
    • Fix NullPointerException when calling ExoPlayer.isTunnelingEnabled ( #10977 ).
  • دانلودها:
    • Make the maximum difference of the start time of two segments to be merged configurable in SegmentDownloader and subclasses ( #248 ).
  • صوتی:
    • Fix broken gapless MP3 playback on Samsung devices ( #8594 ).
    • Fix bug where playback speeds set immediately after disabling audio may be overridden by a previous speed change ( #10882 ).
  • ویدئو:
    • Map HEVC HDR10 format to HEVCProfileMain10HDR10 instead of HEVCProfileMain10 .
    • 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.
  • بازیگران:
    • Fix transient STATE_IDLE when transitioning between media items ( #245 ).
  • 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.

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 ).
  • Extractors:
    • Throw a ParserException instead of a NullPointerException 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 ).
  • صوتی:
    • Use the compressed audio format bitrate to calculate the min buffer size for AudioTrack in direct playbacks (passthrough).
  • متن:
    • Fix TextRenderer passing an invalid (negative) index to Subtitle.getEventTime if a subtitle file contains no cues.
    • SubRip: Add support for UTF-16 files if they start with a byte order mark.
  • Metadata:
    • 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 for MediaMetadata.folderType . The folder type will be deprecated in the next release.
  • داش:
    • Add full parsing for image adaptation sets, including tile counts ( #3752 ).
  • UI:
    • Fix the deprecated PlayerView.setControllerVisibilityListener(PlayerControlView.VisibilityListener) to ensure visibility changes are passed to the registered listener ( #229 ).
    • Fix the ordering of the center player controls in PlayerView when using a right-to-left (RTL) layout ( #227 ).
  • Session:
    • Add abstract SimpleBasePlayer to help implement the Player 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 the DefaultMediaNotificationProvider and use immutable lists for clarity ( #216 ).
    • Add onSetMediaItems callback listener to provide means to modify/set MediaItem 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 ).
  • Metadata:
    • 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 for MediaMetadata.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 the ImaServerSideAdInsertionMediaSource.AdsLoader.Builder to request focusing the skip button on TV devices and set it to true by default.
    • Add a method focusSkipButton() to the ImaServerSideAdInsertionMediaSource.AdsLoader to programmatically request to focus the skip button.
    • Bump IMA SDK version to 3.29.0.
  • 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 single MediaSource ( #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 calling seekToNext or seekToPrevious 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 ).
  • ساخت:
    • Enforce minimum compileSdkVersion to avoid compilation errors ( #10684 ).
    • Avoid publishing block when included in another gradle build.
  • Track selection:
    • Prefer other tracks to Dolby Vision if display does not support it. ( #8944 ).
  • دانلودها:
    • Fix potential infinite loop in ProgressiveDownloader caused by simultaneous download and playback with the same PriorityTaskManager ( #10570 ).
    • Make download notification appear immediately ( #183 ).
    • Limit parallel download removals to 1 to avoid excessive thread creation ( #10458 ).
  • ویدئو:
    • Try alternative decoder for Dolby Vision if display does not support it. ( #9794 ).
  • صوتی:
    • Use SingleThreadExecutor for releasing AudioTrack 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 to androidx.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 ).
  • Metadata:
    • MetadataRenderer can now be configured to render metadata as soon as they are available. Create an instance with MetadataRenderer(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 ).
  • داش:
    • Parse EventStream.presentationTimeOffset from manifests ( #10460 ).
  • UI:
    • Use current overrides of the player as preset in TrackSelectionDialogBuilder ( #10429 ).
  • Session:
    • Ensure commands are always executed in the correct order even if some require asynchronous resolution ( #85 ).
    • Add DefaultMediaNotificationProvider.Builder to build DefaultMediaNotificationProvider instances. The builder can configure the notification ID, the notification channel ID and the notification channel name used by the provider. Also, add method DefaultMediaNotificationProvider.setSmallIcon(int) to set the notifications small icon. ( #104 ).
    • Ensure commands sent before MediaController.release() are not dropped ( #99 ).
    • SimpleBitmapLoader can load bitmap from file:// 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:
    • Add H263 fragmented packet handling ( #119 ).
    • Add support for MP4A-LATM ( #162 ).
  • 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 identify CastPlayer when controlling playback with a MediaController ( #142 ).
  • ترانسفورماتور:
    • 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.

Version 1.0.0-beta02

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 with ExoPlayer.setShuffleOrder results in a call to Player.Listener#onTimelineChanged with reason=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 in DefaultMediaSourceFactory , which was non-functional in some cases ( #116 ).
  • Extractors:
    • Fix parsing of H265 short term reference picture sets ( #10316 ).
    • Fix parsing of bitrates from esds boxes ( #10381 ).
  • داش:
    • 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 in LeanbackAdapter ( 10420 ).
  • بازیگران:
    • Use the MediaItem that has been passed to the playlist methods as Window.mediaItem in CastTimeline ( #25 , #8212 ).
    • Support Player.getMetadata() and Listener.onMediaMetadataChanged() with CastPlayer ( #25 ).

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 with ExoPlayer.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 to MediaSource.Factory.setDrmSessionManagerProvider and MediaSource.Factory.setLoadErrorHandlingPolicy . Instances of DefaultDrmSessionManagerProvider and DefaultLoadErrorHandlingPolicy can be passed explicitly if required.
    • Add MediaItem.RequestMetadata to represent metadata needed to play media when the exact LocalConfiguration is not known. Also remove MediaMetadata.mediaUrl as this is now included in RequestMetadata .
    • Add Player.Command.COMMAND_SET_MEDIA_ITEM to enable players to allow setting a single item.
  • Track selection:
    • Flatten TrackSelectionOverrides class into TrackSelectionParameters , and promote TrackSelectionOverride to a top level class.
    • Rename TracksInfo to Tracks and TracksInfo.TrackGroupInfo to Tracks.Group . Player.getCurrentTracksInfo and Player.Listener.onTracksInfoChanged have also been renamed to Player.getCurrentTracks and Player.Listener.onTracksChanged . This includes 'un-deprecating' the Player.Listener.onTracksChanged method name, but with different parameter types.
    • Change DefaultTrackSelector.buildUponParameters and DefaultTrackSelector.Parameters.buildUpon to return DefaultTrackSelector.Parameters.Builder instead of the deprecated DefaultTrackSelector.ParametersBuilder .
    • Add DefaultTrackSelector.Parameters.constrainAudioChannelCountToDeviceCapabilities which is enabled by default. When enabled, the DefaultTrackSelector will prefer audio tracks whose channel count does not exceed the device output capabilities. On handheld devices, the DefaultTrackSelector 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, the DefaultTrackSelector will monitor for changes in the Spatializer properties and trigger a new track selection upon these. Devices with a television UI mode are excluded from these constraints and the format with the highest channel count will be preferred. To enable this feature, the DefaultTrackSelector instance must be constructed with a Context .
  • ویدئو:
    • Rename DummySurface to PlaceholderSurface .
    • Add AV1 support to the MediaCodecVideoRenderer.getCodecMaxInputSize .
  • صوتی:
    • Use LG AC3 audio decoder advertising non-standard MIME type.
    • Change the return type of AudioAttributes.getAudioAttributesV21() from android.media.AudioAttributes to a new AudioAttributesV21 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 mask AudioFormat.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 return CueGroup instead of List<Cue> .
    • SSA: Support OutlineColour style setting when BorderStyle == 3 (ie OutlineColour 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.
  • Extractors:
    • Add support for AVI ( #2092 ).
    • Matroska: Parse DiscardPadding for Opus tracks.
    • MP4: Parse bitrates from esds boxes.
    • Ogg: Allow duplicate Opus ID and comment headers ( #10038 ).
  • UI:
    • Fix delivery of events to OnClickListener s set on PlayerView in the case that useController=false ( #9605 ). Also fix delivery of events to OnLongClickListener for all view configurations.
    • Fix incorrectly treating a sequence of touch events that exit the bounds of PlayerView before ACTION_UP as a click ( #9861 ).
    • Fix PlayerView accessibility issue where tapping might toggle playback rather than hiding the controls ( #8627 ).
    • Rewrite TrackSelectionView and TrackSelectionDialogBuilder to work with the Player interface rather than ExoPlayer . This allows the views to be used with other Player 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 ).
  • داش:
    • Parse channel count from DTS AudioChannelConfiguration elements. This re-enables audio passthrough for DTS streams ( #10159 ).
    • Disallow passing null to DashMediaSource.Factory.setCompositeSequenceableLoaderFactory . Instances of DefaultCompositeSequenceableLoaderFactory can be passed explicitly if required.
  • HLS:
    • Fallback to chunkful preparation if the playlist CODECS attribute does not contain the audio codec ( #10065 ).
    • Disallow passing null to HlsMediaSource.Factory.setCompositeSequenceableLoaderFactory , HlsMediaSource.Factory.setPlaylistParserFactory , and HlsMediaSource.Factory.setPlaylistTrackerFactory . Instances of DefaultCompositeSequenceableLoaderFactory , DefaultHlsPlaylistParserFactory , or a reference to DefaultHlsPlaylistTracker.FACTORY can be passed explicitly if required.
  • Smooth Streaming:
    • Disallow passing null to SsMediaSource.Factory.setCompositeSequenceableLoaderFactory . Instances of DefaultCompositeSequenceableLoaderFactory can be passed explicitly if required.
  • RTSP:
    • Add RTP reader for H263 ( #63 ).
    • Add RTP reader for MPEG4 ( #35 ).
    • Add RTP reader for HEVC ( #36 ).
    • Add RTP reader for AMR. Currently only mono-channel, non-interleaved AMR streams are supported. Compound AMR RTP payload is not supported. ( #46 )
    • Add RTP reader for VP8 ( #47 ).
    • Add RTP reader for WAV ( #56 ).
    • Fix RTSP basic authorization header. ( #9544 ).
    • Stop checking mandatory SDP fields as ExoPlayer doesn't need them ( #10049 ).
    • Throw checked exception when parsing RTSP timing ( #10165 ).
    • Add RTP reader for VP9 ( #47 ).
    • Add RTP reader for OPUS ( #53 ).
  • Data sources:
    • Rename DummyDataSource to PlaceholderDataSource .
    • Workaround OkHttp interrupt handling.
  • Session:
    • Replace MediaSession.MediaItemFiller with MediaSession.Callback.onAddMediaItems to allow asynchronous resolution of requests.
    • Support setMediaItems(s) methods when MediaController connects to a legacy media session.
    • Remove MediaController.setMediaUri and MediaSession.Callback.onSetMediaUri . The same functionality can be achieved by using MediaController.setMediaItem and MediaSession.Callback.onAddMediaItems .
    • Forward legacy MediaController calls to play media to MediaSession.Callback.onAddMediaItems instead of onSetMediaUri .
    • Add MediaNotification.Provider and DefaultMediaNotificationProvider to provide customization of the notification.
    • Add BitmapLoader and SimpleBitmapLoader 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 to MediaSession.Callback , MediaLibrarySession.MediaLibrarySessionCallback to MediaLibrarySession.Callback and MediaSession.Builder.setSessionCallback to setCallback .
    • Fix NPE in MediaControllerImplLegacy ( #59 ).
    • Update session position info on timeline change( #51 ).
    • Fix NPE in MediaControllerImplBase after releasing controller ( #74 ).
  • 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 ).
  • Remove deprecated symbols:
    • Remove Player.Listener.onTracksChanged(TrackGroupArray, TrackSelectionArray) . Use Player.Listener.onTracksChanged(Tracks) instead.
    • Remove Player.getCurrentTrackGroups and Player.getCurrentTrackSelections . Use Player.getCurrentTracks instead. You can also continue to use ExoPlayer.getCurrentTrackGroups and ExoPlayer.getCurrentTrackSelections , although these methods remain deprecated.
    • Remove DownloadHelper DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_VIEWPORT and DEFAULT_TRACK_SELECTOR_PARAMETERS constants. Use getDefaultTrackSelectorParameters(Context) instead when possible, and DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_CONTEXT otherwise.
    • Remove constructor DefaultTrackSelector(ExoTrackSelection.Factory) . Use DefaultTrackSelector(Context, ExoTrackSelection.Factory) instead.
    • Remove Transformer.Builder.setContext . The Context should be passed to the Transformer.Builder constructor instead.

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 and MediaItem.SubtitleConfiguration.Builder.setId to prioritise the SubtitleConfiguration field and fall back to the Factory value if it's not set ( #10016 ).
  • 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 of DefaultRenderersFactory that override buildVideoRenderers() or buildAudioRenderers() can access the codec adapter factory and pass it to MediaCodecRenderer instances they create.
    • Propagate ICY header fields name and genre to MediaMetadata.station and MediaMetadata.genre respectively so that they reach the app via Player.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 from MediaCodec . ( #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 to queuedInputBufferCount .
    • Make SimpleExoPlayer.renderers private. Renderers can be accessed via ExoPlayer.getRenderer .
    • Updated some AnalyticsListener.EventFlags constant values to match values in Player.EventFlags .
    • Split AnalyticsCollector into an interface and default implementation to allow it to be stripped by R8 if an app doesn't need it.
  • 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 a TrackGroupArray . TrackGroup s can always be made distinguishable by setting an id in the TrackGroup 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 explicitly AudioCapabilities.DEFAULT_AUDIO_CAPABILITIES instead of null .
    • Allow customization of the AudioTrack buffer size calculation by injecting an AudioTrackBufferSizeProvider to DefaultAudioSink . ( #8891 ).
    • Retry AudioTrack creation if the requested buffer size was > 1MB. ( #9712 ).
  • Extractors:
    • WAV: Add support for RF64 streams ( #9543 ).
    • Fix incorrect parsing of H.265 SPS NAL units ( #9719 ).
    • Parse Vorbis Comments (including METADATA_BLOCK_PICTURE ) in Ogg Opus and Ogg Vorbis files.
  • متن:
    • Add a MediaItem.SubtitleConfiguration.id field which is propagated to the Format.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.
  • DRM:
    • Remove playbackLooper from DrmSessionManager.(pre)acquireSession . When a DrmSessionManager is used by an app in a custom MediaSource , the playbackLooper needs to be passed to DrmSessionManager.setPlayer instead.
  • 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:
    • Fix the color of the numbers in StyledPlayerView rewind and fastforward buttons when using certain themes ( #9765 ).
    • Correctly translate playback speed strings ( #9811 ).
  • داش:
    • Add parsed essential and supplemental properties to the Representation ( #9579 ).
    • Support the forced-subtitle track role ( #9727 ).
    • Stop interpreting the main track role as C.SELECTION_FLAG_DEFAULT .
    • Fix base URL exclusion logic for manifests that do not declare the DVB namespace ( #9856 ).
    • Support relative MPD.Location URLs ( #9939 ).
  • 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 ).
  • RTSP:
    • Provide a client API to override the SocketFactory used for any server connection ( #9606 ).
    • Prefer DIGEST authentication method over BASIC if both are present ( #9800 ).
    • Handle when RTSP track timing is not available ( #9775 ).
    • Ignore invalid RTP-Info header values ( #9619 ).
  • ترانسفورماتور:
    • 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 call setClearMediaItemsOnStop(false) on the connector.
  • Cast extension:
    • Fix bug that prevented CastPlayer from calling onIsPlayingChanged correctly ( #9792 ).
    • Support audio metadata including artwork with DefaultMediaItemConverter ( #9663 ).
  • FFmpeg extension:
    • Make build_ffmpeg.sh depend on LLVM's bin utils instead of GNU's ( #9933 ).
  • Android 12 compatibility:
    • Upgrade the Cast extension to depend on com.google.android.gms:play-services-cast-framework:20.1.0 . Earlier versions of play-services-cast-framework are not compatible with apps targeting Android 12, and will crash with an IllegalArgumentException when creating PendingIntent s ( #9528 ).
  • Remove deprecated symbols:
    • Remove Player.EventListener . Use Player.Listener instead.
    • Remove MediaSourceFactory#setDrmSessionManager , MediaSourceFactory#setDrmHttpDataSourceFactory , and MediaSourceFactory#setDrmUserAgent . Use MediaSourceFactory#setDrmSessionManagerProvider instead.
    • Remove MediaSourceFactory#setStreamKeys . Use MediaItem.Builder#setStreamKeys instead.
    • Remove MediaSourceFactory#createMediaSource(Uri) . Use MediaSourceFactory#createMediaSource(MediaItem) instead.
    • Remove setTag from DashMediaSource , HlsMediaSource and SsMediaSource . Use MediaItem.Builder#setTag instead.
    • Remove DashMediaSource#setLivePresentationDelayMs(long, boolean) . Use MediaItem.Builder#setLiveConfiguration and MediaItem.LiveConfiguration.Builder#setTargetOffsetMs to override the manifest, or DashMediaSource#setFallbackTargetLiveOffsetMs to provide a fallback value.
    • Remove (Simple)ExoPlayer.setThrowsWhenUsingWrongThread . Opting out of the thread enforcement is no longer possible.
    • Remove ActionFile and ActionFileUpgradeUtil . Use ExoPlayer 2.16.1 or before to use ActionFileUpgradeUtil to merge legacy action files into DefaultDownloadIndex .
    • Remove ProgressiveMediaSource#setExtractorsFactory . Use ProgressiveMediaSource.Factory(DataSource.Factory, ExtractorsFactory) constructor instead.
    • Remove ProgressiveMediaSource.Factory#setTag and, and ProgressiveMediaSource.Factory#setCustomCacheKey . Use MediaItem.Builder#setTag and MediaItem.Builder#setCustomCacheKey instead.
    • Remove DefaultRenderersFactory(Context, @ExtensionRendererMode int) and DefaultRenderersFactory(Context, @ExtensionRendererMode int, long) constructors. Use the DefaultRenderersFactory(Context) constructor, DefaultRenderersFactory#setExtensionRendererMode , and DefaultRenderersFactory#setAllowedVideoJoiningTimeMs instead.
    • Remove all public CronetDataSource constructors. Use CronetDataSource.Factory instead.
  • 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 (in com.google.android.exoplayer2.ext.flac package)
    • @FlacExtractor.Flags (in com.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.