Media3
| 最近更新時間 | 穩定版 | 候選版 | Beta 版 | Alpha 版 |
|---|---|---|---|---|
| 2025 年 10 月 22 日 | 1.8.0 | - | - | 1.9.0-alpha01 |
宣告依附元件
如果要為 Media3 新增依附元件,您必須將 Google Maven 存放區新增至專案。詳情請參閱 Google 的 Maven 存放區。
在應用程式或模組的 build.gradle 檔案中,新增您需要的構件依附元件:
Groovy
dependencies { def media3_version = "1.8.0" // For media playback using ExoPlayer implementation "androidx.media3:media3-exoplayer:$media3_version" // For DASH playback support with ExoPlayer implementation "androidx.media3:media3-exoplayer-dash:$media3_version" // For HLS playback support with ExoPlayer implementation "androidx.media3:media3-exoplayer-hls:$media3_version" // For SmoothStreaming playback support with ExoPlayer implementation "androidx.media3:media3-exoplayer-smoothstreaming:$media3_version" // For RTSP playback support with ExoPlayer implementation "androidx.media3:media3-exoplayer-rtsp:$media3_version" // For MIDI playback support with ExoPlayer (see additional dependency requirements in // https://github.com/androidx/media/blob/release/libraries/decoder_midi/README.md) implementation "androidx.media3:media3-exoplayer-midi:$media3_version" // For ad insertion using the Interactive Media Ads SDK with ExoPlayer implementation "androidx.media3:media3-exoplayer-ima:$media3_version" // For loading data using the Cronet network stack implementation "androidx.media3:media3-datasource-cronet:$media3_version" // For loading data using the OkHttp network stack implementation "androidx.media3:media3-datasource-okhttp:$media3_version" // For loading data using librtmp implementation "androidx.media3:media3-datasource-rtmp:$media3_version" // For building media playback UIs using Compose implementation "androidx.media3:media3-ui-compose:$media3_version" // For building media playback UIs using Views implementation "androidx.media3:media3-ui:$media3_version" // For building media playback UIs using Jetpack Compose implementation "androidx.media3:media3-ui-compose:$media3_version" // For building media playback UIs for Android TV using the Jetpack Leanback library implementation "androidx.media3:media3-ui-leanback:$media3_version" // For exposing and controlling media sessions implementation "androidx.media3:media3-session:$media3_version" // For extracting data from media containers implementation "androidx.media3:media3-extractor:$media3_version" // For integrating with Cast implementation "androidx.media3:media3-cast:$media3_version" // For scheduling background operations using Jetpack Work's WorkManager with ExoPlayer implementation "androidx.media3:media3-exoplayer-workmanager:$media3_version" // For transforming media files implementation "androidx.media3:media3-transformer:$media3_version" // For applying effects on video frames implementation "androidx.media3:media3-effect:$media3_version" // For muxing media files implementation "androidx.media3:media3-muxer:$media3_version" // Utilities for testing media components (including ExoPlayer components) implementation "androidx.media3:media3-test-utils:$media3_version" // Utilities for testing media components (including ExoPlayer components) via Robolectric implementation "androidx.media3:media3-test-utils-robolectric:$media3_version" // Common functionality for reading and writing media containers implementation "androidx.media3:media3-container:$media3_version" // Common functionality for media database components implementation "androidx.media3:media3-database:$media3_version" // Common functionality for media decoders implementation "androidx.media3:media3-decoder:$media3_version" // Common functionality for loading data implementation "androidx.media3:media3-datasource:$media3_version" // Common functionality used across multiple media libraries implementation "androidx.media3:media3-common:$media3_version" // Common Kotlin-specific functionality implementation "androidx.media3:media3-common-ktx:$media3_version" }
Kotlin
dependencies { val media3_version = "1.8.0" // For media playback using ExoPlayer implementation("androidx.media3:media3-exoplayer:$media3_version") // For DASH playback support with ExoPlayer implementation("androidx.media3:media3-exoplayer-dash:$media3_version") // For HLS playback support with ExoPlayer implementation("androidx.media3:media3-exoplayer-hls:$media3_version") // For SmoothStreaming playback support with ExoPlayer implementation("androidx.media3:media3-exoplayer-smoothstreaming:$media3_version") // For RTSP playback support with ExoPlayer implementation("androidx.media3:media3-exoplayer-rtsp:$media3_version") // For MIDI playback support with ExoPlayer (see additional dependency requirements in // https://github.com/androidx/media/blob/release/libraries/decoder_midi/README.md) implementation("androidx.media3:media3-exoplayer-midi:$media3_version") // For ad insertion using the Interactive Media Ads SDK with ExoPlayer implementation("androidx.media3:media3-exoplayer-ima:$media3_version") // For loading data using the Cronet network stack implementation("androidx.media3:media3-datasource-cronet:$media3_version") // For loading data using the OkHttp network stack implementation("androidx.media3:media3-datasource-okhttp:$media3_version") // For loading data using librtmp implementation("androidx.media3:media3-datasource-rtmp:$media3_version") // For building media playback UIs using Compose implementation("androidx.media3:media3-ui-compose:$media3_version") // For building media playback UIs using Views implementation("androidx.media3:media3-ui:$media3_version") // For building media playback UIs using Jetpack Compose implementation("androidx.media3:media3-ui-compose:$media3_version") // For building media playback UIs for Android TV using the Jetpack Leanback library implementation("androidx.media3:media3-ui-leanback:$media3_version") // For exposing and controlling media sessions implementation("androidx.media3:media3-session:$media3_version") // For extracting data from media containers implementation("androidx.media3:media3-extractor:$media3_version") // For integrating with Cast implementation("androidx.media3:media3-cast:$media3_version") // For scheduling background operations using Jetpack Work's WorkManager with ExoPlayer implementation("androidx.media3:media3-exoplayer-workmanager:$media3_version") // For transforming media files implementation("androidx.media3:media3-transformer:$media3_version") // For applying effects on video frames implementation("androidx.media3:media3-effect:$media3_version") // For muxing media files implementation("androidx.media3:media3-muxer:$media3_version") // Utilities for testing media components (including ExoPlayer components) implementation("androidx.media3:media3-test-utils:$media3_version") // Utilities for testing media components (including ExoPlayer components) via Robolectric implementation("androidx.media3:media3-test-utils-robolectric:$media3_version") // Common functionality for reading and writing media containers implementation("androidx.media3:media3-container:$media3_version") // Common functionality for media database components implementation("androidx.media3:media3-database:$media3_version") // Common functionality for media decoders implementation("androidx.media3:media3-decoder:$media3_version") // Common functionality for loading data implementation("androidx.media3:media3-datasource:$media3_version") // Common functionality used across multiple media libraries implementation("androidx.media3:media3-common:$media3_version") // Common Kotlin-specific functionality implementation("androidx.media3:media3-common-ktx:$media3_version") }
如要進一步瞭解依附元件,請參閱「新增建構依附元件」一文。
意見回饋
您的意見可協助我們改善 Jetpack。您可以使用 Media3 Issue Tracker 尋找問題的答案、已知問題和功能要求,以及提出新問題。
1.9.0 版
1.9.0-alpha01 版
2025 年 10 月 22 日
發布了 androidx.media3:media3-*:1.9.0-alpha01。1.9.0-alpha01 版包含這些修訂項目。
- 通用程式庫:
- 將
minSdk更新為23,與其他 AndroidX 程式庫保持一致。 - 新增
PlayerTransferState,方便在Player執行個體之間轉移播放狀態。 - 在 Player 中新增
void mute()和void unmute()方法,在將 Player 音量設為零之前和之後,保留並還原 Player 的音量。 - 發布先前由
ExoPlayer內部使用的公用程式類別WakeLockManager、WifiLockManager、AudioFocusManager、AudioBecomingNoisyManager和StuckPlayerDetector,以便其他播放器重複使用 (#1893)。 - 修正基礎委派播放器使用參照相等性比較事件監聽器執行個體時的
ForwardingPlayer事件監聽器處理方式 (#2675)。 - 在
media3-common-ktx程式庫中新增Player.listenTo暫停擴充功能函式,指定應執行的特定Player.Events。 - 修正
BasePlayer.getBufferedPercentage中的當機問題,此問題是由於回報的緩衝位置遠大於回報的持續時間時,發生整數溢位所致 (#2750)。
- 將
- ExoPlayer:
- 新增偵測播放器是否卡住的功能,如果播放器似乎卡住,則會觸發
StuckPlayerException播放器錯誤。在下列情況中,每個預設逾時時間都可以在ExoPlayer.Builder中設定 (如有需要):- 嘗試播放影片 10 分鐘後,
STATE_BUFFERING仍未緩衝。 - 嘗試播放 10 秒後,
STATE_READY沒有任何播放進度。 STATE_READY超過宣告時間 1 分鐘,但未到達項目結尾。- 嘗試播放時,因播放遭禁止而經過 10 分鐘。
- 嘗試播放影片 10 分鐘後,
- 預設啟用喚醒鎖定處理功能,修正背景播放期間的緩衝問題。這相當於將
ExoPlayer.Builder.setWakeMode設定為C.WAKE_MODE_LOCAL。 - 新增監聽邏輯,在系統向最初傳遞至
ExoPlayer.Builder的Context回報變更時,自動更新虛擬裝置 ID。 - 新增
ExoPlayer.setVirtualDeviceId,手動更新從傳遞至ExoPlayer.Builder的Context取得的虛擬裝置 ID。 - 請確保在目前項目結束前 10 秒內,算繪器不會耗用下一個播放清單項目的資料。
- 在
ExoPlayer中新增setSeekBackIncrementMs、setSeekForwardIncrementMs和setMaxSeekToPreviousPositionMs,以便在建構後更新這些設定 (#2736)。 - 在
DefaultPreloadManager中新增預先快取功能。應用程式現在可以透過TargetPreloadStatusControl.getTargetPreloadStatus(T rankingData)傳回DefaultPreloadManager.PreloadStatus.specifiedRangeCached(startPositionMs, durationMs)或DefaultPreloadManager.PreloadStatus.specifiedRangeCached(durationMs),指出媒體項目需要預先快取。 - 在短片示範應用程式中,使用
DefaultPreloadManager的預先快取功能。 - 新增本機播放的
DefaultLoadControl.Builder設定器,並調整DefaultLoadControl的預設值,以便順利播放各種本機檔案。 - 修正錯誤:設定空白播放清單可能會導致播放器處於
STATE_READY或STATE_BUFFERING狀態。 - 強化預先載入管理員 API:
- 新增
addMediaItems(List<MediaItem>, List<T>)和addMediaSources(List<MediaSource>, List<T>),以批次新增媒體項目或媒體來源,並在之後自動呼叫invalidate()。 - 新增
removeMediaItems((List<MediaItem>)和removeMediaSources(List<MediaSource>),以批次移除媒體項目或媒體來源,並確保預先載入管理工具不會在移除後開始預先載入或繼續預先載入任何項目。 - 允許
DefaultPreloadManager.setCurrentPlayingIndex(int)自動失效。更新目前播放的索引後,應用程式不再需要明確呼叫invalidate()。
- 新增
- 在清除模式下,新增功能可略過同一組圖片內向前搜尋時的主要畫面格重設。
- 為應用程式新增
DefaultLoadControl.Builder.setPlayerTargetBufferBytes(String, int),為具有指定playerName的播放器設定目標緩衝區位元組值。現在DefaultLoadControl可以根據自身分配到的位元組和目標緩衝區位元組,分別為每位播放器做出決策。 - 在
AdPlaybackState.AdGroup中加入SkipInfo,即可攜帶廣告群組中每則廣告的略過資訊。 - 修正在播放後續捲動廣告時呼叫
removeMediaItems(List)會導致當機的錯誤 (#2746)。 - 修正播放清單時的頓挫問題,因為系統會誤將影格一律設為最後一個樣本並算繪。
- 如果播放器無法產生音訊工作階段 ID,請啟用重試路徑 (#2382、#2678)。
- 在
DefaultPreloadManager中新增支援功能,控管來源的緩衝區總位元組數,避免預先載入的緩衝區總位元組數任意增加。如要使用預設控制邏輯,應用程式可以透過DefaultLoadControl.Builder.setPlayerTargetBufferBytes(String, int)為PlayerId.Preload.name的playerName設定預先載入的目標緩衝區位元組 (「preload」),並透過DefaultPreloadManager.Builder.setLoadControl(LoadControl)插入建立的DefaultLoadControl。
- 新增偵測播放器是否卡住的功能,如果播放器似乎卡住,則會觸發
- CompositionPlayer:
- 在新的
@ExperimentalApi註解下發布CompositionPlayer,表示該功能可供實驗,但仍在開發中。部分 API 可能會在日後的版本中大幅變更,且某些用途有已知問題和限制 (部分未記錄)。 - 在
CompositionPlayer中新增對COMMAND_SET_AUDIO_ATTRIBUTES和音訊焦點處理的支援。 - 在
CompositionPlayer中新增支援次要序列的速度變更。
- 在新的
- 轉換程式:
- 將
InAppMp4Muxer設為預設多工器。 - 新增
EditedMediaItem.Builder#setSpeed()並淘汰Effects#createExperimentalSpeedChangingEffects()。 - 將
EditedMediaItemSequence中的forceAudioTrack和forceVideoTrack替換為trackTypes。
- 將
- 音軌選取:
- 新增
TrackSelectionParameters.selectTextByDefault,偏好選取任何文字軌,而不指定其他更具體的偏好設定。 - 在
TrackSelectionParameters中加入preferredVideoLabels、preferredAudioLabels和preferredTextLabels,指定特定標籤的曲目偏好設定,例如從 HLS NAME 標記讀取的曲目 (#1666)。
- 新增
- 擷取工具:
- FLAC:加強標頭偵測功能,減少在編碼的 FLAC 資料中找到偽標頭的機率,避免解碼錯誤 (#558)。
- MP3:允許 MP3 檔案開頭的 ID3 標記之間 (和之前) 有間隙 (#811、#5718)。
- MP4:在從擷取器發出音軌格式前,先查看第一個樣本的層值,以區分
audio/mpeg(MP3)、audio/mpeg-L1和audio/mpeg-L2MIME 類型 (#2683)。 - MP4:假設大於 1 MB 的
stbl方塊表示檔案不得為片段化檔案 (#2650),藉此提升極大檔案的偵測效率。 - Matroska:新增 DTS-HD 偵測支援 (#6225)。
- 修正
MatroskaExtractor的問題:如果檔案有多個音軌,搜尋可能不準確。提示點現在會正確與各自的音軌建立關聯,因此搜尋結果會更加精確。 - MP4:新增對
©mvn(動作名稱) 和©mvi(動作索引) 中繼資料的支援,這些資料現在會以TextInformationFrame物件的形式,分別在Format.metadata中以MVNM和MVIN的 ID 發出 (#2754)。 - MPEG-TS:修正因沒有時間戳記的 PES 封包而導致的
IllegalArgumentExceptionReorderingBufferQueue(#2764)。 - MP4:忽略缺少
stsd方格的軌道 (而非無法剖析整個檔案)。 - 新增擷取 HEIC 動態相片的支援。
HeifExtractor現在可以剖析內含內嵌視訊和音軌的 HEIC 檔案。 - MP3:將
FLAG_ENABLE_INDEX_SEEKING變更為優先從中繼資料標頭 (例如 Xing 和 VBRI) 尋找資訊 (如有),如果沒有其他搜尋資訊,則改為以索引為準。這項功能可提升含有搜尋中繼資料的檔案效能 (#2839)。
- 檢查員:
- 推出新的
:media3-inspector模組,做為媒體檢查公用程式的專屬主頁面。這個模組現在包含新的androidx.media3.inspector.MetadataRetriever,可為中繼資料和影格擷取作業提供統一的 API。現有的androidx.media3.exoplayer.MetadataRetriever已淘汰,改用這個新版本。 - 推出
androidx.media3.inspector.FrameExtractor,這是用於擷取影格的全新公用 API。這個AutoCloseable類別提供擷取影格的方法,支援 HDR 影片、影片特效和自訂解碼器選取項目。應透過特定Builder建立MediaItem。 - FrameExtractor:新增
getThumbnail(),可從媒體檔案擷取代表性縮圖畫面,不必指定特定時間戳記。
- 推出新的
- 音訊:
- 讓
AudioProcessor執行個體瞭解搜尋作業。 - 允許將新的
AudioOutputProvider介面插入DefaultAudioSink.Builder,以支援自訂音訊輸出路徑。預設值為AudioTrackAudioOutputProvider。 - 在
GainProcessor中處理搜尋。 - 在音軌格式支援評估中,運用 AC-4 解碼器設定檔和層級功能 (#2580)。
- 避免在播放開始時處理路由變更回呼,導致潛在延遲 (#2646)。
- 允許重複使用 EAC3、EAC3-JOC 和 AC-4 格式的轉碼器 (#1346)。
- 在
Sonic中新增對浮點 PCM 樣本的支援。 - 在
ToFloatPcmAudioProcessor中新增 16 位元 PCM 樣本的支援。
- 讓
- 影片:
- 針對不同設定檔的 Dolby Vision 內容,停用轉碼器重複使用功能。
- 文字:
- 修正 Dolby Vision 內容中 CEA-6/708 字幕的剖析問題 (#2775)。
- 圖片:
- 修正 ScrubbingMode 問題,避免播放器在清除 DASH 縮圖軌時卡住 (#2815)。
- DRM:
- 將
MediaDrmCallback方法的傳回類型從byte[]變更為新的MediaDrmCallback.Response類型,以便傳回額外的選用資訊。這是來源破壞性變更,但只要在傳回前,以new Response包裝先前的byte[]傳回值,即可輕鬆解決中斷問題。 - 將網址和延遲時間等重要要求資訊新增至
AnalyticsListener.onDrmKeysLoaded(#1001)。 - 將佈建要求資料從網址參數移至 POST 主體。
- 將
- Muxers:
- 新增
MediaMuxerCompat,取代架構MediaMuxer。 - 新增
MuxerUtil.createMotionPhotoFromJpegImageAndBmffVideo()即可建立原況照片。 - 新增
WebmMuxer,即可將OPUS、VORBIS、VP8和VP9媒體串流多工處理成webm檔案格式。
- 新增
- IMA 擴充功能:
- 移除自訂 Proguard 規則,讓應用程式改用 IMA Android 封存檔中發布的規則。
- 新增
ImaServerSideAdInsertionUriBuilder.setNetworkCode,這個新 API 可為 IMA SDK 設定 Google Ad Manager 聯播網代碼,以便處理廣告 ID,如 Google Ad Manager 設定中所指定。網路代碼為選填欄位,但建議用於 Full 服務串流要求。如要找出聯播網代碼,請參閱這篇文章。 - 將 IMA 依附元件升級至 3.37.0,這需要啟用核心程式庫的去糖化功能。相依應用程式也必須啟用這項功能。請參閱 IMA 的設定注意事項。
- 在 SSAI URI 產生器中支援 IMA DAI 自訂 UI 選項。伺服器端廣告插播的自訂 UI 選項包括「可略過」和「關於這則廣告」的顯示支援。這項功能目前僅供已列入許可清單的特定發布商使用。這項變更也會將 IMA SDK 版本升級至 3.38.0 (版本資訊),以便存取自訂 UI 選項 API。
- 工作階段:
- 在
MediaSession.Callback.onPlaybackResumption中新增參數,指出呼叫是僅用於收集資訊,還是用於開始播放 (#1764)。 - 更新
MediaSession.ControllerInfo.isTrusted,將自有應用程式中的控制器也宣告為可信任 (#2542)。 - 新增
MediaSessionService.triggerNotificationUpdate,手動觸發通知更新 (#1833)。 - 在自訂指令方法中加入
ProgressListener。 - 將
MediaLibrarySession.Builder.setLibraryErrorReplicationMode的預設值變更為非嚴重錯誤。 - 在
MediaButtonReceiver.onForegroundServiceStartNotAllowedException中新增Context參數 (#2625)。 - 從平台
PlaybackInfo讀取音量控制 ID,而不是透過繫結器擷取。這可確保系統會以不可分割的方式讀取播放類型和音量控制 ID,且兩者相符。 - 修正錯誤:系統會先篩除
ACTION_UP鍵事件,再將這些事件傳遞至回呼以進行自訂處理。這與 media1 的做法和平台做法一致 (#2637)。 - 修正錯誤:即使指令無法使用,
PlayerWrapper仍會呼叫getCurrentTimeline()(#2665)。 - 修正錯誤:訊息會留在主要 Looper 的訊息佇列中,導致服務終止後發生記憶體流失問題 (#2692)。
- 如果連線至舊版工作階段應用程式 (使用
MediaBrowser),只有在舊版工作階段的PlaybackStateCompat中將自訂動作宣傳為自訂動作時,自訂指令才會傳送至工作階段。所有其他自訂動作都會傳送至服務。 - 實作
onAudioSessionIdChanged,在工作階段設定音訊工作階段 ID 時通知媒體控制器 (#244)。 - 修正錯誤:
KEYCODE_HEADSETHOOK在onStartCommand()中收到媒體鍵事件Intent時,不會啟動播放器。只要像處理KEYCODE_MEDIA_PLAY_PAUSE一樣處理「KEYCODE_HEADSETHOOK」,即可修正這個問題 (#2816)。 - 修正錯誤:工作階段和控制器之間未傳達 Surface 大小,導致無法在 demo-session 中套用影片效果。如果您使用控制器,且播放器無法處理
setVideoSurfaceHolder呼叫,這可能就是重大變更。 - 修正非
StringCharSequence中繼資料值 (例如 span 樣式字串) 的傳播問題 (#2853)。
- 在
- UI:
- 將
ProgressStateWithTickInterval類別和對應的rememberProgressStateWithTickInterval可組合項新增至media3-ui-compose模組。這個狀態持有者用於demo-compose,以文字形式顯示目前位置和時間長度。 - 將
MuteButtonState新增至ui-compose,處理音量靜音。Player這個狀態持有者會在demo-compose中顯示靜音/取消靜音切換按鈕。 - 將
ProgressStateWithTickCount類別和對應的rememberProgressStateWithTickCountComposable 新增至media3-ui-compose模組。這個狀態持有者用於demo-compose,以顯示進度,形式為唯讀的水平進度列。 - 將
ContentFrame可組合函式新增至media3-ui-compose,將PlayerSurface管理與長寬比大小調整和遮蓋功能結合。 - 解決已知 API 34 平台錯誤,該錯誤會導致在 Compose
AndroidView中使用SurfaceView時,影片遭到拉伸/裁剪,進而影響ContentFrame和PlayerSurface可組合項與SURFACE_TYPE_SURFACE_VIEW(#1237、#2811)。 - 建立新的
media3-ui-compose-material3模組,並在其中新增 Material 3 主題的可組合函式 (PlayPauseButton、NextButton、PreviousButton、SeekBackButton、SeekForwardButton、RepeatButton、ShuffleButton、MuteButton)。 - 新增支援在
PlayerView中放置媒體路線按鈕。
- 將
- HLS 擴充功能:
- DASH 擴充功能:
- RTSP 擴充功能:
- 處理處理 H264 和 H265 的片段化 NAL 單元時,缺少 RTP 封包的錯誤 (#2613)。
- 解碼器擴充功能 (FFmpeg、VP9、AV1 等):
- AV1 擴充功能:AV1 軟體解碼器現在使用高效能的
dav1d程式庫,取代先前的libgav1實作項目,以提升解碼速度。
- AV1 擴充功能:AV1 軟體解碼器現在使用高效能的
- Cast 擴充功能:
- 新增
CastPlayer.Builder,啟用CastPlayer的本機和 Cast 播放功能。如要保留舊版CastPlayer行為,僅支援 Cast 播放,可以使用RemoteCastPlayer。現有的CastPlayer建構函式會保留舊行為,但會遭到淘汰,建議改用CastPlayer或RemoteCastPlayer建構工具。 - 停止在
DefaultMediaItemConverter中強制執行不可為空值的 MIME 類型。 - 如果有的話,請使用
MediaItem.mediaMetadata.mediaType推斷要在DefaultCastOptionsProvider#toMediaQueueItem中使用的 Cast MEDIA_TYPE。 - 在
DefaultCastOptionsProvider中啟用遠端到本機的轉移功能。 - 在工作階段示範中新增 Cast 支援。
- 支援在可組合的 UI 上顯示媒體路線按鈕。
- 新增支援功能,在動作列選單中顯示媒體路線按鈕。
- 支援將媒體路線按鈕顯示為 View UI。
- 新增
- 測試公用程式:
- 新增
FakeClock自動前進行為的最大時間差。預設為 1 秒,但可透過FakeClock.Builder設定。 - 新增訊息間的最大時間差 (適用於
RobolectricUtil.runMainLooperUntil和runLooperUntil)。預設值為 1 秒,但可透過這些方法的新多載設定。 - 將
CapturingRenderersFactory從test-utils移至test-utils-robolectric。
- 新增
- 移除已淘汰的符號:
- 移除已淘汰的
DefaultPreloadManager建構函式。改用DefaultPreloadManager.Builder。 - 移除了已淘汰的
EditedMediaItemSequence建構函式。改用EditedMediaItemSequence.Builder。
- 移除已淘汰的
1.8.0 版
1.8.0 版
2025 年 7 月 30 日
1.8.0 版包含這些修訂項目。
- 通用程式庫:
- 新增在
ForwardingSimpleBasePlayer中取代播放器的支援。
- 新增在
- ExoPlayer:
- 將隨機播放模式的 getter 新增至
ExoPlayer介面 (#2522)。 - 如果從多個執行緒存取
DefaultAudioSink,則會更清楚地擲回例外狀況。如果這是因為在播放器外部呼叫RendererCapabilities.getFormatSupport所致,請務必在與 ExoPlayer 播放執行緒相同的執行緒上呼叫這個方法,或使用與播放所用例項不同的例項 (#1191)。 - 修正錯誤:電視上的非立體聲音訊格式可能會標示為
DefaultTrackSelector不支援。 - 使用 MediaCodec 的
DECODE_ONLY旗標時 (在清除模式中預設為啟用),請確保最後一個影格正確算繪。 - 新增支援功能,可使用從
Context傳遞至ExoPlayer.Builder的虛擬裝置 ID。 - 在清除模式中,預設啟用動態排程。
- 避免在搜尋項目結尾時,不必要地重新載入來源。
- 在清除模式中,預設使用
MediaCodec.BUFFER_FLAG_DECODE_ONLY。 - 當
PreloadMediaSource由ExoPlayer播放,且播放執行緒與預先載入執行緒不同時,擲回IllegalStateException(#2495)。 - 在
ShuffleMode中新增cloneAndMove,並使用預設實作項目 (#2226)。 - 如果不需要呼叫
render,請變更Renderer.getMinDurationToProgressUs的預設行為,傳回較大的值。 - 修正錯誤:暫停時搜尋至結尾,內部排程會延遲最後一格畫面。目前,只有在啟用
ExoPlayer.Builder.experimentalSetDynamicSchedulingEnabled時,錯誤修正才會生效。 - 新增
ExoPlayer.setScrubbingModeEnabled(boolean)方法。這項設定可針對許多頻繁的搜尋動作 (例如使用者拖曳搜尋列) 最佳化播放器。您可以在ExoPlayer和ExoPlayer.Builder上使用setScrubbingModeParameters(..)自訂快轉模式的行為。 - 允許在快轉/倒轉模式中自訂部分搜尋容許值。
- 在清除模式中提高轉碼器運作速率。
- 修正錯誤:
AdsMediaSource內容中的準備錯誤可能永遠不會回報 (#2337)。 - 修正
MergingMediaSource中的記憶體流失問題,例如側載字幕時會使用MergingMediaSource(#2338)。 - 允許
CmcdConfiguration.Factory傳回null,針對特定媒體項目停用 CMCD 記錄 (#2386)。 - 將預設圖片緩衝區大小從 128 KB (從文字軌複製貼上時發生錯誤) 增加至 26 MB,這足以容納 5000 萬像素的 Ultra HDR 圖片 (#2417)。
- 新增
PreCacheHelper,讓應用程式預先快取單一媒體,並指定開始位置和時間長度。 - 在
DefaultPreloadManager中新增從指定位置預先載入的支援。
- 將隨機播放模式的 getter 新增至
- 轉換程式:
- 新增
CodecDbLite,可針對晶片組最佳化影片編碼設定。 - 在
DefaultEncoderFactory中新增setEnableCodecDbLite標記,啟用 CodecDB Lite 設定最佳化功能。這項旗標預設為 false。 - 如要填補初始間隙 (透過
addGap()新增),現在必須在EditedMediaItemSequence.Builder中明確設定experimentalSetForceAudioTrack(true)。如果間隙位於序列中間,則不需要這個標記。 - 將
Muxer介面從media3-transformer移至media3-muxer。 - 將「
MediaItem.Builder().setImageDuration(long)」設為必要設定,才能將媒體項目匯入為圖片。 - 新增
Transformer.Builder().experimentalSetMp4EditListTrimEnabled(boolean),其中包含修剪時的 MP4 編輯清單,指示播放器忽略修剪起點前的主要畫面格與修剪起點之間的樣本。 - 更新 Composition Demo 應用程式,改用 Kotlin 和 Jetpack Compose,並新增自訂
VideoCompositorSettings,將序列排列成 2x2 或子母畫面版面配置。
- 新增
- 擷取工具:
- 從片段化 MP4 檔案剖析中繼資料 (#2084)。
- JPEG:支援開頭沒有 Exif 區段的動態相片 (#2552)。
- 新增支援:在具有多個
sidx原子片段的 MP4 中搜尋。 您可以在FragmentedMp4Extractor上使用FLAG_MERGE_FRAGMENTED_SIDX旗標啟用這項行為 (#9373)。 - 忽略 FLAC 檔案中的空白搜尋表 (包括僅含預留位置搜尋點的搜尋表),並在已知檔案長度時,改用二分搜尋法 (#2327)。
- 修正 H.265 SEI 單元的剖析問題,完全略過無法辨識的 SEI 類型 (#2456)。
- 更新
WavExtractor,在剖析WAVE_FORMAT_EXTENSIBLE類型檔案時,使用標頭擴充功能的 SubFormat 資料做為音訊格式。 - MP4:新增對
ipcm和fpcm方塊的支援,定義原始 PCM 音訊軌 (不支援 64 位元浮點 PCM)。 - MP4:處理
tkhd轉換矩陣的旋轉部分,該矩陣會旋轉及反映影片。這樣可確保 iPhone 前置鏡頭拍攝的反射影片會正向顯示,但會沿著 Y 軸錯誤反射 (#2012)。 - MP3:由於
FLAG_ENABLE_CONSTANT_BITRATE_SEEKING(_ALWAYS)(#2194),當回溯至固定位元率搜尋時,請使用來自無法搜尋的 Xing、VBRI 和類似可變位元率中繼資料的持續時間和資料大小。
- 音訊:
- 修正錯誤:音訊播放時間非常接近媒體結尾時,不會呼叫
AnalyticsListener.onAudioPositionAdvancing。 - 在
ChannelMappingAudioProcessor和TrimmingAudioProcessor中新增對所有線性 PCM 樣本格式的支援。 - 在
CompositionPlayer中新增音訊間隙支援。 - 從
BaseAudioProcessor#reset()移除對BaseAudioProcessor#flush()的虛假呼叫。 - 允許在 DefaultAudioMixer 中進行恆定功率升混/降混。
- 將
ChannelMappingAudioProcessor、TrimmingAudioProcessor和ToFloatPcmAudioProcessor設為公開 (#2339)。 - 在
AudioTrackPositionTracker中使用AudioTrack#getUnderrunCount(),在DefaultAudioSink中偵測欠載,而不是盡量估算。 - 改善音訊時間戳記平滑度,避免音訊輸出裝置發生非預期的位置偏移。
- 修正錯誤:連線至藍牙裝置時,從暫停狀態恢復播放後,前 10 秒的音訊/視訊會不同步。
- 修正
AnalyticsListener.onAudioPositionAdvancing未回報音訊開始前進的時間,但回報第一次測量時間的錯誤。 - 修正部分裝置在備用立體聲音訊後,無法復原為多聲道音訊的問題 (#2258)。
- 修正錯誤:音訊播放時間非常接近媒體結尾時,不會呼叫
- 影片:
- 將已卸除螢幕的 Surface 解決方法擴展至「lenovo」和「motorola」裝置 (#2059)。
- 如果音訊樣本並非從確切要求的位置開始,則在啟動時,改善影片影格的順暢發布情形。
- 將已卸除螢幕的 Surface 解決方法擴展至「realme」裝置 (#2059)。
- 新增實驗性
ExoPlayerAPI,在將僅解碼的輸入緩衝區加入佇列時,加入MediaCodec.BUFFER_FLAG_DECODE_ONLY旗標。這個標記會通知解碼器略過僅解碼的緩衝區,進而加快搜尋速度。使用DefaultRenderersFactory.experimentalSetEnableMediaCodecBufferDecodeOnlyFlag啟用。 - 改善軟體視訊轉碼器的轉碼器效能檢查。這可能會導致部分額外曲目標示為
EXCEEDS_CAPABILITIES。 - 修正部分裝置上的 VP9 Widevine 播放錯誤 (#2408)。
- 文字:
- 新增對 MP4 檔案中 VobSub 音軌的支援 (#2510)。
- 修正字幕片段一開始載入失敗,但稍後載入成功,接著出現多個空白字幕片段時,播放會停滯的問題 (#2517)。
- 修正 SSA 和 SubRip,在啟用字幕時顯示進行中的提示 (#2309)。
- 修正從有字幕錯誤的串流切換至有空白字幕軌的直播時,播放會卡住的問題 (#2328)。
- 修正播放含有 B 畫面 (#2372) 的 H.262 串流時,CEA-608 字幕會亂碼的問題。
- 在 Matroska 檔案中新增對 SSA 字幕的
CodecId = S_TEXT/SSA支援。先前MatroskaExtractor只支援CodecId = S_TEXT/ASS,這代表 SubStation Alpha 字幕的「進階」版本 (v4 以上),但 ExoPlayer 的剖析邏輯在這兩個版本中相同 (#2384)。 - 在 SubStation Alpha (SSA) 字幕檔案中新增
layer屬性的支援功能,用於定義提示的 Z 順序,以便在螢幕上同時顯示多個提示時使用 (#2124)。
- 中繼資料:
- 新增支援擷取媒體時間長度和
Timeline的MetadataRetriever,並將其遷移至以例項為基礎的AutoCloseableAPI。使用新的Builder為MediaItem建立例項,然後呼叫retrieveTrackGroups()、retrieveTimeline()和retrieveDurationUs(),取得中繼資料的ListenableFuture。先前的靜態方法現已淘汰 (#2462)。
- 新增支援擷取媒體時間長度和
- 圖片:
- 將解碼點陣圖限制為
BitmapFactoryImageDecoder中的顯示大小,以免應用程式嘗試顯示非常大的圖片 (例如 5000 萬像素) 時,因PlayerView而發生Canvas: trying to draw too large bitmap.導致當機。 - 變更
DefaultRenderersFactory.getImageDecoderFactory()的簽章,以採用Context參數。 - 將
CompositionPlayer中使用的點陣圖輸出大小上限,與Transformer中已使用的點陣圖輸出大小上限對齊 (也就是說,CompositionPlayer不會像ExoPlayer一樣在解碼點陣圖時考量螢幕大小)。
- 將解碼點陣圖限制為
- DRM:
- 新增
OfflineLicenseHelper.newWidevineInstance的新多載,接受MediaItem.DrmConfiguration,以便正確套用 HTTP 要求標頭 (#2169)。
- 新增
- 效果:
- 新增
Presentation.createForShortSide(int),建立Presentation,確保最短邊一律符合指定值,無論輸入方向為何。
- 新增
- Muxers:
- 修正錯誤:在 MP4 碎片中,音訊樣本未設定正確的樣本標記。
writeSampleData()API 現在使用 Muxer 專屬的BufferInfo類別,而非MediaCodec.BufferInfo。- 新增
Muxer.Factory#supportsWritingNegativeTimestampsInEditList,預設為 false。
- IMA 擴充功能:
- 修正錯誤:一個廣告發生載入錯誤時,可能會意外導致另一個廣告群組失效。
- 修正錯誤:VOD 視窗結束後,廣告群組會導致播放停止。
如果廣告群組的開始時間晚於時間範圍,系統就不會再將其加入佇列 (#2215)。
MediaPeriodQueue
- 工作階段:
- 修正錯誤:系統會忽略來自第三方非具備權限的 Media3 控制器連線。
- 將自訂指令傳送至舊版
MediaBrowserServiceCompat時,請移除可用指令的檢查作業。這與連線至舊版應用程式時,舊版控制器/瀏覽器的行為一致。 - 修正錯誤,避免系統將播放器的第一個播放錯誤誤認為持續性自訂例外狀況。這會導致應用程式無法復原。
- 修正錯誤:部分未由工作階段處理的控制器變更可能會導致
IllegalStateExceptions。 - 修正錯誤:如果工作階段未處理控制器動作,可能會導致控制器處於無效狀態。
- 修正 StrictMode 不安全啟動違規警告 (#2330)。
- 修正錯誤:從主執行緒呼叫
setSessionExtras時,如果從主執行緒以外的應用程式執行緒執行播放器,會導致IllegalStateException(#2265)。 - 如果玩家設定了媒體項目,但未準備或播放這些項目,請勿自動顯示通知 (#2423 https://github.com/androidx/media/issues/2423)。您可以透過
MediaSessionService.setShowNotificationForIdlePlayer設定這項行為。 - 為所有或選取的控制器新增自訂
PlaybackException。 - 修正錯誤:在
MediaController上搜尋直播內容時,可能會導致IllegalArgumentException。 - 如果是直播,請停止發布播放位置,並禁止平台媒體控制器在目前項目中搜尋,以免 Android Auto 使用者介面 (以及其他使用平台媒體工作階段資訊的控制器) 出現位置錯誤 (#1758)。
- 修正錯誤:將空值傳遞至連結至舊版
MediaBrowserServiceCompat的MediaBrowser的getLibraryRoot時,會產生NullPointerException。 - 修正錯誤:傳送自訂動作、搜尋結果或 getItem 要求時,舊版工作階段應用程式會因
ClassNotFoundException而當機。 - 修正
MediaItem.LocalConfiguration.uri分享至平台工作階段的MediaMetadata時發生的錯誤。如要刻意分享 URI,讓控制器重新要求媒體,請改為設定MediaItem.RequestMetadata.mediaUri。
- UI:
- 修正錯誤:
PlayerSurface在可重複使用的元件 (例如LazyColumn) 內無法正常運作 (#2493)。 - 修正 Compose 錯誤,這個錯誤會導致設定初始按鈕狀態與觀察狀態變化 (例如圖示形狀或是否啟用) 之間出現間隙。現在系統會擷取觀察期外對 Player 所做的任何變更 (#2313)。
- 在
media3-ui-compose模組中新增SeekBackButtonState和SeekForwardButtonState的狀態持有者和可組合函式。 - 在
PlayerControlView中新增對 ExoPlayer 搜尋模式的支援。啟用後,當使用者開始拖曳滑桿時,播放器會進入快轉模式,並針對每次移動發出player.seekTo呼叫,然後在手指離開螢幕時退出快轉模式。如要啟用這項整合功能,請在 XML 中使用time_bar_scrubbing_enabled = true,或透過 Java/Kotlin 使用setTimeBarScrubbingEnabled(boolean)方法。 - 讓
PlayerSurface接受可為空值的Player引數。
- 修正錯誤:
- 下載內容:
- 新增對漸進式串流的部分下載支援。應用程式可以使用
DownloadHelper準備漸進式串流,並向輔助程式要求DownloadRequest,同時指定下載應涵蓋的時間型媒體開始和結束位置。傳回的DownloadRequest包含已解析的位元組範圍,可用於建立ProgressiveDownloader並下載相應內容。 - 新增
DownloadHelper.Factory,取代靜態DownloadHelper.forMediaItem()方法。 - 為
SegmentDownloader實作項目新增Factory。 - 新增對自適應串流的部分下載支援。應用程式可以使用
DownloadHelper準備自適應串流,並向輔助程式要求DownloadRequest,同時指定下載內容應涵蓋的媒體開始和結束時間位置。傳回的DownloadRequest會攜帶已解析的時間範圍,藉此建立具體的SegmentDownloader,並下載相應內容。
- 新增對漸進式串流的部分下載支援。應用程式可以使用
- Cronet 擴充功能:
- 新增自動 Cookie 處理功能 (#5975)。
- HLS 擴充功能:
- 修正錯誤:緩衝區中沒有可用區塊時,
HlsSampleStreamWrapper會嘗試在緩衝區內搜尋 #2598。 - 修正在載入低延遲部分和預先載入提示後,音軌選取項目變更會導致播放停滯或凍結的問題 (#2299)。
- 如果伺服器未遵守
CAN-BLOCK-RELOAD=YES,請等待目標時間長度的一半,避免過度重新載入 (#2317)。 - 修正錯誤:在插播廣告前啟動插播串流時,系統會嘗試為錯誤的廣告解析中途廣告和資產清單,導致播放停滯 (#2558)。
- 修正播放清單剖析功能,接受引號字串屬性值中的
\f(表單動態饋給) (#2420)。 - 支援更新具有相同 ID 的插頁式廣告 (#2427)。
- 修正錯誤:直播活動沒有可載入的片段時,有時不會傳播播放清單載入錯誤 (#2401https://github.com/androidx/media/issues/2401)。
- 依據 NAME 標記將字幕轉譯版本分組,與音訊轉譯版本的分組方式類似 (#1666)。
- 支援 X-ASSET-LIST 和直播,並使用
HlsInterstitialsAdsLoader。
- 修正錯誤:緩衝區中沒有可用區塊時,
- DASH 擴充功能:
- RTSP 擴充功能:
- 解碼器擴充功能 (FFmpeg、VP9、AV1 等):
- 修正
DefaultTrackSelector.setAllowInvalidateSelectionsOnRendererCapabilitiesChange對音訊解碼器擴充功能沒有影響的錯誤 (#2258)。
- 修正
- Cast 擴充功能:
- 測試公用程式:
- 在
TestPlayerRunHelper中新增advance(player).untilPositionAtLeast和untilMediaItemIndex,即可將播放器快轉至指定位置。在大多數情況下,這些方法比現有的untilPosition和untilStartOfMediaItem方法更可靠。 - 將
FakeDownloader移至test-utils-robolectric模組,以便在其他測試中重複使用。 - 已移除
transformer.TestUtil.addAudioDecoders(String...)、transformer.TestUtil.addAudioEncoders(String...)和transformer.TestUtil.addAudioEncoders(ShadowMediaCodec.CodecConfig, String...)。請改用ShadowMediaCodecConfig設定陰影編碼器和解碼器。 - 在
ShadowMediaCodecConfig回報的轉碼器名稱中,將「exotest」前置字元替換為「media3」。
- 在
- 移除已淘汰的符號:
- 移除了已淘汰的
SegmentDownloader建構函式SegmentDownloader(MediaItem, Parser<M>, CacheDataSource.Factory, Executor),以及子類別DashDownloader、HlsDownloader和SsDownloader中的對應建構函式。 - 已移除已淘汰的
Player.hasNext()、Player.hasNextWindow()。請改用Player.hasNextMediaItem()。 - 已移除已淘汰的
Player.next()。改用Player.seekToNextMediaItem()。 - 已移除已淘汰的
Player.seekToPreviousWindow()。改用Player.seekToPreviousMediaItem()。 - 已移除已淘汰的
Player.seekToNextWindow()。改用Player.seekToNextMediaItem()。 - 已移除
exoplayer模組中已淘汰的BaseAudioProcessor。使用common模組下的BaseAudioProcessor。 - 移除已淘汰的
MediaCodecVideoRenderer建構函式MediaCodecVideoRenderer(Context, MediaCodecAdapter.Factor, MediaCodecSelector, long, boolean, @Nullable Handler, @Nullable VideoRendererEventListener, int, float, @Nullable VideoSinkProvider)。
- 移除了已淘汰的
1.8.0-rc02 版
2025 年 7 月 24 日
使用 1.8.0 穩定版。
1.8.0-rc01 版
2025 年 7 月 16 日
使用 1.8.0 穩定版。
1.8.0-beta01 版
2025 年 7 月 2 日
使用 1.8.0 穩定版。
1.8.0-alpha01 版
2025 年 5 月 19 日
使用 1.8.0 穩定版。
1.7.0 版
1.7.1 版
2025 年 5 月 16 日
這個版本與 1.6.1 版的程式碼相同,發布這個版本是為了確保它會顯示為「較新」版本,而非 1.7.0 版。1.7.0 版是誤標為穩定版的 Alpha 版 (詳情請參閱下文)。
1.7.0 版
2025 年 5 月 16 日
這個版本應為 1.7.0-alpha01,但 maven.google.com 誤標為 1.7.0 (即穩定版)。請勿使用這個版本。繼續使用 1.6.1 版,或升級至 1.7.1 版 (程式碼與 1.6.1 版相同)。
1.6.0 版
1.6.1
2025 年 4 月 14 日
發布了 androidx.media3:media3-*:1.6.1。1.6.1 版包含這些修訂項目。
- 通用程式庫:
- 新增
PlaybackParameters.withPitch(float)方法,方便使用新的pitch值複製PlaybackParameters(#2257)。
- 新增
- ExoPlayer:
- 修正問題:由於初始化下一個媒體項目時發生可復原的轉譯器錯誤,導致媒體項目轉場失敗 (#2229)。
- 修正問題:
ProgressiveMediaPeriod會擲回IllegalStateException,因為PreloadMediaSource會嘗試在準備完成前呼叫getBufferedDurationUs()(#2315)。 - 修正傳送
CmcdData至 DASH、HLS 和 SmoothStreaming 的資訊清單要求 (#2253)。 - 確認移除廣告群組後,
AdPlaybackState.withAdDurationsUs(long[][])仍可使用。使用者仍須傳遞已移除廣告群組的持續時間陣列,該陣列可以空白或為空值 (#2267)。
- 擷取工具:
- MP4:從
tkhd方格剖析alternate_group,並在每個軌道的Format.metadata中將其公開為Mp4AlternateGroupData項目 (#2242)。
- MP4:從
- 音訊:
- 修正卸載問題,播放短片內容播放清單時,位置可能會停滯 (#1920)。
- 工作階段:
- 將平台
MediaSession回呼的匯總逾時時間從 500 毫秒縮短至 100 毫秒,並新增實驗性設定器,允許應用程式設定這個值。 - 修正使用者關閉通知後,通知會再次顯示的問題 (#2302)。
- 修正錯誤:當包裝播放器實際為空時,工作階段會傳回單一項目時間軸。如果封裝的播放器沒有可用的
COMMAND_GET_TIMELINE,但COMMAND_GET_CURRENT_MEDIA_ITEM可用,且封裝的播放器為空白 (#2320),就會發生這種情況。 - 修正錯誤:在與服務進行其他互動 (例如
setForegroundServiceTimeoutMs) 後,系統會無聲無息地忽略呼叫MediaSessionService.setMediaNotificationProvider的要求 (#2305)。
- 將平台
- UI:
- 啟用
PlayerSurface,以便與ExoPlayer.setVideoEffects和CompositionPlayer搭配使用。 - 修正
PlayerSurface無法使用新的Player重新組合的錯誤。
- 啟用
- HLS 擴充功能:
- 修正問題:
CmcdData未針對 HLS 媒體設定區塊時間長度,導致處理加密媒體片段時發生斷言失敗 (#2312)。
- 修正問題:
- RTSP 擴充功能:
- 新增對採用 RTSPT 配置欄位的 URI 的支援,以便將 RTSP 工作階段設定為使用 TCP (#1484)。
- Cast 擴充功能:
- 新增播放清單中繼資料支援 (#2235)。
1.6.0
2025 年 3 月 26 日
發布了 androidx.media3:media3-*:1.6.0。1.6.0 版包含這些修訂項目。
- 通用程式庫:
- 新增
AudioManagerCompat和AudioFocusRequestCompat,取代androidx.media中的對等類別。 - 將 Kotlin 從 1.9.20 升級至 2.0.20,並使用 Compose 編譯器 Gradle 外掛程式。將 KotlinX Coroutines 程式庫從 1.8.1 升級至 1.9.0。
- 移除
Format.toBundle(boolean excludeMetadata)方法,改用Format.toBundle()。 - 修正
SimpleBasePlayer中的錯誤:在setPlaylist之後,於State中設定新的currentMediaItemIndex(使用nullMediaMetadata) 時,不會重新評估中繼資料 (#1940)。 - 將
SimpleBasePlayer.State存取權從受保護變更為公開,方便在其他類別中處理更新 (#2128)。
- 新增
- ExoPlayer:
- 新增
MediaExtractorCompat,這個新類別提供的功能與平台MediaExtractor相同。 - 為使用
MediaCodecVideoRenderer播放新增實驗性「ExoPlayer」預先暖機支援。您可以透過experimentalSetEnableMediaCodecVideoRendererPrewarming設定DefaultRenderersFactory,提供次要MediaCodecVideoRenderer給ExoPlayer。啟用後,系統會在播放期間預先處理連續媒體項目的影片,以縮短媒體項目轉場延遲時間。ExoPlayer - 將
DefaultLoadControl中bufferForPlaybackMs和bufferForPlaybackAfterRebufferMs的預設值分別調降為 1000 和 2000 毫秒。 - 非同步初始化
DeviceInfo和裝置音量 (如果使用setDeviceVolumeControlEnabled啟用)。這些值在ExoPlayer.Builder.build()後不會立即提供,Player.Listener會透過onDeviceInfoChanged和onDeviceVolumeChanged通知變更。 - 建立播放器後,初始音訊工作階段 ID 不再立即提供。如有需要,可以使用
AnalyticsListener.onAudioSessionIdChanged聆聽初始更新內容。 - 選取影片軌時,請考量語言。根據預設,系統會選取與所選音軌語言相符的「主要」影片軌 (如有)。如要明確指定影片語言偏好設定,請使用
TrackSelectionParameters.Builder.setPreferredVideoLanguage(s)。 - 在
DefaultTrackSelector.selectVideoTrack()方法中新增selectedAudioLanguage參數。 - 在
MediaSourceEventListener.onLoadStarted和對應的MediaSourceEventListener.EventDispatcher方法中新增retryCount參數。 - 修正錯誤:如果多週期 DASH 串流中的播放清單項目或週期長度與實際內容不符,可能會導致項目結尾的影格凍結 (#1698)。
- 將
BasePreloadManager.Listener移至頂層PreloadManagerListener。 RenderersFactory.createSecondaryRenderer,為預先暖機提供次要算繪器。預先暖機可加快媒體項目在播放期間的轉場速度。- 啟用傳送
CmcdData,以用於自動調整串流格式 DASH、HLS 和 SmoothStreaming 的資訊清單要求 (#1951)。 - 提供要在
MediaCodecRenderer.onReadyToInitializeCodec中初始化的轉碼器MediaCodecInfo(#1963)。 - 將
AdsMediaSource改為允許AdPlaybackStates透過附加廣告群組來擴展。系統偵測到無效的修改,並擲回例外狀況。 - 修正問題:在片中廣告後轉換至內容媒體時,可能會快速連續顯示額外的僅解碼影格。
- 請讓
DefaultRenderersFactory新增兩個MetadataRenderer例項,讓應用程式預設接收兩種不同的中繼資料架構。 - 重新評估是否應在暫停播放時取消載入區塊 (#1785)。
- 新增
ClippingMediaSource選項,允許在無法搜尋的媒體中裁剪。 - 修正錯誤:使用預先暖機功能搜尋時,可能會封鎖後續媒體項目轉場效果。
- 修正
ExoPlayer.isLoading()轉換為STATE_IDLE或STATE_ENDED時,仍維持true的錯誤 (#2133)。 - 將
lastRebufferRealtimeMs新增至LoadControl.Parameter(#2113)。
- 新增
- 轉換程式:
- 新增支援轉封裝為可回溯相容的替代格式。
- 新增支援功能,可轉碼及轉封裝 Dolby Vision (設定檔 8) 格式。
- 更新
VideoFrameProcessor.registerInputStream和VideoFrameProcessor.Listener.onInputStreamRegistered的參數,以使用Format。 - 使用
DefaultEncoderFactory時,請產生 HDR 靜態中繼資料。 - 使用
MediaMetricsManager啟用 Android 平台診斷支援功能。Transformer 會向平台轉送編輯事件和效能資料,有助於在裝置提供系統效能與偵錯資訊。如果裝置使用者已啟用分享使用狀況與診斷資料功能,則 Google 也可能會收集以上資料。您可以透過Transformer.Builder.setUsePlatformDiagnostics(false),讓應用程式選擇不採用 Transformer 的平台診斷貢獻功能。 - 將
InAppMuxer分成InAppMp4Muxer和InAppFragmentedMp4Muxer。 您可以使用InAppMp4Muxer產生非片段化 MP4 檔案,而InAppFragmentedMp4Muxer則用於產生片段化 MP4 檔案。 - 將
Muxer介面從media3-muxer移至media3-transformer。 - 新增
MediaProjectionAssetLoader,從MediaProjection提供媒體,用於螢幕錄影,並在 Transformer 試用版應用程式中新增螢幕錄影支援功能。 - 將
#getInputFormat()新增至Codec介面。 - 盡可能將釋出
GlObjectsProvider的責任轉移至DefaultVideoFrameProcessor和DefaultVideoCompositor中的呼叫端。
- 擷取工具:
- AVI:修正處理含有固定位元率壓縮音訊的檔案時,串流標頭儲存位元組數而非區塊數的問題。
- 修正以 1 或 2 個位元組 (而非 4 個) 表示長度的 NAL 單元處理方式。
- 修正 MP4 編輯清單中的
ArrayIndexOutOfBoundsException,編輯清單從非同步影格開始,且沒有前一個同步影格時 (#2062)。 - 修正部分裝置上 TS 串流可能會停滯的問題 (#2069)。
- FLAC:新增 32 位元 FLAC 檔案支援。先前這些項目無法使用
IllegalStateException: Playback stuck buffering and not loading播放 (#2197)。
- 音訊:
- 修正
onAudioPositionAdvancing的呼叫時機,改為在播放作業繼續時呼叫 (先前是在播放作業暫停時呼叫)。 - 如果
SpeedChangingAudioProcessor設定為預設參數,請勿略過SonicAudioProcessor。 - 修正
Sonic#getOutputSize()中的下溢問題,避免DefaultAudioSink停滯。 - 修正
MediaCodecAudioRenderer.getDurationToProgressUs()和DecoderAudioRenderer.getDurationToProgressUs(),確保搜尋作業能正確重設提供的持續時間。 - 將
androidx.media3.common.audio.SonicAudioProcessor設為最終版本。 - 在
ChannelMappingAudioProcessor和TrimmingAudioProcessor中新增對浮點 PCM 的支援。
- 修正
- 影片:
- 將
MediaCodecVideoRenderer.shouldUsePlaceholderSurface變更為 受保護,以便應用程式覆寫,封鎖預留位置介面的使用情形 (#1905)。 - 新增實驗性
ExoPlayerAV1 樣本依附元件剖析,加快搜尋速度。使用新的DefaultRenderersFactory.experimentalSetParseAv1SampleDependenciesAPI 啟用這項功能。 - 新增實驗性
ExoPlayerAPI,可捨棄不依附的延遲MediaCodecVideoRenderer解碼器輸入緩衝區。使用DefaultRenderersFactory.experimentalSetLateThresholdToDropDecoderInputUs啟用。 - 修正沒有介面的播放器會立即就緒,但解碼任何待處理影格的速度非常緩慢的問題 (#1973)。
- 從卸除式介面模式排除 Xiaomi 和 OPPO 裝置,避免螢幕閃爍 (#2059)。
- 將
- 文字:
- 新增 VobSub 字幕支援 (#8260)。
- 停止使用
MediaItem.Builder.setSubtitleConfigurations預先載入所有設定的字幕檔,改為只載入所選音軌的字幕檔 (#1721)。 - TTML:新增使用
style參照tts:origin和tts:extent的支援 (#2953)。 - 將 WebVTT 和 SubRip 時間戳記限制為精確到小數點後 3 位。 先前我們錯誤地剖析了任意數量的小數位數,但一律假設值是以毫秒為單位,導致時間戳記錯誤 (#1997)。
- 修正播放清單包含 CEA-608 或 CEA-708 字幕的剪輯項目時,播放作業停止的問題。
- 修正 SSA 檔案包含時間長度為零的提示 (開始和結束時間相同) 時的
IllegalStateException(#2052)。 - 將字幕多工處理至與音訊和視訊相同的容器時,抑制 (並記錄) 字幕剖析錯誤 (#2052)。
- 修正使用 CR 行尾的 WebVTT 檔案中,多位元組 UTF-8 字元的處理方式 (#2167)。
- DRM:
- 修正在 API 低於 27 的裝置上播放 ClearKey 內容時發生的
MediaCodec$CryptoException: Operation not supported in this configuration錯誤 (#1732)。
- 修正在 API 低於 27 的裝置上播放 ClearKey 內容時發生的
- 效果:
- 已將
OverlaySettings的功能移至StaticOverlaySettings。OverlaySettings可以設為子類別,允許動態疊加設定。
- 已將
- Muxers:
- 將
MuxerException移出Muxer介面,避免出現過長的完整名稱。 - 在
Mp4Muxer.Builder和FragmentedMp4Muxer.Builder中,已將setSampleCopyEnabled()方法重新命名為setSampleCopyingEnabled()。 Mp4Muxer.addTrack()和FragmentedMp4Muxer.addTrack()現在會傳回int軌道 ID,而不是TrackToken。Mp4Muxer和FragmentedMp4Muxer不再實作Muxer介面。- 預設停用
Mp4Muxer樣本批次處理和複製功能。 - 修正
FragmentedMp4Muxer中的錯誤,此錯誤會在只寫入音軌時建立大量片段。
- 將
- 工作階段:
- 當播放暫停、停止或失敗時,額外保留前景服務狀態 10 分鐘。這樣一來,使用者就能在逾時前繼續播放內容,而不必擔心各種裝置的前景服務限制。請注意,覆寫
onTaskRemoved時,您無法再使用player.pause()呼叫在stopSelf()前停止前景服務,請改用MediaSessionService.pauseAllPlayersAndStopSelf()。 - 當播放進入錯誤或停止狀態時,請保持通知顯示。只有在清除播放清單或釋出播放器時,系統才會移除通知。
- 改善 Android 平台 MediaSession 動作 ACTION_PLAY 和 ACTION_PAUSE 的處理方式,只根據可用指令設定其中一個動作,並接受只設定其中一個動作的情況。
- 將
Context新增為MediaButtonReceiver.shouldStartForegroundService的參數 (#1887)。 - 修正錯誤:在連線至舊版工作階段的
MediaController上呼叫Player方法時,系統會捨棄待處理更新中的變更。 - 讓
MediaSession.setSessionActivity(PendingIntent)接受空值 (#2109)。 - 修正播放清單清除後,過時通知仍會顯示的錯誤 (#2211)。
- 當播放暫停、停止或失敗時,額外保留前景服務狀態 10 分鐘。這樣一來,使用者就能在逾時前繼續播放內容,而不必擔心各種裝置的前景服務限制。請注意,覆寫
- UI:
- 將狀態持有者和可組合函式新增至
media3-ui-compose模組,適用於PlayerSurface、PresentationState、PlayPauseButtonState、NextButtonState、PreviousButtonState、RepeatButtonState、ShuffleButtonState和PlaybackSpeedState。
- 將狀態持有者和可組合函式新增至
- 下載內容:
- 修正
CacheWriter中的錯誤,如果資料來源擲回Exception(而非IOException),就會導致資料來源保持開啟,且快取區域遭到鎖定 (#9760)。
- 修正
- HLS 擴充功能:
- 新增
HlsInterstitialsAdsLoader的第一個版本。廣告載入器會讀取 HLS 媒體播放清單的 HLS 插頁式廣告,並將這些廣告對應至傳遞至AdsMediaSource的AdPlaybackState。這個初始版本僅支援具有X-ASSET-URI屬性的 HLS VOD 串流。 - 新增
HlsInterstitialsAdsLoader.AdsMediaSourceFactory。應用程式可以使用這項功能建立AdsMediaSource例項,以便利安全的方式使用HlsInterstitialsAdsLoader。 - 從 HLS 播放清單剖析
SUPPLEMENTAL-CODECS標記,偵測 Dolby Vision 格式 (#1785)。 - 放寬在 HLS 串流中搜尋同步位置的條件 (#2209)。
- 新增
- DASH 擴充功能:
- 解碼器擴充功能 (FFmpeg、VP9、AV1 等):
- 新增 MPEG-H 解碼器模組,使用內建的 MPEG-H 解碼器解碼 MPEG-H 音訊 (#1826)。
- MIDI 擴充功能:
- 將自訂
AudioSink和AudioRendererEventListener執行個體導入MidiRenderer。
- 將自訂
- Cast 擴充功能:
- 將
play-services-cast-framework依附元件升級至 21.5.0,修正應用程式在搭載 Google Play 服務但已停用的裝置上,指定 API 34 以上版本時發生的FLAG_MUTABLE錯誤 (#2178)。
- 將
- 試用版應用程式:
- 擴充
demo-compose,新增其他按鈕,並透過縮放和快門支援功能,提升PlayerSurface整合體驗。
- 擴充
- 移除已淘汰的符號:
- 移除已淘汰的
AudioMixer.create()方法。改用DefaultAudioMixer.Factory().create()。 - 移除下列已淘汰的
Transformer.Builder方法:setTransformationRequest(),請改用setAudioMimeType()、setVideoMimeType()和setHdrMode()。setAudioProcessors(),請在EditedMediaItem.Builder.setEffects()中設定音訊處理器,然後傳遞至Transformer.start()。setVideoEffects(),在EditedMediaItem.Builder.setEffects()中設定影片效果,然後傳遞至Transformer.start()。setRemoveAudio(),請改用EditedMediaItem.Builder.setRemoveAudio()從傳遞至EditedMediaItem的Transformer.start()中移除音訊。setRemoveVideo(),請改用EditedMediaItem.Builder.setRemoveVideo()從傳遞至Transformer.start()的EditedMediaItem中移除影片。- 請改用
EditedMediaItem.Builder.setFlattenForSlowMotion(),將傳遞至Transformer.start()的EditedMediaItem扁平化。setFlattenForSlowMotion() setListener(),請改用addListener()、removeListener()或removeAllListeners()。
- 移除下列已淘汰的
Transformer.Listener方法:onTransformationCompleted(MediaItem),請改用onCompleted(Composition, ExportResult)。onTransformationCompleted(MediaItem, TransformationResult),請改用onCompleted(Composition, ExportResult)。onTransformationError(MediaItem, Exception),請改用onError(Composition, ExportResult, ExportException)。onTransformationError(MediaItem, TransformationException),請改用onError(Composition, ExportResult, ExportException)。onTransformationError(MediaItem, TransformationResult, TransformationException),請改用onError(Composition, ExportResult, ExportException)。onFallbackApplied(MediaItem, TransformationRequest, TransformationRequest),請改用onFallbackApplied(Composition, TransformationRequest, TransformationRequest)。
- 移除已淘汰的
TransformationResult類別。改用ExportResult。 - 移除已淘汰的
TransformationException類別。改用ExportException。 - 移除已淘汰的
Transformer.PROGRESS_STATE_NO_TRANSFORMATION。改用Transformer.PROGRESS_STATE_NOT_STARTED。 - 移除已淘汰的
Transformer.setListener()。請改用Transformer.addListener()、Transformer.removeListener()或Transformer.removeAllListeners()。 - 移除已淘汰的
Transformer.startTransformation()。改用Transformer.start(MediaItem, String)。 - 移除已淘汰的
SingleFrameGlShaderProgram。改用BaseGlShaderProgram。 - 移除
Transformer.flattenForSlowMotion。改用EditedMediaItem.flattenForSlowMotion。 - 已移除
ExoPlayer.VideoComponent、ExoPlayer.AudioComponent、ExoPlayer.TextComponent和ExoPlayer.DeviceComponent。 - 已移除
androidx.media3.exoplayer.audio.SonicAudioProcessor。 - 移除了下列已淘汰的
DownloadHelper方法:- 建構函式
DownloadHelper(MediaItem, @Nullable MediaSource, TrackSelectionParameters, RendererCapabilities[]),請改用DownloadHelper(MediaItem, @Nullable MediaSource, TrackSelectionParameters, RendererCapabilitiesList)。 - 不過,您可以建立含有
RenderersFactory的DefaultRendererCapabilitiesList,並呼叫DefaultRendererCapabilitiesList.getRendererCapabilities(),達到相同的功能。getRendererCapabilities(RenderersFactory)
- 建構函式
- 已移除
PlayerNotificationManager.setMediaSessionToken(MediaSessionCompat)方法。請改用PlayerNotificationManager.setMediaSessionToken(MediaSession.Token)並傳遞(MediaSession.Token) compatToken.getToken()。
- 移除已淘汰的
1.6.0-rc02
2025 年 3 月 19 日
使用 1.6.0 穩定版。
1.6.0-rc01
2025 年 3 月 12 日
使用 1.6.0 穩定版。
1.6.0-beta01
2025 年 2 月 26 日
使用 1.6.0 穩定版。
1.6.0-alpha03 版本
2025 年 2 月 6 日
使用 1.6.0 穩定版。
1.6.0-alpha02 版本
2025 年 1 月 30 日
使用 1.6.0 穩定版。
1.6.0-alpha01 版本
2024 年 12 月 20 日
使用 1.6.0 穩定版。
1.5 版本
1.5.1 版本
2024 年 12 月 19 日
發布了 androidx.media3:media3-*:1.5.1。1.5.1 版包含這些修訂項目。
- ExoPlayer:
- 停用 MediaCodec 中的非同步解密功能,避免發生這項平台 API 回報的轉碼器逾時問題 (#1641)。
- 擷取工具:
- MP3:如果
VBRI影格的目錄未涵蓋檔案中的所有 MP3 資料,請勿提早停止播放 (#1904)。
- MP3:如果
- 影片:
- 回溯使用
MediaCodecAdapter提供的像素顯示比例值,在處理onOutputFormatChanged時提供 (#1371)。
- 回溯使用
- 文字:
- 修正
ReplacingCuesResolver.discardCuesBeforeTimeUs中的錯誤,該錯誤會導致系統錯誤捨棄在timeUs處啟動的提示 (開始時間早於timeUs,但尚未結束) (#1939)。
- 修正
- 中繼資料:
- 從 Vorbis 註解將光碟/曲目編號和類型擷取至
MediaMetadata(#1958)。
- 從 Vorbis 註解將光碟/曲目編號和類型擷取至
1.5.0 版本
2024 年 11 月 27 日
發布了 androidx.media3:media3-*:1.5.0。1.5.0 版包含這些修訂項目。
- 通用程式庫:
- 新增
ForwardingSimpleBasePlayer,允許轉送至其他播放器,同時確保完整一致性及監聽器處理作業 (#1183)。 - 將
SimpleBasePlayer.State.playlist替換為getPlaylist()方法。 - 為
SimpleBasePlayer.State.Builder.setPlaylist()新增覆寫,直接指定Timeline和目前的Tracks和Metadata,而非建構播放清單結構。 - 將
minSdk提高至 21 (Android Lollipop)。這與所有其他 AndroidX 程式庫一致。 - 新增
androidx.media3:media3-common-ktx構件,提供以 Common 程式庫為基礎建構的 Kotlin 專用功能 - 將
Player.listen暫停擴充功能函式新增至media3-common-ktx程式庫,以啟動協同程式來監聽Player.Events。 - 從手動內嵌的內部類別中移除
@DoNotInline註解,避免執行階段類別驗證失敗。現在,新版 R8 會自動將這類呼叫作業移出內嵌,避免執行階段失敗 (因此不再需要手動移出內嵌)。由於compileSdk = 35,程式庫的所有 Gradle 使用者都必須使用 Android Gradle 外掛程式版本,該版本會使用執行這項作業的 R8 版本。如果程式庫使用者採用非 Gradle 的建構系統,則必須確保 R8 等效的縮減/模糊化步驟會執行類似的自動內嵌程序,以免發生執行階段類別驗證失敗的情況。這項變更已在其他 AndroidX 程式庫中完成。
- 新增
- 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(),在個別算繪器允許播放時傳送信號。 - 修正
MediaCodec.CryptoException有時會在MediaCodec以非同步模式運作時 (API 31 以上的預設行為) 回報為「執行階段發生未預期的錯誤」的問題。 - 使用
PreloadMediaSource.PreloadControl.onContinueLoadingRequested()傳遞bufferedDurationUs,而非bufferedPositionUs。此外,應用程式也將DefaultPreloadManager.Status.STAGE_LOADED_TO_POSITION_MS變更為DefaultPreloadManager.Status.STAGE_LOADED_FOR_DURATION_MS,因此應用程式必須傳遞代表特定時間長度的值 (從預設開始位置起算),對應的媒體來源必須預先載入這個 IntDef,而非位置。 - 新增
ForwardingRenderer實作,將所有方法呼叫轉送至另一個算繪器 (1703)。 - 為播放清單中的下一個項目新增播放清單預先載入功能。應用程式可以呼叫
ExoPlayer.setPreloadConfiguration(PreloadConfiguration),據此啟用預先載入功能。預先載入功能預設為停用。啟用這項功能後,為避免干擾播放作業,DefaultLoadControl會限制預先載入作業,只在播放器未載入播放內容時啟動及繼續。應用程式可以實作適當的LoadControl.shouldContinuePreloading()(例如在DefaultLoadControl中覆寫這個方法時),變更這項行為。如果應用程式使用LoadControl的自訂實作方式,LoadControl的預設實作方式會停用預先載入功能。 - 新增方法
MediaSourceEventListener.EventDispatcher.dispatchEvent(),允許叫用子類別監聽器的事件 (1736)。 - 新增
DefaultPreloadManager.Builder,以建構DefaultPreloadManager和ExoPlayer執行個體,並保持共用設定一致。 - 從
LoadControl.onTracksSelected()移除Renderer[]參數,因為DefaultLoadControl實作可以從ExoTrackSelection[]擷取串流類型。 - 已淘汰
DefaultLoadControl.calculateTargetBufferBytes(Renderer[], ExoTrackSelection[]),並將方法標示為最終方法,避免遭到覆寫。請改用新的DefaultLoadControl.calculateTargetBufferBytes(ExoTrackSelection[])。 - 在
MergingMediaSource中回報次要來源的MediaSourceEventListener事件。這會導致系統回報側載字幕 (使用MediaItem.LocalConfiguration.subtitleConfigurations新增的字幕) 的載入開始/錯誤/取消/完成事件,這些事件可能會顯示為AnalyticsListener發出的重複載入事件。 - 避免字幕和中繼資料錯誤完全停止播放。
系統會改為停用有問題的音軌,並繼續播放其餘音軌 (#1722)。
- 在新的字幕處理程序 (擷取期間),相關聯的剖析 (例如無效的字幕資料) 和載入錯誤 (例如 HTTP 404) 會透過
onLoadError回呼發出。 - 在舊版字幕處理作業 (轉譯期間),只有相關聯的載入錯誤會透過
onLoadError回呼發出,而剖析錯誤則會遭到忽略 (這是先前就有的行為)。
- 在新的字幕處理程序 (擷取期間),相關聯的剖析 (例如無效的字幕資料) 和載入錯誤 (例如 HTTP 404) 會透過
- 修正錯誤:如果多週期 DASH 串流中的播放清單項目或週期長度與實際內容不符,可能會導致項目結尾的影格凍結 (#1698)。
- 在
SntpClient中新增設定器,設定自上次更新後經過的最長時間,超過這個時間後,用戶端會重新初始化 (#1794)。
- 現在可以為每個媒體項目呼叫
- 轉換程式:
- 新增
SurfaceAssetLoader,支援透過Surface將影片資料排入 Transformer 的佇列。 ImageAssetLoader會透過AssetLoader.onError回報不支援的輸入內容,而不是擲回IllegalStateException。- 強制規定匯出圖片時必須使用
MediaItem.Builder.setImageDurationMs設定圖片顯示時間。 - 新增對音訊 EditedMediaItem 序列中間隔的匯出支援。
- 新增
- 音軌選取:
DefaultTrackSelector:在其他因素相同的情況下,請優先使用物件式音訊,而非聲道式音訊。
- 擷取工具:
- 允許
Mp4Extractor和FragmentedMp4Extractor識別後續樣本未做為參照的 H264 樣本。 - 在
AmrExtractor中新增選項,啟用以索引為準的搜尋功能。 - 將有效影格之間超過 128 KB 的 MP3 檔案視為截斷 (而非無效)。也就是說,如果檔案結尾有非 MP3 資料,且沒有其他中繼資料指出 MP3 位元組的長度,現在系統會在 MP3 資料結尾停止播放,而不是因
ParserException: Searched too many bytes.{contentIsMalformed=true, dataType=1}(#1563) 而失敗。 - 修正處理 MP4 檔案中的編輯清單時,非關鍵影格媒體開始位置的預先捲動範例處理方式 (#1659)。
- 使用
Mp4Extractor和FragmentedMp4Extractor中的mdhd方塊媒體時間長度,改善影格速率計算 (#1531)。 - 修正 MP4 編輯清單中
media_time的縮放比例有誤問題。雖然segment_duration已使用影片時間碼正確縮放,但現在media_time會使用軌道時間碼正確縮放,如 MP4 格式標準所指定 (#1792)。 - 在 MP4 編輯清單的
endIndices計算中處理順序錯誤的影格 (#1797)。 - 修正 MP4 檔案
mdhd方塊中的媒體時間長度剖析作業,以處理-1值 (#1819)。 - 新增支援功能,可識別 MP4 檔案中的
h263方塊,以用於 H.263 影片 (#1821)。 - 新增 AC-4 Level-4 ISO 基礎媒體檔案格式支援 (#1265)。
- 允許
- DataSource:
- 更新
HttpEngineDataSource,允許從 S 擴充功能 7 版開始使用,而非 API 級別 34 (#1262)。 DataSourceContractTest:確認DataSource.getUri()會傳回已解析的 URI (如文件所述)。如果這與要求的 URI 不同,測試可以使用新的DataSourceContractTest.TestResource.Builder.setResolvedUri()方法指出這一點。DataSourceContractTest:在對open()的呼叫失敗 (因資源「找不到」) 後,以及後續的close()呼叫之前,判斷DataSource.getUri()和getResponseHeaders()是否會傳回「開啟」值。- 覆寫
DataSourceContractTest.getNotFoundResources()可讓測試子類別提供多個「找不到」資源,並提供任何預期標頭。這樣就能區分 HTTP 404 (含標頭) 和「找不到伺服器」(不含標頭)。
- 覆寫
- 更新
- 音訊:
- 如果媒體中含有 CTA-2075 音量中繼資料,系統會自動在轉碼器上設定這項資料。
- 確保搜尋時音量能平順降低。
- 修正搜尋時可能發生的爆音。
- 修正 Sonic 時間延展/音高轉移演算法的截斷錯誤累積問題。
- 修正
SpeedChangingAudioProcessor中的錯誤,避免輸出畫面格數減少。
- 影片:
MediaCodecVideoRenderer避免解碼既未算繪,也未做為其他樣本參考的樣本。- 在 API 35 以上版本中,
MediaCodecAdapter現在可能會在configure中收到nullSurface,並呼叫新方法detachOutputSurface,移除先前設定的Surface(如果轉碼器支援此功能 (MediaCodecInfo.detachedSurfaceSupported))。 - 如果處理
onOutputFormatChanged時提供像素顯示比例值,請使用MediaCodecAdapter(#1371)。 - 針對 Galaxy Tab S7 FE 裝置問題新增權變措施,該問題會導致 60 fps 安全 H264 串流標示為不支援 (#1619)。
- 針對在最後一個樣本後停滯,但未傳回串流結尾信號的轉碼器,新增解決方法。
- 文字:
- 新增自訂
VoiceSpan,並填入 WebVTT 語音跨度 (#1632)。 - 確保 HLS 中的 WebVTT 顯示字幕時間戳記過大的情況 (以微秒表示並乘以
90,000MPEG 時基時,會溢位 64 位元long) (#1763)。 - 支援 Dolby Vision 內容中的 CEA-608 字幕 (#1820)。
- 修正啟用 CEA-608 字幕時,DASH 多週期串流播放會停止的問題 (#1863)。
- 新增自訂
- 中繼資料:
- 將
C.TRACK_TYPE_METADATA類型指派給含有 icy 或 vnd.dvb.ait 內容的曲目。
- 將
- 圖片:
- 加入
ExternallyLoadedImageDecoder,簡化與 Glide 或 Coil 等外部圖片載入程式庫的整合。
- 加入
- DataSource:
- 新增
FileDescriptorDataSource,這個新DataSource可用於從FileDescriptor讀取資料 (#3757)。
- 新增
- 效果:
- 新增
DefaultVideoFrameProcessor解決方法,以解決SurfaceTexture縮放比例略有差異的問題。SurfaceTexture可能會包含小幅縮放,以剪除裁剪緩衝區邊緣周圍的 1 紋素邊框。現在已處理完畢,輸出內容更接近預期結果。 - 加快
DefaultVideoFrameProcessor.queueInputBitmap()。因此,使用Transformer將圖片匯出為影片的速度會更快。
- 新增
- IMA 擴充功能:
- 修正錯誤:清除播放清單可能會導致
ArrayIndexOutOfBoundsException發生ImaServerSideAdInsertionMediaSource。 - 修正錯誤:如果伺服器端插入的 DAI 串流沒有前置廣告,在播放最後一個片中廣告後,可能會導致
ArrayIndexOutOfBoundsException(#1741)。
- 修正錯誤:清除播放清單可能會導致
- 工作階段:
- 新增
MediaButtonReceiver.shouldStartForegroundService(Intent),允許應用程式覆寫這個方法,藉此禁止系統在恢復播放時發出播放指令。根據預設,服務一律會啟動,且系統會透過ForegroundServiceDidNotStartInTimeException導致服務當機 (#1528),因此無法抑制播放。 - 修正錯誤:連線至舊版服務時,從
MediaBrowser傳送的自訂指令會派送至MediaSessionCompat.Callback,而非方法的MediaBrowserServiceCompat變體。這會導致MediaBrowser無法接收舊版服務傳回的實際回傳值 (#1474)。 - 處理特定製造商的裝置在為媒體按鈕意圖設定廣播接收器時擲回的
IllegalArgumentException(#1730)。 - 為媒體項目新增指令按鈕。這會新增 Media3 API,適用於先前稱為
Custom browse actions的項目,以及具有MediaBrowserCompat的舊版程式庫。請注意,MediaBrowser和MediaController都可以使用媒體項目的 Media3 指令按鈕。請參閱「實作自訂瀏覽動作」。 - 修正錯誤:有時 Media3 控制器無法在要求
play()後,讓工作階段應用程式啟動前景服務。 - 限制
CommandButton.Builder.setIconUri只能接受內容 URI。 - 將 Media3 瀏覽器的連線提示傳遞至初始
MediaBrowserCompat,以便連線至舊版MediaBrowserCompat。服務可以接收在首次呼叫onGetRoot()時,以根提示形式傳入的連線提示。 - 修正錯誤:
MediaBrowser連線至舊版瀏覽器服務後,瀏覽器訂閱parentid時,MediaBrowser未收到服務傳送的錯誤。 - 改善互通性行為,讓連線至舊版
MediaBrowserService的 Media3 瀏覽器在訂閱父項時,不會要求parentId的子項兩次。
- 新增
- UI:
- 由於 XML 型共用轉場效果有問題,請選擇在
PlayerView-in-Compose-AndroidView中使用延展/裁剪影片的解決方法。在AndroidView內使用PlayerView的應用程式需要呼叫PlayerView.setEnableComposeSurfaceSyncWorkaround才能選擇加入 (#1237、#1594)。 - 將
setFullscreenButtonState新增至PlayerView,允許視需要更新全螢幕按鈕的圖示,也就是頻外更新,而非對點擊互動做出反應 (#1590、#184)。 - 修正錯誤:如有應用程式定義的文字音軌選取偏好設定,文字選取畫面中的「無」選項就無法運作。
- 由於 XML 型共用轉場效果有問題,請選擇在
- DASH 擴充功能:
- 支援從區隔中間開始的週期 (#1440)。
- 流暢串流擴充功能:
- 修正播放含有文字軌的 SmoothStreaming 串流時發生的
Bad magic number for Bundle錯誤 (#1779)。
- 修正播放含有文字軌的 SmoothStreaming 串流時發生的
- RTSP 擴充功能:
- 解碼器擴充功能 (FFmpeg、VP9、AV1 等):
- 新增 IAMF 解碼器模組,支援使用 libiamf 原生程式庫合成音訊,播放含有 IAMF 音軌的 MP4 檔案。
- 啟用立體聲配置和 5.1 聲道空間化功能,並視需要啟用頭部追蹤功能,即可播放內容。不過,目前不支援雙耳播放。
- 在 Android 15 上為解碼器擴充功能新增 16 KB 頁面支援 (#1685)。
- 新增 IAMF 解碼器模組,支援使用 libiamf 原生程式庫合成音訊,播放含有 IAMF 音軌的 MP4 檔案。
- Cast 擴充功能:
- 在 CastSession 中斷連線後停止清除時間軸,讓傳送端應用程式在連線中斷後繼續在本機播放。
- 提供
Context時,填入 CastPlayer 的DeviceInfo。這樣就能將MediaSession連結至RoutingSession,這是整合輸出切換器時的必要步驟 (#1056)。
- 測試公用程式:
DataSourceContractTest現在包含驗證下列項目的測試:- 輸入串流
read position已更新。 - 輸出緩衝區
offset已正確套用。
- 輸入串流
- 試用版應用程式
- 解決試用版短片應用程式中的記憶體流失問題 (#1839)。
- 移除已淘汰的符號:
- 移除已淘汰的
Player.hasPrevious、Player.hasPreviousWindow()。 請改用Player.hasPreviousMediaItem()。 - 移除已淘汰的
Player.previous()方法。改用Player.seekToPreviousMediaItem()。 - 移除已淘汰的
DrmSessionEventListener.onDrmSessionAcquired方法。 - 移除已淘汰的
DefaultEncoderFactory建構函式。改用DefaultEncoderFactory.Builder。
- 移除已淘汰的
1.5.0-rc02 版
2024 年 11 月 19 日
使用 1.5.0 穩定版。
1.5.0-rc01 版
2024 年 11 月 13 日
使用 1.5.0 穩定版。
1.5.0-beta01 版
2024 年 10 月 30 日
使用 1.5.0 穩定版。
1.5.0-alpha01 版本
2024 年 9 月 10 日
使用 1.5.0 穩定版。
1.4.0 版本
1.4.1 版本
2024 年 8 月 27 日
發布了 androidx.media3:media3-*:1.4.1。1.4.1 版包含這些修訂項目。
- ExoPlayer:
- 擷取工具:
- MP3:根據
Info影格中的長度欄位,正確忽略尾端非 MP3 資料,修正Searched too many bytes錯誤 (#1480)。
- MP3:根據
- 文字:
- TTML:修正百分比
tts:fontSize值的處理方式,確保系統能從含有百分比tts:fontSize值的父項節點正確沿用這些值。 - 修正
Subtitle中因錯誤處理要求輸出開始時間大於或等於最終事件時間的情況,而導致IndexOutOfBoundsException發生LegacySubtitleUtil的問題 (#1516)。
- TTML:修正百分比
- DRM:
- 修正 API 31 以上版本裝置播放 L1 Widevine 內容時發生的
android.media.MediaCodec$CryptoException: Operation not supported in this configuration: ERROR_DRM_CANNOT_HANDLE錯誤。這個錯誤是因為架構方法 (#1603) 的實作不完整所致。MediaDrm.requiresSecureDecoder
- 修正 API 31 以上版本裝置播放 L1 Widevine 內容時發生的
- 效果:
- 將
release()方法新增至GlObjectsProvider。
- 將
- 工作階段:
- RTSP 擴充功能:
- 在 SDP 剖析中略過無效的媒體說明 (#1087)。
1.4.0 版本
2024 年 7 月 25 日
發布了 androidx.media3:media3-*:1.4.0。1.4.0 版包含這些修訂項目。
- 通用程式庫:
- 將預設為無運算的搜尋呼叫轉送至受保護的
BasePlayer.seekTo()和SimpleBasePlayer.handleSeek()方法,而非忽略這些呼叫。如果您在自訂播放器中實作這些方法,可能需要使用mediaItemIndex == C.INDEX_UNSET處理這些額外的呼叫。 - 移除 Java 8 強化版 desugaring 的編譯依附元件 (#1312)。
- 請確認系統會忽略傳遞至非圖片
MediaItem的MediaItem.Builder.setImageDurationMs()持續時間 (如文件所述)。 - 新增
Format.customData,儲存應用程式提供的Format執行個體自訂資訊。
- 將預設為無運算的搜尋呼叫轉送至受保護的
- ExoPlayer:
- 新增
BasePreloadManager,根據多個來源的rankingData所定義的優先順序,協調這些來源的預先載入作業。您可以擴充這個類別,進行自訂。新增DefaultPreloadManager,使用PreloadMediaSource將來源的媒體樣本預先載入記憶體,並使用整數rankingData指出 UI 上項目的索引。 - 在大多數
LoadControl方法中新增PlayerId,即可讓LoadControl實作項目支援多位玩家。 - 移除
Buffer.isDecodeOnly()和C.BUFFER_FLAG_DECODE_ONLY。不需要設定這個標記,因為轉譯器和解碼器會根據時間戳記決定是否要略過緩衝區。自訂Renderer實作項目應檢查緩衝時間是否至少為BaseRenderer.getLastResetPositionUs(),以決定是否應顯示樣本。自訂SimpleDecoder實作可視需要檢查isAtLeastOutputStartTimeUs(),或使用DecoderOutputBuffer.shouldBeSkipped標記其他緩衝區以略過這些緩衝區。 - 允許
TargetPreloadStatusControl.getTargetPreloadStatus(T)傳回空值,表示不要使用指定rankingData預先載入MediaSource。 - 將
remove(MediaSource)新增至BasePreloadManager。 - 在
BasePreloadManager中新增reset(),即可釋放所有保留來源,同時保留預先載入管理工具執行個體。 - 新增
ExoPlayer.setPriority()(和Builder.setPriority()) 來定義PriorityTaskManager中使用的優先順序值,以及 API 35 以上版本的 MediaCodec 重要性。 - 修正更新上次重新緩衝時間的問題,這會導致 CMCD 中出現不正確的
bs(緩衝區資源不足) 鍵 (#1124)。 - 新增
PreloadMediaSource.PreloadControl.onLoadedToTheEndOfSource(PreloadMediaSource),表示來源已載入至結尾。這樣一來,DefaultPreloadManager和自訂PreloadMediaSource.PreloadControl實作項目就能預先載入下一個來源或採取其他動作。 - 修正在項目結尾略過無聲片段時,可能會觸發播放例外狀況的錯誤。
- 在
PreloadMediaSource中加入clear,即可捨棄預先載入期。 - 新增錯誤碼
PlaybackException.ERROR_CODE_DECODING_RESOURCES_RECLAIMED,用於為優先順序較高的工作回收轉碼器資源時。 - 讓
AdsMediaSource在初始內容媒體準備完成前載入片頭前廣告 (#1358)。 - 修正錯誤:從資訊清單中移除原始週期後,重新準備多週期 DASH 直播串流時,播放作業會移至
STATE_ENDED。 - 在
PreloadMediaSource.PreloadControl中,將onTimelineRefreshed()重新命名為onSourcePrepared(),並將onPrepared()重新命名為onTracksSelected()。並相應地重新命名DefaultPreloadManager.Stage中的 IntDef。 - 新增動態排程的實驗性支援功能,以便更妥善地配合 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)。- 修正處理播放器錯誤時可能發生的
IllegalArgumentException,該錯誤是在預先讀取其他播放清單項目時發生 (#1483)。
- 新增
- 轉換程式:
- 在
ExportResult中加入audioConversionProcess和videoConversionProcess,指出輸出檔案中各個音軌的製作方式。 - 放寬修剪最佳化 H.264 層級檢查。
- 新增支援功能,可在序列中切換 SDR 和 HDR 輸入媒體。
- 新增對合成層級音效的支援。
- 新增支援將 Ultra HDR 圖片轉碼為 HDR 影片。
- 修正問題:
DefaultAudioMixer在重設並重複使用後,不會輸出正確的位元組數量。 - 解決解碼器錯誤,處理 PCM 輸入時,音訊聲道數量上限為立體聲。
- 在
ExoPlayerAssetLoader中選取音軌時,請忽略音訊聲道數量的限制,因為這些限制只適用於播放。 - 將
androidx.media3.transformer.Muxer介面替換為androidx.media3.muxer.Muxer,並移除androidx.media3.transformer.Muxer。 - 修正從內容 URI 配置載入 HEIC 圖片的問題。 (#1373)。
- 在
AudioGraphInput中調整音軌長度,改善影音同步效果。 - 移除
ExportResult.processedInputs欄位。如果使用這個欄位提供轉碼器詳細資料,請改用DefaultDecoderFactory.listener。如果發生轉碼器例外狀況,轉碼器詳細資料會顯示在ExportException.codecInfo中。
- 在
- 擷取工具:
- MPEG-TS:向前推出變更,確保最後一個影格是透過將串流的最後存取單元傳遞至樣本佇列 (#7909) 算繪。修正僅 I 影格 HLS 串流(#1150) 和 H.262 HLS 串流 (#1126) 中出現的問題。
- MP3:優先採用
Info框架的資料大小,而非基礎串流回報的大小 (例如檔案大小或 HTTPContent-Length標頭)。這有助於從固定位元率搜尋計算中排除無法播放的預告片資料 (例如專輯封面),使搜尋更準確 (#1376)。 - MP3:使用
Info影格中的影格計數和其他資料 (如有),計算固定位元率搜尋的平均位元率,而不是從Info影格後的影格位元率外推,這可能會人為縮小,例如PCUT影格 (#1376)。 - 修正 AVI 容器中的 PCM 音訊格式擷取作業。
- 音訊:
- 修正直通播放的 DTS:X Profile 2 編碼屬性 (#1299)。
- 如要卸載播放作業,請在呼叫
AudioTrack.stop()前,先在DefaultAudioSink中重設串流完成的追蹤欄位,以便AudioTrack.StreamEventCallback#onPresentationEnded正確識別所有待處理資料的播放時間。 - 修正
SilenceSkippingAudioProcessor中的錯誤,不同音訊格式 (例如立體聲到單聲道) 間的轉場效果可能會導致處理器擲回例外狀況 (#1352)。 - 實作
MediaCodecAudioRenderer.getDurationToProgressUs(),讓 ExoPlayer 動態排定主要工作迴圈,以便 MediaCodecAudioRenderer 能夠繼續運作。
- 影片:
- 修正問題:在播放期間切換介面時,
Listener.onRenderedFirstFrame()會過早抵達。 - 修正 Dolby Vision 的解碼器備用邏輯,視需要使用相容的 AV1 解碼器 (#1389)。
- 修正啟用影片轉譯器時,可能在播放期間中途發生的轉碼器例外狀況。
- 修正問題:在播放期間切換介面時,
- 文字:
- 修正字幕在搜尋位置之前開始時會遭到略過的問題。 這個問題只出現在 Media3 1.4.0-alpha01 中。
- 變更預設的字幕剖析行為,改為在擷取期間而非算繪期間進行剖析 (如需擷取和算繪之間的差異,請參閱 ExoPlayer 的架構圖)。
- 如要覆寫這項變更,請同時呼叫
MediaSource.Factory.experimentalParseSubtitlesDuringExtraction(false)和TextRenderer.experimentalSetLegacyDecodingEnabled(true)。如要將這些元件導入ExoPlayer執行個體,請參閱自訂說明文件。這些方法 (以及所有舊版字幕解碼支援) 將在日後推出的版本中移除。 - 如果應用程式採用自訂
SubtitleDecoder實作方式,請更新為實作SubtitleParser(並使用SubtitleParser.Factory,而非SubtitleDecoderFactory)。
- 如要覆寫這項變更,請同時呼叫
- PGS:修正行程長度解碼,將
0解析為顏色索引,而非常值顏色值 (#1367)。 - CEA-708:忽略
rowLock值。CEA-708-E S-2023 規格指出,無論串流中出現的值為何,rowLock和columnLock都應假設為 true (系統未實作columnLock支援功能,因此實際上會一律假設為 false)。- 這項變更原本包含在
1.3.0-alpha01版本資訊中,但我們在1.3.0-rc01版本發布前不慎還原了這項變更。我們已修正這個問題,因此變更內容會再次顯示。
- 這項變更原本包含在
- CEA-708:避免 ExoPlayer 處理「設定筆尖位置」指令時,加入重複的換行符 (#1315)。
- 修正
IllegalArgumentException,當 WebVTT 字幕樣本不含任何提示時 (例如在 DASH 串流中),會從LegacySubtitleUtil傳回IllegalArgumentException的問題 (#1516)。
- 中繼資料:
- 圖片:
- 新增對非正方形 DASH 縮圖格線的支援 (#1300)。
- 針對 API 34 以上版本新增 AVIF 支援。
- 允許
null做為ExoPlayer.setImageOutput()的參數,以清除先前設定的ImageOutput。
- DataSource:
- 實作對
android.resource://package/id原始資源 URI 的支援,其中package與目前應用程式的套件不同。先前未記載此做法,但相較於依名稱存取其他套件中的資源,這種做法更有效率。 - 在
DataSpec建構函式中,急切檢查url是否為非空值。這個參數已註解為非空值。 - 允許
ByteArrayDataSource在open()期間將 URI 解析為位元組陣列,而不是在建構時進行硬式編碼 (#1405)。
- 實作對
- DRM:
- 允許在
DefaultDrmSessionManagerProvider上設定LoadErrorHandlingPolicy(#1271)。
- 允許在
- 效果:
- 支援在同一個
EditedMediaItem或Composition中進行多次速度變更SpeedChangeEffect。 - 支援從 Ultra HDR 點陣圖輸入 HLG 和 PQ 輸出。
- 新增 EGL_GL_COLORSPACE_BT2020_HLG_EXT 支援,可改善 ExoPlayer.setVideoEffect 和 Transformer 的 Debug SurfaceView 中的 HLG 表面輸出。
- 更新疊加矩陣實作,將
setOverlayFrameAnchor()中套用的 x 和 y 值對調,使其與文件一致。如果使用OverlaySettings.Builder.setOverlayFrameAnchor(),請將 x 和 y 值乘以-1,即可翻轉這些值。 - 修正搭配
ExoPlayer#setVideoEffects使用TimestampWrapper會當機的問題 (#821)。 - 將預設 SDR 顏色工作空間從線性顏色變更為電氣 BT 709 SDR 影片。此外,也提供第三個選項,可保留原始色彩空間。
- 允許定義 EditedMediaItemSequences 的不確定 z 順序 (#1055)。
- 在不同的 HDR 內容中維持一致的亮度範圍 (使用 HLG 範圍)。
- 新增在 HDR 內容上疊加 Ultra HDR (點陣圖) 的支援。
- 允許在 API 26 之前使用
SeparableConvolution效果。 - 移除未使用的
OverlaySettings.useHdr,因為疊加層和影格的動態範圍必須相符。 - 為
TextOverlay新增 HDR 支援。文字重疊的亮度可使用OverlaySettings.Builder.setHdrLuminanceMultiplier()調整。
- 支援在同一個
- IMA 擴充功能:
- 將應用程式播放 DAI 廣告串流所需的 Promote API 升級為穩定版。
- 在
ImaServerSideAdInsertionMediaSource.AdLoader中新增replaceAdTagParameters(Map <String, String>),以便在執行階段取代廣告代碼參數。 - 修正錯誤:廣告播放期間發生播放器錯誤時,系統不會呼叫
VideoAdPlayer.VideoAdPlayerCallback.onError()(#1334)。 - 將 IMA SDK 版本遞增升級至 3.33.0,修正使用
data://廣告代碼 URI 時發生的NullPointerException問題 (#700)。
- 工作階段:
- 將
CommandButton.enabled的預設值變更為true,並確保即使相關聯的指令可用,控制器的值仍可維持為 false。 - 新增
CommandButton的圖示常數,應使用這些常數,而非自訂圖示資源。 - 新增
MediaSessionService.isPlaybackOngoing(),讓應用程式查詢服務是否需要在onTaskRemoved()中停止 (#1219)。 - 新增
MediaSessionService.pauseAllPlayersAndStopSelf(),方便暫停所有工作階段的播放作業,並呼叫stopSelf()終止MediaSessionService的生命週期。 - 覆寫
MediaSessionService.onTaskRemoved(Intent),提供安全預設實作,在播放作業進行中時讓服務在前台執行,否則停止服務。 - 在平台工作階段中繼資料中不設定時間長度,即可隱藏直播媒體通知中的搜尋列 (#1256)。
- 將
MediaMetadata的轉換對齊MediaDescriptionCompat,以便在選取中繼資料屬性時,使用與 media1 相同的偏好順序和邏輯。 - 新增
MediaSession.sendError(),可將非致命錯誤傳送至 Media3 控制器。使用通知控制器 (請參閱MediaSession.getMediaNotificationControllerInfo()) 時,自訂錯誤會用於將平台工作階段的PlaybackState更新為錯誤狀態,並提供指定錯誤資訊 (#543)。 - 新增
MediaSession.Callback.onPlayerInteractionFinished(),在特定控制器的系列播放器互動完成時通知工作階段。 - 新增
SessionError,並在SessionResult和LibraryResult中使用,取代錯誤代碼,盡可能提供錯誤的詳細資訊和解決方法。 - 發布媒體遙控器測試應用程式的程式碼,可用於測試與發布媒體工作階段的應用程式互動。
- 將傳遞至 media3 的額外資料
MediaSession[Builder].setSessionExtras()傳播至 media1 控制器的PlaybackStateCompat.getExtras()。 - 將嚴重和一般錯誤對應至平台工作階段,以及從平台工作階段對應。
PlaybackException會對應至PlaybackStateCompat的嚴重錯誤狀態。傳送至媒體通知控制器的SessionError(附帶MediaSession.sendError(ControllerInfo, SessionError)) 會對應至PlaybackStateCompat中的非重大錯誤,也就是說,系統會設定錯誤代碼和訊息,但平台工作階段的狀態仍與STATE_ERROR不同。 - 允許為每個控制器設定工作階段活動,以覆寫全域工作階段活動。您可以在連線時為控制器定義工作階段活動,方法是使用
AcceptedResultBuilder.setSessionActivivty(PendingIntent)建立ConnectionResult。連線後,工作階段活動可透過MediaSession.setSessionActivity(ControllerInfo, PendingIntent)更新。 - 改善對
MediaLibrarySession.Callback的呼叫錯誤複製作業。 現在可以透過MediaLibrarySession.Builder.setLibraryErrorReplicationMode()選擇錯誤類型,或停用預設開啟的錯誤複製功能,設定錯誤複製作業。
- 將
- UI:
- 下載內容:
- 確認
DownloadHelper不會洩漏未發布的Renderer執行個體,否則最終可能導致應用程式當機並出現IllegalStateException: Too many receivers, total of 1000, registered for pid(#1224)。
- 確認
- Cronet 擴充功能:
- 修正
CronetDataSource中的SocketTimeoutException。在某些版本的 Cronet 中,回呼提供的要求不一定相同。這會導致回呼未完成,且要求逾時 (https://issuetracker.google.com/328442628)。
- 修正
- HLS 擴充功能:
- 修正錯誤:等待不連續性的待處理 EMSG 樣本在
HlsSampleStreamWrapper中委派時,偏移值不正確,導致IndexOutOfBoundsException或IllegalArgumentException(#1002)。 - 修正錯誤:非主要播放清單會持續重新載入 LL-HLS 串流 (#1240)。
- 修正啟用 HLS 的 CMCD 時,初始化區隔會導致
Source Error和IllegalArgumentException的錯誤。 - 修正錯誤:在直播期間,系統不會重新整理非主要播放的播放清單 (#1240)。
- 修正啟用 HTTP 即時串流直播的 CMCD 導致
ArrayIndexOutOfBoundsException的錯誤 (#1395)。
- 修正錯誤:等待不連續性的待處理 EMSG 樣本在
- DASH 擴充功能:
- Cast 擴充功能:
- 修正錯誤,該錯誤會將
MediaQueueItem的專輯名稱轉換為 Media3 媒體項目的藝人 (#1255)。
- 修正錯誤,該錯誤會將
- 測試公用程式:
- 在
FakeRenderer中實作onInit()和onRelease()。 - 將
TestPlayerRunHelper.runUntil()/playUntil()方法變更為在非致命錯誤 (例如回報給AnalyticsListener.onVideoCodecError()的錯誤) 時失敗。使用新的TestPlayerRunHelper.run(player).ignoringNonFatalErrors().untilXXX()方法鏈結停用這項行為。
- 在
- 試用版應用程式:
- 在簡短的示範應用程式中使用
DefaultPreloadManager。 - 允許透過指令列的
Intent引數設定重複模式 (#1266)。 - 如果裝置支援,請使用
HttpEngineDataSource做為HttpDataSource。
- 在簡短的示範應用程式中使用
- 移除已淘汰的符號:
- 移除
CronetDataSourceFactory。改用CronetDataSource.Factory。 - 移除部分
DataSpec建構函式。改用DataSpec.Builder。 - 從
DefaultHttpDataSource、OkHttpDataSource和CronetDataSource移除setContentTypePredicate(Predicate)方法。請改用每個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.FormatSupportIntDef 和FORMAT_HANDLED、FORMAT_EXCEEDS_CAPABILITIES、FORMAT_UNSUPPORTED_DRM、FORMAT_UNSUPPORTED_SUBTYPE、FORMAT_UNSUPPORTED_TYPE常數。請改用androidx.media3.common.C中的對等 IntDef 和常數 (例如C.FORMAT_HANDLED)。 - 移除
Bundleable介面。包括移除所有Bundleable.Creator<Foo> CREATOR常數欄位。呼叫端應改為對每個型別使用Bundle toBundle()和static Foo fromBundle(Bundle)方法。
- 移除
1.4.0-rc01 版本
2024 年 7 月 10 日
使用 1.4.0 穩定版。
1.4.0-beta01 版本
2024 年 6 月 26 日
使用 1.4.0 穩定版。
1.4.0-alpha02 版
2024 年 6 月 7 日
使用 1.4.0 穩定版。
1.4.0-alpha01 版
2024 年 4 月 17 日
使用 1.4.0 穩定版。
1.3.0 版本
1.3.1 版本
2024 年 4 月 11 日
發布了 androidx.media3:media3-*:1.3.1。1.3.1 版包含這些修訂項目。
- 通用程式庫:
- 新增
Format.labels,允許使用本地化或其他替代標籤。
- 新增
- ExoPlayer:
- 轉換程式:
- 新增解決方法,避免因
MediaMuxer不支援 API 30 之前的負數呈現時間戳記而擲回例外狀況。
- 新增解決方法,避免因
- 音軌選取:
DefaultTrackSelector:優先選擇畫面更新率「合理」(>=10fps) 的視訊軌,而非畫面更新率較低或未設定的視訊軌。這樣一來,播放器就能在從動態相片擷取的 MP4 中選取「實際」影片軌,這類 MP4 可能包含兩個 HEVC 軌,其中一個的解析度較高,但影格數量非常少 (#1051)。
- 擷取工具:
- 音訊:
- 如果音軌無法在卸載模式中初始化,請停用卸載功能,允許轉譯器復原。
- 影片:
- 文字:
- WebVTT:避免直接連續的提示從
WebvttParser.parse建立額外的CuesWithTiming執行個體 (#1177)。
- WebVTT:避免直接連續的提示從
- DRM:
- 解決
NoSuchMethodError問題,在某些 Android 14 裝置上,MediaDrm架構可能會擲回這個問題,而不是ResourceBusyException或NotProvisionedException(#1145)。
- 解決
- 效果:
- 透過轉換色域,改善 PQ 至 SDR 的色調對應。
- 工作階段:
- UI:
- 如果
Locale無法識別顯示名稱,則改為加入音軌語言名稱 (#988)。
- 如果
- DASH 擴充功能:
- 將資訊清單中的所有
Label元素填入Format.labels(#1054)。
- 將資訊清單中的所有
- RTSP 擴充功能:
- 在 SDP 剖析中略過空白的工作階段資訊值 (i-tag) (#1087)。
- 解碼器擴充功能 (FFmpeg、VP9、AV1、MIDI 等):
- 預設會停用 MIDI 擴充功能做為本機依附元件,因為這需要設定額外的 Maven 存放區。如果使用者需要這個模組的本機依附元件,可以重新啟用。
1.3.0 版本
2024 年 3 月 6 日
發布了 androidx.media3:media3-*:1.3.0。1.3.0 版包含這些修訂項目。
- 通用程式庫:
- 實作對
android.resource://package/[type/]name原始資源 URI 的支援,其中package與目前應用程式的套件不同。這項功能一直以來都記載為可運作,但直到現在才正確實作。 - 將應用程式程式碼設定或從媒體讀取的 MIME 類型正規化為全小寫。
- 在
AdPlaybackState中定義廣告時,請使用完整的MediaItem,而非單一Uri。 - 將
minSdk提高至 19 (Android KitKat)。這項做法與所有其他 AndroidX 程式庫一致,且是升級至最新版 AndroidX 依附元件的必要條件。 - 當
artworkUri和artworkData至少有一個為非空值時,在MediaMetadata.Builder.populate(MediaMetadata)中填入這兩個值 (#964)。
- 實作對
- ExoPlayer:
- 新增
PreloadMediaSource和PreloadMediaPeriod,讓應用程式能在播放前,預先載入特定開始位置的內容媒體來源。PreloadMediaSource會負責準備內容媒體來源以接收Timeline、準備及快取指定開始位置的期間、選取軌道,以及載入該期間的媒體資料。應用程式會實作PreloadMediaSource.PreloadControl來控制預先載入進度,並將預先載入的來源設為播放器的來源,以供播放。 - 新增
ExoPlayer.setImageOutput,允許應用程式設定ImageRenderer.ImageOutput。 DefaultRenderersFactory現在會預設為播放器提供ImageRenderer,並將ImageOutput和ImageDecoder.Factory.DEFAULT設為空值。- 略過無聲片段時發出
Player.Listener.onPositionDiscontinuity事件 (#765)。 - 新增實驗性支援,可在擷取期間剖析字幕。您可以使用
MediaSource.Factory.experimentalParseSubtitlesDuringExtraction()啟用這項功能。 - 使用
PreloadMediaSource支援自適應媒體來源。 - 使用 HttpEngine API 實作
HttpEngineDataSource,即HttpDataSource。 - 防止子類別化
CompositeSequenceableLoader。這個元件先前可擴充,但從未在程式庫中建立子類別。如要進行自訂,請使用裝飾器模式包裝執行個體,並實作自訂CompositeSequenceableLoaderFactory。 - 修正重複相同時間會導致清除這個項目中繼資料的問題 (#1007)。
- 將
BundledChunkExtractor.Factory和DefaultHlsExtractorFactory中的experimentalSetSubtitleParserFactory方法重新命名為setSubtitleParserFactory,並禁止傳遞null。使用新的experimentalParseSubtitlesDuringExtraction(boolean)方法控制剖析行為。 - 新增支援在擷取期間自訂使用的
SubtitleParser.Factory。這時就會用到MediaSource.Factory.setSubtitleParserFactory()。 - 為從
MergingMediaSource產生的所有Format.id欄位新增來源前置字元。這有助於找出產生Format(#883) 的來源。 - 修正用於驗證自訂通用媒體用戶端資料 (CMCD) 金鑰名稱的 regex,將其修改為僅檢查連字號 (#1028)。
- 停止對 CMCD 查詢參數進行雙重編碼 (#1075)。
- 新增
- 轉換程式:
- 音軌選取:
- 新增
DefaultTrackSelector.selectImageTrack,啟用圖片軌選取功能。 - 新增
TrackSelectionParameters.isPrioritizeImageOverVideoEnabled,判斷是否要選取圖片軌 (如果圖片軌和影片軌都可用)。預設值為false,表示系統會優先選取視訊軌。
- 新增
- 擷取工具:
- 在 MP4 擷取器中新增 AV1C 剖析功能,以擷取
ColorInfo.colorSpace、ColorInfo.colorTransfer和ColorInfo.colorRange值 (#692)。 - MP3:使用固定位元率 (CBR) 搜尋含有
Info標頭的檔案 (相當於Xing標頭的 CBR)。先前我們使用Info標頭中的搜尋表,但如果忽略該標頭並假設檔案為 CBR,搜尋結果會更精確。 - MPEG2-TS:新增 DTS、DTS-LBR 和 DTS:X Profile2 支援 (#275)。
- 從 TS 描述元擷取音訊類型,並對應至角色旗標,讓使用者做出更明智的音軌選擇 (#973)。
- 在 MP4 擷取器中新增 AV1C 剖析功能,以擷取
- 音訊:
- 影片:
- 變更採用
VideoFrameProcessor.Factory引數的MediaCodecVideoRenderer建構函式,並替換為採用VideoSinkProvider引數的建構函式。如要插入自訂VideoFrameProcessor.Factory,應用程式可以例項化使用自訂VideoFrameProcessor.Factory的CompositingVideoSinkProvider,並將影片接收器供應器傳遞至MediaCodecVideoRenderer。
- 變更採用
- 文字:
- 修正點陣圖提示的序列化,解決使用
DefaultExtractorsFactory.setTextTrackTranscodingEnabled時發生的Tried to marshall a Parcel that contained Binder objects錯誤 (#836)。 - CEA-708:忽略
rowLock值。CEA-708-E S-2023 規格指出,無論串流中出現的值為何,rowLock和columnLock都應視為 true (columnLock支援功能尚未實作,因此實際上會一律視為 false)。
- 修正點陣圖提示的序列化,解決使用
- 圖片:
- 新增 DASH 縮圖支援功能。系統會裁剪格狀圖片,並在圖片顯示時間附近提供個別縮圖。
ImageOutput
- 新增 DASH 縮圖支援功能。系統會裁剪格狀圖片,並在圖片顯示時間附近提供個別縮圖。
- DRM:
- 根據預設,即使後續加密樣本的金鑰尚未準備就緒,系統也會立即播放 DRM 內容中「清除前導」的未加密樣本。如果播放位置到達加密樣本時,金鑰仍未準備就緒,可能會導致播放中途停頓 (但先前播放作業不會在這個時間點開始)。您可以使用
MediaItem.DrmConfiguration.Builder.setPlayClearContentWithoutKey或DefaultDrmSessionManager.Builder.setPlayClearSamplesWithoutKeys停用這項行為。
- 根據預設,即使後續加密樣本的金鑰尚未準備就緒,系統也會立即播放 DRM 內容中「清除前導」的未加密樣本。如果播放位置到達加密樣本時,金鑰仍未準備就緒,可能會導致播放中途停頓 (但先前播放作業不會在這個時間點開始)。您可以使用
- IMA 擴充功能:
- 修正問題:如果 DASH 和 HLS 廣告沒有適當的副檔名,就無法播放。
- 工作階段:
- 為 TV 應用程式停用按兩下偵測功能 (#962)。
- 修正問題:只有非空值的額外資訊的
MediaItem.RequestMetadata不會在媒體控制器和工作階段之間傳輸。 - 在
MediaLibrarySession.Builder中新增建構函式,只接受Context,而非MediaLibraryService。
- HLS 擴充功能:
- 將
HlsMediaPeriod瀏覽權限降低為套件私有。不應從 HLS 套件外部直接依附這類項目。 - 更有效率地將搜尋作業解析為區隔開頭 (#1031)。
- 將
- 解碼器擴充功能 (FFmpeg、VP9、AV1、MIDI 等):
- MIDI 解碼器:忽略 SysEx 事件訊息 (#710)。
- 測試公用程式:
- 請勿暫停「
TestPlayerRunHelper.playUntilPosition」中的播放作業。測試會讓播放作業維持播放狀態,但會暫停進度,直到測試能夠新增斷言和後續動作為止。
- 請勿暫停「
- 試用版應用程式:
- 新增短片試用版模組,示範如何搭配短片內容使用
PreloadMediaSource。
- 新增短片試用版模組,示範如何搭配短片內容使用
1.3.0-rc01 版本
2024 年 2 月 22 日
使用 1.3.0 穩定版。
1.3.0-beta01 版本
2024 年 2 月 7 日
使用 1.3.0 穩定版。
1.3.0-alpha01 版本
2024 年 1 月 15 日
使用 1.3.0 穩定版。
1.2.0 版本
1.2.1 版本
2024 年 1 月 9 日
- ExoPlayer:
- 轉換程式:
- 解決因設定高運作速率,導致編碼器在設定時擲回的問題。
- 擷取工具:
- 音訊:
- 修正多次呼叫
SilenceSkippingAudioProcessor時的 EOS 處理方式 (#712)。
- 修正多次呼叫
- 影片:
- 針對 Galaxy Tab S7 FE、Chromecast (支援 Google TV) 和 Lenovo M10 FHD Plus 裝置的問題新增解決方法,這些裝置會將 60 fps 的 AVC 串流標示為不支援 (#693)。
- 中繼資料:
- 修正錯誤:
MediaMetadata僅從含有大寫鍵的 Vorbis 註解填入資料 (#876)。 - 在剖析非常大的 ID3 影格時,系統會擷取
OutOfMemoryError,也就是說,播放作業可以繼續進行,不必使用標記資訊,而不是完全無法播放。
- 修正錯誤:
- DRM:
- 將適用於偽造 ClearKey
https://default.url授權網址的解決方法擴展至 API 33 以上版本 (先前僅適用於 API 33) (#837)。 - 修正從加密內容切換至未加密內容時,
ERROR_DRM_SESSION_NOT_OPENED未附加至播放器的問題。錯誤原因是使用安全解碼器播放未加密內容時發生錯誤。
- 將適用於偽造 ClearKey
- 工作階段:
- 將自訂鍵和值放在
MediaMetadataCompat中,然後將MediaMetadataCompat放在MediaMetadata.extras中,並將MediaMetadata.extras放在MediaMetadataCompat中 (#756、#802)。 - 修正舊版控制器的
notifyChildrenChanged廣播問題 (#644)。 - 修正錯誤:在部分裝置上,為已停用的通知
setWhen計時器設定負時間,會導致裝置異常終止 (#903)。 - 修正媒體通知控制器尚未完成連線,但系統要求第一次更新通知時發生的
IllegalStateException(#917)。
- 將自訂鍵和值放在
- UI:
- DASH 擴充功能:
- 在 DASH 資訊清單中,將「f800」剖析為 Dolby 的 5 個聲道 (#688)。
- 解碼器擴充功能 (FFmpeg、VP9、AV1、MIDI 等):
- Cast 擴充功能:
- 對
Timeline的建立作業進行清理,避免在投放裝置上載入媒體失敗時,應用程式發生異常終止情形 (#708)。
- 對
1.2.0 版本
2023 年 11 月 15 日
- 通用程式庫:
- 在
Log.Logger介面的方法中新增@Nullable Throwable參數。這些方法的message參數不再包含傳遞至Log.{d,i,w,e}()方法的Throwable相關資訊,因此如要使用這項資訊,實作時必須手動附加 (可能使用Logger.appendThrowableString(String, Throwable))。 - 修正 Kotlin 相容性問題,避免系統未將可為空值的泛型型別參數和可為空值的陣列元素型別偵測為可為空值。例如
TrackSelectorResult和SimpleDecoder方法參數 (#6792)。 - 變更
Util.shouldShowPlayButton中的預設 UI 和通知行為,在播放暫時遭到抑制時 (例如因暫時失去音訊焦點),顯示「播放」按鈕。如要維持舊版行為,請使用PlayerView.setShowPlayButtonIfPlaybackIsSuppressed(false)或MediaSession.Builder.setShowPlayButtonIfPlaybackIsSuppressed(false)(#11213)。 - 將
androidx.annotation:annotation-experimental升級至1.3.1,修正 https://issuetracker.google.com/251172715。 - 將
ExoPlayer.setAudioAttributes移至Player介面。
- 在
- ExoPlayer:
- 修正 AC4 串流中的搜尋問題,原因是系統未正確識別僅供解碼的樣本 (#11000)。
- 透過
ExoPlayer.Builder.setSuppressPlaybackOnUnsuitableOutput啟用這項功能後,如果音訊輸出裝置不適合播放內容 (例如 Wear OS 裝置的內建喇叭),系統就會停止播放。如果嘗試播放時沒有合適的音訊輸出裝置,或播放期間所有合適的輸出裝置都已中斷連線,播放抑制原因就會更新為Player.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUT。連線適當的輸出裝置後,系統就會移除停用原因。 - 新增
MediaSource.canUpdateMediaItem和MediaSource.updateMediaItem,以便在透過Player.replaceMediaItem(s)建立後接受MediaItem更新。 - 允許透過
Player.replaceMediaItem(s)為程式庫提供的所有MediaSource類別更新MediaItem(#33、#9978)。 - 將
MimeTypes.TEXT_EXOPLAYER_CUES重新命名為MimeTypes.APPLICATION_MEDIA3_CUES。 - 新增
PngExtractor,將整個 PNG 檔案傳送及讀取至TrackOutput做為一個樣本。 - 在
SequenceableLoader介面中強化SequenceableLoader.continueLoading(long)方法,以支援SequenceableLoader.continueLoading(LoadingInfo loadingInfo)。LoadingInfo包含其他參數,包括playbackSpeed和lastRebufferRealtimeMs,以及現有的playbackPositionUs。 - 在
ChunkSource介面中,將ChunkSource.getNextChunk(long, long, List, ChunkHolder)方法強化為ChunkSource.getNextChunk(LoadingInfo, long, List, ChunkHolder)。 - 在通用媒體用戶端資料 (CMCD) 記錄中新增其他欄位:緩衝區資源不足 (
bs)、截止時間 (dl)、播放速率 (pr) 和啟動 (su) (#8699)。 - 在
ColorInfo中新增亮度和色度位元深度 (#491)。 - 在通用媒體用戶端資料 (CMCD) 記錄中新增其他欄位:下一個物件要求 (
nor) 和下一個範圍要求 (nrr) (#8699)。 - 新增功能,使用查詢參數 (#553) 傳輸通用媒體用戶端資料 (CMCD) 資料。
- 修正
ExperimentalBandwidthMeter中的ConcurrentModificationException(#612)。 - 在
CompositeMediaSource.getMediaTimeForChildMediaTime中新增MediaPeriodId參數。 - 支援
ClippingMediaSource(以及其他具有週期/視窗時間偏移的來源) 中的ConcatenatingMediaSource2(#11226)。 - 變更
BaseRenderer.onStreamChanged(),讓其也接收MediaPeriodId引數。
- 轉換程式:
- 剖析圖片輸入內容的 EXIF 旋轉資料。
- 移除
TransformationRequest.HdrMode註解類型及其相關常數。請改用Composition.HdrMode和相關常數。 - 簡化
OverlaySettings即可修正旋轉問題。 - 已將
SampleConsumer.queueInputBitmap的frameRate和durationUs參數變更為TimestampIterator。
- 音軌選取:
- 新增
DefaultTrackSelector.Parameters.allowAudioNonSeamlessAdaptiveness,明確允許或禁止非無縫式調整。預設值仍為目前的true行為。
- 新增
- 擷取工具:
- MPEG-TS:將串流的最後一個存取單元傳遞至樣本佇列,確保系統會算繪最後一個影格 (#7909)。
- 修正判斷
rotationDegrees時的錯字。已將projectionPosePitch變更為projectionPoseRoll(#461)。 - 移除
Extractor執行個體可直接透過instanceof檢查的假設。如要取得Extractor的實作詳細資料,請先呼叫Extractor.getUnderlyingInstance。 - 新增
BmpExtractor。 - 新增
WebpExtractor。 - 新增
HeifExtractor。 - 在
Mp4Extractor中新增對傳統版 QuickTime 的支援。
- 音訊:
- 在 MP4 和 Matroska 中新增對 24/32 位元大端 PCM 的支援,並剖析 MP4 中
lpcm的 PCM 編碼。 - 新增支援功能,可從 MP4 檔案中擷取 Vorbis 音訊。
- 新增
AudioSink.getFormatOffloadSupport(Format),透過DefaultAudioOffloadSupportProvider擷取接收器可為格式提供的卸載支援層級。傳回包含isFormatSupported、isGaplessSupported和isSpeedChangeSupported的新AudioOffloadSupport。 - 新增
AudioSink.setOffloadMode(),藉此設定音訊接收器上的卸載設定。預設值為AudioSink.OFFLOAD_MODE_DISABLED。 - 您可以在
TrackSelectionParameters中透過setAudioOffloadPreference啟用卸載功能。如果偏好設定為啟用,且裝置支援格式卸載,且選取的音軌為單一音軌,則會啟用音訊卸載。 - 如果
audioOffloadModePreference設為AUDIO_OFFLOAD_MODE_PREFERENCE_REQUIRED,則DefaultTrackSelector只會選取音軌,且僅限於卸載支援該音軌格式的情況。如果卸載作業不支援任何音軌,系統就不會選取任何音軌。 - 由於曲目轉換後會發生播放位置問題,因此在 API 級別 33 之前的版本中,停用卸載的無間隙支援。
- 從
DefaultRenderersFactory.buildAudioSink方法簽章中移除enableOffload參數。 - 移除方法
DefaultAudioSink.Builder.setOffloadMode。 - 移除 intdef 值
DefaultAudioSink.OffloadMode.OFFLOAD_MODE_ENABLED_GAPLESS_DISABLED。 - 在卸載播放期間新增對 Opus 無間隙中繼資料的支援。
- 如果首次寫入失敗,請停用卸載功能,允許轉譯器復原 (#627)。
- 預設為純音訊卸載播放啟用卸載排程。
- 刪除
ExoPlayer.experimentalSetOffloadSchedulingEnabled和AudioOffloadListener.onExperimentalOffloadSchedulingEnabledChanged。 - 已將
onExperimentalSleepingForOffloadChanged重新命名為onSleepingForOffloadChanged,並將onExperimentalOffloadedPlayback重新命名為onOffloadedPlayback。 - 將音訊卸載模式相關的
TrackSelectionParameters介面和定義移至內部AudioOffloadPreferences類別。 - 將
onAudioTrackInitialized和onAudioTrackReleased回呼新增至AnalyticsListener、AudioRendererEventListener和AudioSink.Listener。 - 修正 DTS Express 音訊緩衝區下溢問題 (#650)。
- 修正 E-AC3-JOC 的功能檢查會擲回
IllegalArgumentException的錯誤 (#677)。
- 在 MP4 和 Matroska 中新增對 24/32 位元大端 PCM 的支援,並剖析 MP4 中
- 影片:
- 允許
MediaCodecVideoRenderer使用自訂VideoFrameProcessor.Factory。 - 修正錯誤:如果音訊串流以負時間戳記開頭,則無法算繪第一個影格 (#291)。
- 允許
- 文字:
- 移除
ExoplayerCuesDecoder。現在TextRenderer可直接處理含有sampleMimeType = application/x-media3-cues的文字軌,不需要SubtitleDecoder執行個體。
- 移除
- 中繼資料:
- 對於「僅解碼」的樣本,系統不會再呼叫
MetadataDecoder.decode,因為實作必須傳回空值。
- 對於「僅解碼」的樣本,系統不會再呼叫
- 效果:
- 依時間戳記新增
VideoFrameProcessor.queueInputBitmap(Bitmap, Iterator<Long>)佇列點陣圖輸入。 - 將
VideoFrameProcessor.registerInputStream()變更為非封鎖。 應用程式必須實作VideoFrameProcessor.Listener#onInputStreamRegistered()。 - 已將
VideoFrameProcessor.queueInputBitmap的frameRate和durationUs參數變更為TimestampIterator。
- 依時間戳記新增
- IMA 擴充功能:
- 修正錯誤:如果播放清單中的第一個項目不是多週期 DASH 直播,可能會擲回例外狀況 (#571)。
- 請先釋放 StreamManager,再呼叫
AdsLoader.destroy() - 將 IMA SDK 版本遞增升級至 3.31.0。
- 工作階段:
- 將通知前景服務行為設為
DefaultMediaNotificationProvider中的FOREGROUND_SERVICE_IMMEDIATE(#167)。 - 請僅使用 API 31 以上版本,以免在 Samsung 裝置上發生已淘汰 API 的問題 (#167)。
android.media.session.MediaSession.setMediaButtonBroadcastReceiver() - 使用媒體通知控制器做為 Proxy,設定可用指令和自訂版面配置,用於填入通知和平台工作階段。
- 轉換 Media3
MediaSessionService.onStartCommand()收到的媒體按鈕事件,而不是將事件傳送至平台工作階段,再傳回 Media3。這樣一來,來電控制器一律會是媒體通知控制器,應用程式就能在所有支援的 API 級別中,以相同方式輕鬆辨識來自通知的來電。 - 修正與舊版
MediaSessionCompat連線時,MediaController.getCurrentPosition()不會前進的問題。 - 為方便起見,請新增
MediaLibrarySession.getSubscribedControllers(mediaId)。 - 覆寫
MediaLibrarySession.Callback.onSubscribe(),以判斷控制器訂閱的父項 ID 是否可用。如果成功,系統會接受訂閱,並立即呼叫notifyChildrenChanged(),通知瀏覽器 (#561)。 - 為 Automotive OS 新增工作階段示範模組,並為 Android Auto 啟用工作階段示範。
- 如果媒體通知控制器無法使用
COMMAND_GET_TIMELINE,請勿設定架構工作階段的佇列。由於 Android Auto 是從架構工作階段讀取資料的用戶端控制器,因此 Android Auto 的 UI 中不會顯示queue按鈕 (#339)。 - 預設使用
DataSourceBitmapLoader,而非SimpleBitmapLoader(#271、#327)。 - 新增
MediaSession.Callback.onMediaButtonEvent(Intent),允許應用程式覆寫預設的媒體按鈕事件處理作業。
- 將通知前景服務行為設為
- UI:
- 為 Wear OS 裝置新增
Player.Listener實作項目,處理因Player.PLAYBACK_SUPPRESSION_REASON_UNSUITABLE_AUDIO_OUTPUT導致的播放抑制問題,方法是啟動系統對話方塊,讓使用者連線至合適的音訊輸出裝置 (例如藍牙耳機)。如果在可設定的逾時時間內 (預設為 5 分鐘) 連接合適的裝置,系統會自動繼續播放。
- 為 Wear OS 裝置新增
- 下載內容:
- 為確保與 Android 14 相容,請為
DownloadService聲明「資料同步」前景服務類型。使用這項服務時,應用程式也需要在資訊清單中將dataSync新增為foregroundServiceType,並新增FOREGROUND_SERVICE_DATA_SYNC權限 (#11239)。
- 為確保與 Android 14 相容,請為
- HLS 擴充功能:
- 使用從上次載入開始時間計算出的間隔,而非上次載入完成時間,重新整理 HLS 直播播放清單 (#663)。
- DASH 擴充功能:
- 允許在區隔範本網址中出現多個相同的 DASH ID。
- 新增實驗性支援,可在擷取期間剖析字幕。這個版本可更妥善地合併重疊的字幕,包括解決字幕片段間轉換時的閃爍問題。您可以使用
DashMediaSource.Factory.experimentalParseSubtitlesDuringExtraction()啟用這項功能 (#288)。
- RTSP 擴充功能:
- 解碼器擴充功能 (FFmpeg、VP9、AV1、MIDI 等):
- 發布 MIDI 解碼器模組,支援使用 Jsyn 程式庫合成音訊,播放標準 MIDI 檔案。
- 新增
DecoderOutputBuffer.shouldBeSkipped,直接標記不需要呈現的輸出緩衝區。建議您使用這個方法,而不要使用即將淘汰的C.BUFFER_FLAG_DECODE_ONLY。 - 新增
Decoder.setOutputStartTimeUs和SimpleDecoder.isAtLeastOutputStartTimeUs,讓解碼器在開始時間前捨棄僅供解碼的樣本。建議您優先使用這個方法,而非即將淘汰的Buffer.isDecodeOnly。 - 修正將 MIDI 解碼器構件發布至 Maven 存放區的錯誤。構件已重新命名為
media3-exoplayer-midi(#734)。
- Leanback 擴充功能:
- 修正停用介面可能導致 Leanback 程式碼中出現
ArithmeticException的錯誤 (#617)。
- 修正停用介面可能導致 Leanback 程式碼中出現
- 測試公用程式:
- 讓
TestExoPlayerBuilder和FakeClock與 Espresso UI 測試和 Compose UI 測試相容。修正錯誤:在 Espresso 或 Compose 檢視區塊互動期間,播放進度會以非決定性方式前進。
- 讓
- 移除已淘汰的符號:
- 移除
TransformationRequest.Builder.setEnableRequestSdrToneMapping(boolean)和TransformationRequest.Builder.experimental_setEnableHdrEditing(boolean)。請改用Composition.Builder.setHdrMode(int),並將Composition傳遞至Transformer.start(Composition, String)。 - 移除已淘汰的
DownloadNotificationHelper.buildProgressNotification方法,改用採用notMetRequirements參數的非淘汰方法。
- 移除
1.2.0-rc01 版本
2023 年 11 月 1 日
使用 1.2.0 穩定版。
1.2.0-beta01 版本
2023 年 10 月 19 日
使用 1.2.0 穩定版。
1.2.0-alpha02 版本
2023 年 9 月 29 日
使用 1.2.0 穩定版。
1.2.0-alpha01 版本
2023 年 8 月 17 日
使用 1.2.0 穩定版。
1.1.0 版本
1.1.1 版
2023 年 8 月 16 日
- 通用程式庫:
- 從所有模組中移除意外新增的
multidex依附元件 (#499)。
- 從所有模組中移除意外新增的
- ExoPlayer:
- 修正
PlaybackStatsListener中的問題:播放清單清除後,會建立虛假的PlaybackStats。 - 在 Common Media Client Data (CMCD) 記錄中新增其他欄位:串流格式 (sf)、串流類型 (st)、版本 (v)、最高位元率 (tb)、物件時間長度 (d)、測得的輸送量 (mtp) 和物件類型 (ot) (#8699)。
- 修正
- 音訊:
- 修正播放極短檔案時,
Player.getState()從未轉換為STATE_ENDED的錯誤 (#538)。
- 修正播放極短檔案時,
- 音訊卸載:
- 根據 RFC 7845,將 Ogg ID 標頭和註解標頭頁面加到位元串流的前面,以便卸載 Opus 播放作業。
- 影片:
- H.265/HEVC:修正剖析 SPS 短期和長期參考圖片資訊的問題。
- 文字:
- CEA-608:變更提示截斷邏輯,只考量可見文字。先前將提示長度限制為 32 個字元時,會納入縮排和定位點偏移量 (這在技術上符合規格)(#11019)。
- IMA 擴充功能:
- 將 IMA SDK 版本遞增升級至 3.30.3。
- 工作階段:
- 在控制器的狀態中新增自訂版面配置,並提供存取該版面配置的 getter。自訂版面配置變更時,系統會呼叫
MediaController.Listener.onCustomLayoutChanged。應用程式如要將不同的自訂版面配置傳送至不同的 Media3 控制器,可以在MediaSession.Callback.onConnect中使用AcceptedResultBuilder,確保連線完成時,控制器可以使用自訂版面配置。 - 修正
MediaLibraryServiceLegacyStub將錯誤傳送至不支援此錯誤的Result,導致產生UnsupportedOperationException的情況 (#78)。 - 修正
PlayerWrapper建立VolumeProviderCompat的方式,透過舊版指令 (COMMAND_ADJUST_DEVICE_VOLUME和COMMAND_SET_DEVICE_VOLUME) 和新指令 (COMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS和COMMAND_SET_DEVICE_VOLUME_WITH_FLAGS) 判斷volumeControlType(#554)。
- 在控制器的狀態中新增自訂版面配置,並提供存取該版面配置的 getter。自訂版面配置變更時,系統會呼叫
1.1.0 版本
2023 年 7 月 5 日
- 通用程式庫:
- Add suppression reason for unsuitable audio route and play when ready change reason for suppressed too long. (#15)。
- 在 Player 中新增指令:
COMMAND_GET_METADATACOMMAND_SET_PLAYLIST_METADATACOMMAND_SET_DEVICE_VOLUME_WITH_FLAGSCOMMAND_ADJUST_DEVICE_VOLUME_WITH_FLAGS
- 在 Player 中新增過載方法,讓使用者指定音量標記:
void setDeviceVolume(int, int)void increaseDeviceVolume(int)void decreaseDeviceVolume(int)void setDeviceMuted(boolean, int)
- 新增
Builder的DeviceInfo,並淘汰現有建構函式。 - 新增
DeviceInfo.routingControllerId,指定遠端播放的路由控制器 ID。 - 新增
Player.replaceMediaItem(s)做為捷徑,可新增及移除相同位置的項目 (#8046)。
- ExoPlayer:
- 只有在明確選擇加入時,才允許 ExoPlayer 控制裝置音量方法。使用
ExoPlayer.Builder.setDeviceVolumeControlEnabled可存取:getDeviceVolume()isDeviceMuted()setDeviceVolume(int)和setDeviceVolume(int, int)increaseDeviceVolume(int)和increaseDeviceVolume(int, int)decreaseDeviceVolume(int)和decreaseDeviceVolume(int, int)
- 新增
FilteringMediaSource,可從MediaSource篩選可用的音軌類型。 - 新增支援功能,可在自動調整串流格式 (DASH、HLS 和 SmoothStreaming) 的外送要求中加入通用媒體用戶端資料 (CMCD)。以下欄位已納入:
br、bl、cid、rtp和sid(#8699)。API 結構和 API 方法:- CMCD 記錄功能預設為停用,請使用
MediaSource.Factory.setCmcdConfigurationFactory(CmcdConfiguration.Factory cmcdConfigurationFactory)啟用。 - 所有鍵預設都會啟用,請覆寫
CmcdConfiguration.RequestConfig.isKeyAllowed(String key)來篩除要記錄的鍵。 - 覆寫
CmcdConfiguration.RequestConfig.getCustomData()即可啟用自訂鍵記錄功能。
- CMCD 記錄功能預設為停用,請使用
- 在主要試用版的資訊清單中新增其他動作,方便使用自訂
*.exolist.json檔案啟動試用版應用程式 (#439)。 - 新增
ExoPlayer.setVideoEffects(),以便在播放影片時使用Effect。 - 更新
SampleQueue,將sourceId儲存為long,而非int。這會變更公用方法SampleQueue.sourceId和SampleQueue.peekSourceId的簽章。 - 在
LoadControl方法shouldStartPlayback和onTracksSelected中新增參數,以便將這些方法與相關的MediaPeriod建立關聯。 - 變更
ServerSideAdInsertionMediaSource.setAdPlaybackStates(Map<Object, AdPlaybackState>)的簽章,方法是加入時間軸參數,其中包含以 UID 做為對應鍵的週期。這是為了避免多週期直播發生並行問題。 - 淘汰
EventDispatcher.withParameters(int windowIndex, @Nullable MediaPeriodId mediaPeriodId, long mediaTimeOffsetMs)和BaseMediaSource.createEventDispatcher(..., long mediaTimeOffsetMs)。您可以改為呼叫不含mediaTimeOffsetUs的方法變體。請注意,即使是已淘汰的變體,系統也不會再將偏移量新增至分派器分派的MediaLoadData物件的startTimeUs和endTimeUs。 - 將
ExoTrackSelection.blacklist重新命名為excludeTrack,並將isBlacklisted重新命名為isTrackExcluded。 - 修正在空白播放清單上呼叫
ExoPlayer.setMediaItem(s)和addMediaItem(s)時,兩者行為不一致的問題。
- 只有在明確選擇加入時,才允許 ExoPlayer 控制裝置音量方法。使用
- 轉換程式:
- 移除
Transformer.Builder.setMediaSourceFactory(MediaSource.Factory)。 請改用ExoPlayerAssetLoader.Factory(MediaSource.Factory)和Transformer.Builder.setAssetLoaderFactory(AssetLoader.Factory)。 - 移除
Transformer.startTransformation(MediaItem, ParcelFileDescriptor)。 - 修正錯誤:如果系統在等待處理輸入影格時收到影片串流結尾的信號,轉換作業可能會卡住 (導致多工器逾時)。
- 透過
MediaCodecList查詢轉碼器,而非使用findDecoder/EncoderForFormat公用程式,以擴大支援範圍。 - 移除
DefaultEncoderFactory中的 B 幀設定,因為部分裝置無法使用這項設定。
- 移除
- 音軌選取:
- 新增系統預設停用的
DefaultTrackSelector.Parameters.allowInvalidateSelectionsForRendererCapabilitiesChange。啟用後,當轉譯器功能變更時,DefaultTrackSelector會觸發新的軌道選取作業。
- 新增系統預設停用的
- 擷取工具:
- 音訊:
- 修正錯誤:啟用通道和
AudioProcessors時,部分播放作業會失敗,例如無間隙修剪 (#10847)。 - 在直接播放 (卸載) 中,將 Opus 影格封裝在 Ogg 封包中。
- 在睡眠期間,透過卸載排程推斷目前位置。
- 在播放器生命週期結束時新增
Renderer.release()和AudioSink.release(),以釋放資源。 - 在
DefaultAudioSink中監聽音訊功能變更。在DefaultAudioSink的建構函式中新增必要參數context,DefaultAudioSink會使用這項參數向AudioCapabilitiesReceiver註冊為監聽器,並在收到功能變更通知時更新audioCapabilities屬性。 - 透過
AudioSink.Listener介面中的新事件onAudioCapabilitiesChanged和新介面RendererCapabilities.Listener傳播音訊功能變更,觸發onRendererCapabilitiesChanged事件。 - 新增
ChannelMixingAudioProcessor,將縮放/混音套用至音訊聲道。 - 在
DecoderDiscardReasons中新增 int 值DISCARD_REASON_AUDIO_BYPASS_POSSIBLE,以便在音訊功能變更後,略過模式可能適用時捨棄音訊解碼器。 - 新增 DTS Express 和 DTS:X 的直接播放支援 (#335)。
- 修正錯誤:啟用通道和
- 影片:
- 當轉譯器停用時,請讓
MediaCodecVideoRenderer回報寬度和高度為 0 的VideoSize。Player.getVideoSize()變更時,系統會相應呼叫Player.Listener.onVideoSizeChanged。這項變更生效後,如果Player.getCurrentTracks不支援影片,或系統尚未判斷支援的視訊軌大小,ExoPlayer 的影片大小 (含MediaCodecVideoRenderer) 寬度和高度都會是 0。
- 當轉譯器停用時,請讓
- DRM:
- 降低
DefaultDrmSession上多種僅供內部使用的方法的瀏覽權限,這些方法不應從 DRM 套件外部呼叫:void onMediaDrmEvent(int)void provision()void onProvisionCompleted()onProvisionError(Exception, boolean)
- 降低
- Muxer:
- 新增可用於建立 MP4 容器檔案的 Muxer 程式庫。
- IMA 擴充功能:
- 為動態廣告插播啟用多週期直播 DASH 串流。請注意,目前的實作方式尚未支援在直播中搜尋 (#10912)。
- 修正錯誤:由於連續時間軸中計算出的內容位置略有差異,因此系統會在直播中插入新的廣告群組。
- 工作階段:
- 新增輔助方法
MediaSession.getControllerForCurrentRequest,取得目前呼叫Player方法的控制器相關資訊。 - 新增
androidx.media3.session.MediaButtonReceiver,讓應用程式能夠透過藍牙耳機等裝置傳送的媒體按鈕事件,實作播放作業續傳功能 (#167)。 - 在
MediaSession.Callback.onAddMediaItems中新增預設實作項目,允許將要求的MediaItems傳遞至Player(如果LocalConfiguration存在,例如 URI) (#282)。 - 在 Android 12 以下版本的小型媒體通知檢視畫面中,預設新增「seek to previous」和「seek to next」指令按鈕 (#410)。
- 在
MediaSession.Callback.onAddMediaItems中新增預設實作項目,允許將要求的MediaItems傳遞至Player(如果LocalConfiguration存在,例如 URI) (#282)。 - 在 Android 12 以下版本的小型媒體通知檢視畫面中,預設新增「seek to previous」和「seek to next」指令按鈕 (#410)。
- 新增輔助方法
- UI:
- 新增
shouldShowPlayButton和handlePlayPauseButtonActionUtil 方法,使用播放/暫停按鈕編寫自訂 UI 元素。
- 新增
- RTSP 擴充功能:
- DASH 擴充功能:
- 從多時段 DASH 串流的
MediaLoadData.startTimeMs和MediaLoadData.endTimeMs中移除媒體時間偏移。 - 修正重新準備多週期 Live Dash 媒體來源時,會產生
IndexOutOfBoundsException的錯誤 (#10838)。
- 從多時段 DASH 串流的
- HLS 擴充功能:
- 新增
HlsMediaSource.Factory.setTimestampAdjusterInitializationTimeoutMs(long),為載入執行緒設定逾時,等待TimestampAdjuster初始化。如果初始化作業未在逾時前完成,系統會擲回PlaybackException,避免播放作業無止盡地停滯。預設情況下,逾時時間會設為零 (#323)。
- 新增
- 測試公用程式:
- 檢查
DataSourceContractTest中的 URI 配置是否不區分大小寫。
- 檢查
- 移除已淘汰的符號:
- 移除
DefaultAudioSink建構函式,改用DefaultAudioSink.Builder。 - 移除
HlsMasterPlaylist,改用HlsMultivariantPlaylist。 - 移除
Player.stop(boolean)。請改用Player.stop()和Player.clearMediaItems()(如果reset是true)。 - 移除兩個已淘汰的
SimpleCache建構函式,改用採用DatabaseProvider的非淘汰建構函式,以提升效能。 - 移除
DefaultBandwidthMeter建構函式,改用DefaultBandwidthMeter.Builder。 - 移除
DefaultDrmSessionManager建構函式,改用DefaultDrmSessionManager.Builder。 - 移除兩個已淘汰的
HttpDataSource.InvalidResponseCodeException建構函式,並使用可接受額外欄位(cause、responseBody) 的非淘汰建構函式,加強錯誤記錄功能。 - 移除
DownloadHelper.forProgressive、DownloadHelper.forHls、DownloadHelper.forDash和DownloadHelper.forSmoothStreaming,改用DownloadHelper.forMediaItem。 - 移除已淘汰的
DownloadService建構函式,改用未淘汰的建構函式,其中包含提供channelDescriptionResourceId參數的選項。 - 移除已淘汰的字元集 String 常數 (
ASCII_NAME、UTF8_NAME、ISO88591_NAME、UTF16_NAME和UTF16LE_NAME),改用kotlin.text套件、java.nio.charset.StandardCharsets或com.google.common.base.Charsets中的 Kotlin 字元集。 - 移除已淘汰的
WorkManagerScheduler建構函式,改用非已淘汰的建構函式,其中包含提供Context參數的選項。 - 移除已淘汰的
createVideoSampleFormat、createAudioSampleFormat、createContainerFormat和createSampleFormat方法,這些方法用於例項化Format類別。請改用Format.Builder建立Format的例項。 - 移除已淘汰的方法
copyWithMaxInputSize、copyWithSubsampleOffsetUs、copyWithLabel、copyWithManifestFormatInfo、copyWithGaplessInfo、copyWithFrameRate、copyWithDrmInitData、copyWithMetadata、copyWithBitrate和copyWithVideoSize,改用Format.buildUpon()和設定器方法。 - 移除已淘汰的
ExoPlayer.retry(),改用prepare()。 - 移除已淘汰的零引數
DefaultTrackSelector建構函式,請改用DefaultTrackSelector(Context)。 - 移除已淘汰的
OfflineLicenseHelper建構函式,改用OfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)。 - 移除已淘汰的
DownloadManager建構函式,改用採用Executor的建構函式。 - 移除已淘汰的
Cue建構函式,改用Cue.Builder。 - 移除已淘汰的
OfflineLicenseHelper建構函式,改用OfflineLicenseHelper(DefaultDrmSessionManager, DrmSessionEventListener.EventDispatcher)。 - 移除四個已淘汰的
AnalyticsListener方法:onDecoderEnabled,請改用onAudioEnabled和/或onVideoEnabled。- 請改用
onAudioDecoderInitialized和/或onVideoDecoderInitialized。onDecoderInitialized - 請改用
onAudioInputFormatChanged和/或onVideoInputFormatChanged。onDecoderInputFormatChanged onDecoderDisabled,請改用onAudioDisabled和/或onVideoDisabled。
- 移除已淘汰的
Player.Listener.onSeekProcessed和AnalyticsListener.onSeekProcessed,改用onPositionDiscontinuity和DISCONTINUITY_REASON_SEEK。 - 移除
ExoPlayer.setHandleWakeLock(boolean),改用setWakeMode(int)。 - 移除已淘汰的
DefaultLoadControl.Builder.createDefaultLoadControl(),改用build()。 - 移除已淘汰的
MediaItem.PlaybackProperties,改用MediaItem.LocalConfiguration。已淘汰的欄位MediaItem.playbackProperties現在的類型為MediaItem.LocalConfiguration。
- 移除
1.1.0-rc01 版本
2023 年 6 月 21 日
使用 1.1.0 穩定版。
1.1.0-beta01 版本
2023 年 6 月 7 日
使用 1.1.0 穩定版。
1.1.0-alpha01 版本
2023 年 5 月 10 日
使用 1.1.0 穩定版。
1.0.0 版本
1.0.2 版
2023 年 5 月 18 日
發布了 androidx.media3:media3-*:1.0.2。1.0.2 版包含此連結所列的修訂項目。
此版本可對應至 ExoPlayer 2.18.7 版。
這個版本包含自 1.0.1 版以來的下列變更:
- 核心程式庫:
- 新增
Buffer.isLastSample(),表示Buffer是否包含旗標C.BUFFER_FLAG_LAST_SAMPLE。 - 修正問題:如果最後一個含有影格的樣本在未讀取「串流結尾」樣本的情況下出列,可能不會轉譯最後一個影格。(#11079)。
- 新增
- 擷取工具:
- 修正 MPEG-TS 檔案中 H.265 SPS 的剖析問題,方法是重新使用 RTSP 和 MP4 擷取器已使用的剖析邏輯 (#303)。
- 文字:
- SSA:針對開頭為位元組順序標記的 UTF-16 檔案新增支援 (#319)。
- 工作階段:
- 修正問題:連線至會更新動作的舊版
MediaSessionCompat時,MediaController不會更新可用指令。 - 修正錯誤,避免
MediaLibraryService無法針對從 System UI 呼叫Callback.onGetLibraryRoot的要求傳回空值 (API 30 上的params.isRecent == true) (#355)。 - 修正
MediaSessionService或MediaLibraryService的記憶體流失問題 (#346)。 - 修正錯誤:合併的
Timeline和位置更新可能會導致MediaController擲回IllegalStateException。MediaSession
- 修正問題:連線至會更新動作的舊版
1.0.1 版
2023 年 4 月 18 日
發布了 androidx.media3:media3-*:1.0.1。1.0.1 版包含以下修訂項目。
此版本可對應至 ExoPlayer 2.18.6 版。
- 核心程式庫:
- 搜尋預設位置時,重設目標直播覆寫 (#11051)。
- 修正媒體中空白樣本串流可能導致播放卡住的錯誤。
- 工作階段:
- 修正錯誤:舊版
MediaSessionCompat發布多個相同佇列項目時,導致MediaController發生例外狀況 (#290)。 - 新增遺失的
MediaSession.broadcastCustomCommand轉送至舊版MediaControllerCompat.Callback.onSessionEvent(#293)。 - 修正錯誤:呼叫
MediaSession.setPlayer時,可用指令不會更新。 - 修正問題:如果
TrackSelectionOverride執行個體參照的群組具有Format.metadata,系統會忽略從MediaController傳送的TrackSelectionOverride執行個體 (#296)。 - 修正問題:
Player.COMMAND_GET_CURRENT_MEDIA_ITEM必須可供存取,才能透過舊版MediaSessionCompat存取中繼資料。 - 修正問題:在背景執行緒上的
MediaSession例項於MediaSessionService中使用時,會導致當機 (#318)。 - 修正問題:程式庫宣告媒體按鈕接收器,但應用程式並未打算這麼做 (#314)。
- 修正錯誤:舊版
- DASH:
- 修正空白區隔時間軸的處理方式 (#11014)。
- RTSP:
- 如果使用 UDP 的 RTSP 設定失敗,並顯示 RTSP 錯誤 461 UnsupportedTransport,請使用 TCP 重試 (#11069)。
1.0.0 版本
2023 年 3 月 22 日
發布了 androidx.media3:media3-*:1.0.0。1.0.0 版包含此連結所列的修訂項目。
此版本可對應至 ExoPlayer 2.18.5 版。
自 1.0.0-rc02 以來沒有任何異動。
1.0.0-rc02 版
2023 年 3 月 2 日
發布了 androidx.media3:media3-*:1.0.0-rc02。查看 1.0.0-rc02 版的修訂項。
此版本可對應至 ExoPlayer 2.18.4 版。
- 核心程式庫:
- 下載內容:
- 在
SegmentDownloader和子類別 (#248) 中,將要合併的兩個區隔的開始時間最大差異設為可設定。
- 在
- 音訊:
- 影片:
- 將 HEVC HDR10 格式對應至
HEVCProfileMain10HDR10,而非HEVCProfileMain10。 - 針對 Chromecast (支援 Google TV) 和 Lenovo M10 FHD Plus 裝置問題新增解決方法,此問題會導致 60 fps AVC 串流標示為不支援 (#10898)。
- 修正播放影格速率遠高於螢幕刷新率的媒體時,影格發布效能的問題。
- 將 HEVC HDR10 格式對應至
- 投放:
- 修正在媒體項目之間轉場時發生的暫時性
STATE_IDLE問題 (#245)。
- 修正在媒體項目之間轉場時發生的暫時性
- RTSP:
- 擷取剖析無效 RTSP Describe 回應訊息時擲回的 IllegalArgumentException (#10971)。
- 工作階段:
- 修正通知的播放/暫停按鈕不會隨著播放器狀態更新的錯誤 (#192)。
- IMA 擴充功能:
- 修正錯誤:如果 DAI 串流沒有任何廣告,系統不會收到第一個 (也是唯一一個)
LOADED事件,導致串流無法啟動。
- 修正錯誤:如果 DAI 串流沒有任何廣告,系統不會收到第一個 (也是唯一一個)
1.0.0-rc01 版
2023 年 2 月 16 日
發布了 androidx.media3:media3-*:1.0.0-rc01。1.0.0-rc01 版包含以下修訂項目。
此版本可對應至 ExoPlayer 2.18.3 版。
- 核心程式庫:
- 調整轉譯器的解碼器排序邏輯,以維持
MediaCodecSelector的偏好設定,即使解碼器回報可能無法順利播放媒體亦然。舉例來說,在預設選取器中,系統會優先採用僅提供功能性支援的硬體解碼器,而非完全支援格式的軟體解碼器。(#10604)。 - 新增
ExoPlayer.Builder.setPlaybackLooper,可為新的 ExoPlayer 執行個體設定既有的播放執行緒。 - 允許清除下載管理員協助程式。(#10776)。
- 新增參數至
BasePlayer.seekTo,以指示用於搜尋的指令。 - 在 API 21 以上版本載入可繪項目時使用主題。(#220)。
- 新增
ConcatenatingMediaSource2,允許將多個媒體項目合併至單一視窗。(#247)。
- 調整轉譯器的解碼器排序邏輯,以維持
- 擷取工具:
- 剖析 trak atom 時,如果範例資料表 (stbl) 缺少必要的範例說明 (stsd),則請擲回
ParserException而非NullPointerException。 - 在 fMP4 中直接搜尋同步影格時,正確略過範例 (#10941)。
- 剖析 trak atom 時,如果範例資料表 (stbl) 缺少必要的範例說明 (stsd),則請擲回
- 音訊:
- 使用壓縮的音訊格式位元率來計算直接播放 (直通) 中
AudioTrack的緩衝區大小下限。
- 使用壓縮的音訊格式位元率來計算直接播放 (直通) 中
- 文字:
- 如果字幕檔案不含任何提示,請修正
TextRenderer將無效 (負面) 索引傳遞至Subtitle.getEventTime的問題。 - SubRip:針對開頭為位元組順序標記的 UTF-16 檔案新增支援。
- 如果字幕檔案不含任何提示,請修正
- 中繼資料:
- 依據 ID3 v2.4 的許可,從 ID3 影格剖析多個以空值分隔的值。
- 新增
MediaMetadata.mediaType,來表示內容類型或中繼資料說明的資料夾類型。 - 新增
MediaMetadata.isBrowsable以取代MediaMetadata.folderType。資料夾類型會在下一個版本中淘汰。
- DASH:
- 為圖片調整集新增完整剖析功能,包括圖塊數量。(#3752)。
- UI:
- 工作階段:
- 新增抽象
SimpleBasePlayer,以協助實作自訂播放器的Player介面。 - 新增輔助方法,將平台工作階段符記轉換為 Media3
SessionToken(#171)。 - 使用
onMediaMetadataChanged觸發平台媒體工作階段的更新作業 (#219)。 - 將媒體工作階段新增為
getMediaButtons()的DefaultMediaNotificationProvider引數,並使用不可變動的清單以確保清晰度。(#216)。 - 新增
onSetMediaItems回呼監聽器,提供修改/設定MediaItem清單的方式,在播放器上設定索引和位置之前,依工作階段起始索引和位置 (#156)。 - 避免在非藍牙媒體按鈕事件上輕觸兩下偵測 (#233)。
- 使
QueueTimeline出現可疑的舊版工作階段狀態時更可靠 (#241)。
- 新增抽象
- 中繼資料:
- 依據 ID3 v2.4 的許可,從 ID3 影格剖析多個以空值分隔的值。
- 新增
MediaMetadata.mediaType,來表示內容類型或中繼資料說明的資料夾類型。 - 新增
MediaMetadata.isBrowsable以取代MediaMetadata.folderType。資料夾類型會在下一個版本中淘汰。
- Cast 擴充功能:
- 將 Cast SDK 版本遞增升級至 21.2.0。
- IMA 擴充功能:
- 移除應用程式執行緒上
ImaServerSideAdInsertionMediaSource的播放器監聽器,以免發生執行緒問題。 - 將屬性
focusSkipButtonWhenAvailable新增至ImaServerSideAdInsertionMediaSource.AdsLoader.Builder,以要求在電視裝置上聚焦略過按鈕,並根據預設將其設定為 true。 - 將方法
focusSkipButton()新增至ImaServerSideAdInsertionMediaSource.AdsLoader,以程式輔助方式要求聚焦略過按鈕。 - 將 IMA SDK 版本遞增升級至 3.29.0。
- 移除應用程式執行緒上
- 試用版應用程式:
- 在執行階段要求下載通知的通知權限。(#10884)。
1.0.0-beta03 版
2022 年 11 月 22 日
發布了 androidx.media3:media3-*:1.0.0-beta03。1.0.0-beta03 版包含此連結所列的修訂項目。
此版本可對應至 ExoPlayer 2.18.2 版。
- 核心程式庫:
- 新增
ExoPlayer.isTunnelingEnabled來檢查目前所選的音軌是否已啟用穿隧。(#2518)。 - 新增
WrappingMediaSource來將換行簡化為MediaSource。(#7279)。 - 在播放因可用記憶體不足而卡住時捨棄背景緩衝區。
- 啟用卸載時關閉追蹤「doSomeWork」區塊。
- 修正
PlaybackStatsListener中快速跳轉的工作階段追蹤問題。(#180)。 - 在單一項目播放清單中呼叫
seekToNext或seekToPrevious時,傳送缺少的onMediaItemTransition回呼 (#10667)。 - 新增
Player.getSurfaceSize,傳回影片算繪所在途徑的大小。 - 修正在播放器釋出期間移除事件監聽器會導致
IllegalStateException的錯誤。(#10758)。
- 新增
- 版本:
- 強制執行最低
compileSdkVersion,以避免編譯錯誤。(#10684)。 - 避免包含在其他 Gradle 版本時,發布模塊。
- 強制執行最低
- 音軌選取:
- 如果螢幕不支援 Dolby Vision,則使用其他音軌。 (#8944)。
- 下載內容:
- 影片:
- 如果螢幕不支援 Dolby Vision,不妨試試替代解碼器。 (#9794)。
- 音訊:
- 將
SingleThreadExecutor用於發布AudioTrack執行個體,以免同時發布多個播放器時發生 OutOfMemory 錯誤。(#10057)。 - 已針對 AudioTrack 卸載狀態新增
AudioOffloadListener.onExperimentalOffloadedPlayback。(#134)。 - 始
AudioTrackBufferSizeProvider成為公用介面。 - 新增
ExoPlayer.setPreferredAudioDevice以設定偏好的音訊輸出裝置 (#135)。 - 將
androidx.media3.exoplayer.audio.AudioProcessor重新命名為androidx.media3.common.audio.AudioProcessor。 - 將 8 聲道和 12 聲道音訊對應到所有 7.1 和 7.1.4 聲道遮罩 (#10701)。
- 將
- 中繼資料:
- 現在可以設定
MetadataRenderer,以在中繼資料可用時盡快轉譯。建立具有MetadataRenderer(MetadataOutput, Looper, MetadataDecoderFactory, boolean)的執行個體,以指定轉譯器要否要提早輸出中繼資料,或與播放器位置同步。
- 現在可以設定
- DRM:
- 解決 Android 13 ClearKey 實作中的錯誤,該錯誤會傳回非空白但無效的授權網址。
- 修正在播放清單中切換數位版權管理配置 (例如 Widevine 至 ClearKey) 時會發生
setMediaDrmSession failed: session not opened錯誤。
- 文字:
- CEA-608:確保系統正確處理欄位 2 的服務切換指令。(#10666)。
- DASH:
- 從資訊清單中剖析
EventStream.presentationTimeOffset(#10460)。
- 從資訊清單中剖析
- UI:
- 將播放器目前的覆寫設定做為
TrackSelectionDialogBuilder中的預設值使用 (#10429)。
- 將播放器目前的覆寫設定做為
- 工作階段:
- 即使某些需要非同步解析,仍可確保指令以正確順序執行 (#85)。
- 新增
DefaultMediaNotificationProvider.Builder以建構DefaultMediaNotificationProvider執行個體。建構工具可以設定供應商使用的通知 ID、通知管道 ID 和通知管道名稱。此外,請新增方法DefaultMediaNotificationProvider.setSmallIcon(int),以設定通知小圖示。(#104)。 - 確保在不捨棄
MediaController.release()前傳送指令。(#99)。 SimpleBitmapLoader可以從file://URI 載入點陣圖 (#108)。- 修正防止
MediaController在一段時間內搜尋廣告 (#122) 的斷言。 - 播放結束後,
MediaSessionService就會停止在前景播放,並顯示可重新啟動播放上一次所播放媒體項目的通知。(#112)。 - 請勿為了暫停而啟動具有待處理意圖的前景服務。(#167)。
- 手動隱藏與
DefaultNotificationProvider在 API 26 和 API 27 (API 28 以上版本會自動隱藏標記) 上建立通知相關聯的「標記」(#131)。 - 修正從舊版 MediaSession 至 Media3 MediaController 的第二個繫結機制連線導致 IllegalStateException 的錯誤。(#49)。
- RTSP:
- 我是:
- FFmpeg 擴充功能:
- 新增必要的旗標,以連結 FFmpeg 程式庫與 NDK 23.1.7779620 以上版本 (#9933)。
- AV1 擴充功能:
- 請更新 CMake 版本,以免與最新的 Android Studio 版不相容 (#9933)。
- Cast 擴充功能:
- 實作
getDeviceInfo(),以便在使用MediaController控制播放時能夠識別CastPlayer。(#142)。
- 實作
- 轉換程式:
- 新增多工器監控計時器,以偵測何時產生輸出樣本時太慢。
- 移除已淘汰的符號:
- 移除
Transformer.Builder.setOutputMimeType(String)。這項功能已停用。使用預設多工器時,MIME 類型一律為 MP4。
- 移除
1.0.0-beta02 版
2022 年 7 月 21 日
發布了 androidx.media3:media3-*:1.0.0-beta02。查看 1.0.0-beta02 版的修訂項。
此版本可對應至 ExoPlayer 2.18.1 版。
- 核心程式庫:
- 確認透過
ExoPlayer.setShuffleOrder變更ShuffleOrder會導致使用reason=Player.TIMELINE_CHANGE_REASON_PLAYLIST_CHANGED向Player.Listener#onTimelineChanged呼叫 (#9889)。 - 如果是漸進式媒體,請只加入在緩衝處理位置選取的曲目 (#10361)。
- 允許所有 ExoPlayer 記錄輸出使用自訂記錄器 (#9752)。
- 修正
DefaultMediaSourceFactory中的setDataSourceFactory實作,在某些情況下無法正常運作的問題 (#116)。
- 確認透過
- 擷取工具:
- DASH:
- 從資訊清單中剖析 ClearKey 授權網址 (#10246)。
- UI:
- 確保 TalkBack 會在播放控制項選單中公告目前使用中的速度選項 (#10298)。
- RTSP:
- 新增 VP8 片段化封包處理 (#110)。
- Leanback 擴充功能:
- 監聽
LeanbackAdapter中的playWhenReady變更 (10420)。
- 監聽
- 投放:
1.0.0-beta01 版
2022 年 6 月 16 日
發布了 androidx.media3:media3-*:1.0.0-beta01。1.0.0-beta01 版包含此連結所列的修訂項目。
這與 ExoPlayer 2.18.0 版相對應。
- 核心程式庫:
- 透過
MediaMetricsManager啟用 Android 平台診斷支援功能。ExoPlayer 會向平台傳送播放事件和效能資料,有助於在裝置提供系統效能與偵錯資訊。如果裝置使用者已啟用分享使用狀況與診斷資料功能,則 Google 也可能會收集以上資料。您可以透過ExoPlayer.Builder.setUsePlatformDiagnostics(false),讓應用程式選擇不採用 ExoPlayer 的平台診斷貢獻功能。 - 修正使用
MergingMediaSource會造成音軌重設過度頻繁的問題,例如在播放途中側載字幕及變更選取的字幕便會發生這個情況 (#10248)。 - 停止在 API 29 及 30 偵測 5G-NSA 網路類型。這些播放動作會假設是透過 4G 網路進行。
- 不允許將
null傳遞至MediaSource.Factory.setDrmSessionManagerProvider和MediaSource.Factory.setLoadErrorHandlingPolicy。如有必要,可以明確傳遞DefaultDrmSessionManagerProvider和DefaultLoadErrorHandlingPolicy的執行個體。 - 新增
MediaItem.RequestMetadata,方便在LocalConfiguration還不明確時,代表播放媒體所需的中繼資料。另外也移除MediaMetadata.mediaUrl,因為現在這個中繼資料已內含在RequestMetadata。 - 新增
Player.Command.COMMAND_SET_MEDIA_ITEM,以便讓播放器設定單翼項目。
- 透過
- 音軌選取:
- 將
TrackSelectionOverrides類別壓平合併至TrackSelectionParameters,並將TrackSelectionOverride升級至頂層類別。 - 將
TracksInfo重新命名為Tracks,並將TracksInfo.TrackGroupInfo重新命名為Tracks.Group。Player.getCurrentTracksInfo和Player.Listener.onTracksInfoChanged也已經重新命名為Player.getCurrentTracks和Player.Listener.onTracksChanged。這包括「取消淘汰」Player.Listener.onTracksChanged方法名稱,不過參數類型不同。 - 將
DefaultTrackSelector.buildUponParameters和DefaultTrackSelector.Parameters.buildUpon變更為回傳DefaultTrackSelector.Parameters.Builder,而不是已淘汰的DefaultTrackSelector.ParametersBuilder。 - 新增系統預設啟用的
DefaultTrackSelector.Parameters.constrainAudioChannelCountToDeviceCapabilities。啟用後,DefaultTrackSelector會偏好使用頻道數量並未超出裝置輸出能力範圍的音軌。在手持裝置上,DefaultTrackSelector比起多頻道音訊格式更偏好使用立體聲/單聲道,除非多頻道格式可以設定空間音訊 (Android 12L 以上) 或是 Dolby 環場音效格式。另外,若在可以支援空間音訊的裝置上,則DefaultTrackSelector會監控空間音訊化屬性的變更情況,並在變更時觸發選取新的音軌。設有televisionUI 模式的裝置不受這些限制,系統會偏好使用最多頻道數量的格式。如要啟用這項功能,必須用Context建構DefaultTrackSelector執行個體。
- 將
- 影片:
- 將
DummySurface重新命名為PlaceholderSurface。 - 新增
MediaCodecVideoRenderer.getCodecMaxInputSize的 AV1 支援功能。
- 將
- 音訊:
- 使用 LG AC3 音訊解碼器通告非標準的 MIME 類型。
- 將
AudioAttributes.getAudioAttributesV21()的傳回類型從android.media.AudioAttributes變更為新的AudioAttributesV21包裝函式類別,防止 API 21 以下會發生 ART 驗證過慢的情況。 - 在 HTTP 即時串流不分區塊準備時,會發生未設定格式音訊頻道數量的情況,此時請查詢平台 (API 29 以上) 或為音訊直通假設音訊編碼頻道數量 (10204)。
- 如果解碼器輸出 12 頻道 PCM 音訊,請用頻道遮罩
AudioFormat.CHANNEL_OUT_7POINT1POINT4設定AudioTrack(#10322)。
- DRM
- 如果在變更格式後需要立即尋求 DRM 工作階段,請確定 DRM 工作階段一律可以正常更新 (10274)。
- 文字:
- 將
Player.getCurrentCues()變更為回傳CueGroup,而不是List<Cue>。 - SSA:在
BorderStyle == 3的情況下支援OutlineColour樣式設定 (也就是說OutlineColour會設定提示的背景) (#8435)。 - CEA-708:將資料剖析為多個服務區塊,並忽略並未和目前選取的服務編號相關的區塊。
- 移除
RawCcExtractor,這個項目只有 Google 內部字幕格式使用。
- 將
- 擷取工具:
- UI:
- 修正
useController=false時,在PlayerView上遞送事件到OnClickListener組合的問題 (#9605)。同時,修正所有檢視畫面設定的遞送事件到OnLongClickListener的問題。 - 修正在
ACTION_UP之前,誤將退出PlayerView邊界的觸控事件序列視為點擊的問題 (#9861)。 - 修正
PlayerView輕觸時可能會觸發播放而不是隱藏控制項的無障礙功能問題 (#8627)。 - 重新編寫
TrackSelectionView和TrackSelectionDialogBuilder,以便正確搭配Player介面使用,而不是ExoPlayer。這樣做可讓檢視畫面和其他Player實作內容一同使用,並可移除 UI 模組對於 ExoPlayer 模組的依附性。這是一項破壞性變更。 - 不在
PlayerView音軌選取器內顯示強制文字音軌,當選擇「None」(無) 時,保留合適的強制文字音軌 (#9432)。
- 修正
- DASH:
- 從 DTS
AudioChannelConfiguration元素剖析頻道數量,這樣便能重新啟用 DTS 串流的音訊直通 (#10159)。 - 禁止將
null傳遞至DashMediaSource.Factory.setCompositeSequenceableLoaderFactory。如果有必要的話,可以明確傳遞DefaultCompositeSequenceableLoaderFactory的執行個體。
- 從 DTS
- HLS:
- 如果播放清單的轉碼器屬性並未含有該音訊轉碼器,則使用備用的分區塊準備 (#10065)。
- 禁止將
null傳遞至HlsMediaSource.Factory.setCompositeSequenceableLoaderFactory、HlsMediaSource.Factory.setPlaylistParserFactory及HlsMediaSource.Factory.setPlaylistTrackerFactory。如有需要,可以明確傳遞DefaultCompositeSequenceableLoaderFactory和DefaultHlsPlaylistParserFactory的執行個體或DefaultHlsPlaylistTracker.FACTORY的參考資料。
- 流暢串流:
- 禁止將
null傳遞至SsMediaSource.Factory.setCompositeSequenceableLoaderFactory。如果有必要的話,可以明確傳遞DefaultCompositeSequenceableLoaderFactory的執行個體。
- 禁止將
- RTSP:
- 新增 H263 的 RTP 讀取工具 (#63)。
- 新增 MPEG4 的 RTP 讀取工具 (#35)。
- 新增 HEVC 的 RTP 讀取工具 (#36)。
- 新增 AMR 的 RTP 讀取工具。目前僅支援單頻道和非交錯 AMR 串流。不支援複合 AMR RTP 酬載。(#46)
- 新增 VP8 的 RTP 讀取工具 (#47)。
- 新增 WAV 的 RTP 讀取工具 (#56)。
- 修正 RTSP 基本授權標頭。(#9544)。
- 停止檢查強制性的 SDP 欄位,因為 ExoPlayer 不需要這些欄位 (#10049)。
- 在剖析 RTSP 時間點時擲回已檢查過的例外狀況 (#10165)。
- 新增 VP9 的 RTP 讀取工具 (#47)。
- 新增 OPUS 的 RTP 讀取工具 (#53)。
- 資料來源:
- 將
DummyDataSource重新命名為PlaceholderDataSource。 - 解決 OkHttp 中斷處理的問題。
- 將
- 工作階段:
- 將
MediaSession.MediaItemFiller替換為MediaSession.Callback.onAddMediaItems,以便要求使用非同步解析。 - 當
MediaController連結到舊版工作階段時,支援setMediaItems(s)方法。 - 移除
MediaController.setMediaUri和MediaSession.Callback.onSetMediaUri。您可以用MediaController.setMediaItem和MediaSession.Callback.onAddMediaItems達到相同功能。 - 將舊版的
MediaController播放媒體呼叫傳遞給MediaSession.Callback.onAddMediaItems,而不是onSetMediaUri。 - 新增
MediaNotification.Provider和DefaultMediaNotificationProvider,以便自訂通知內容。 - 新增
BitmapLoader和SimpleBitmapLoader,以便下載作品圖片。 - 新增
MediaSession.setCustomLayout(),以便為舊版工作階段提供回溯相容性。 - 新增
MediaSession.setSessionExtras(),以便提供和舊版工作階段同等的功能。 - 將
MediaSession.MediaSessionCallback重新命名為MediaSession.Callback,MediaLibrarySession.MediaLibrarySessionCallback重新命名為MediaLibrarySession.Callback,並將MediaSession.Builder.setSessionCallback重新命名為setCallback。 - 修正
MediaControllerImplLegacy中的 NPE (#59)。 - 更新時間軸的工作階段位置 (#51)。
- 修正釋放控制器之後
MediaControllerImplBase裡的 NPE (#74)。
- 將
- 廣告播放 / IMA:
- 將廣告輪詢頻率從 100 毫秒降為 200 毫秒,以符合美國媒體評議會 (MRC) 建議內容。
- FFmpeg 擴充功能:
- 將 CMake 版本更新至
3.21.0+,以避免發生導致 AndroidStudio Gradle 同步化失敗的 CMake 錯誤 (#9933)。
- 將 CMake 版本更新至
- 移除已淘汰的符號:
- 移除
Player.Listener.onTracksChanged(TrackGroupArray, TrackSelectionArray)。改用Player.Listener.onTracksChanged(Tracks)。 - 移除
Player.getCurrentTrackGroups和Player.getCurrentTrackSelections。請改用Player.getCurrentTracks。您也可以繼續使用ExoPlayer.getCurrentTrackGroups和ExoPlayer.getCurrentTrackSelections,不過這些項目會繼續視為已淘汰的方法。 - 移除
DownloadHelperDEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_VIEWPORT和DEFAULT_TRACK_SELECTOR_PARAMETERS等常數。請盡量改為使用getDefaultTrackSelectorParameters(Context)或DEFAULT_TRACK_SELECTOR_PARAMETERS_WITHOUT_CONTEXT。 - 移除建構函式
DefaultTrackSelector(ExoTrackSelection.Factory)。請改用DefaultTrackSelector(Context, ExoTrackSelection.Factory)。 - 移除
Transformer.Builder.setContext。Context應改為傳遞至Transformer.Builder建構函式。
- 移除
1.0.0-alpha03 版本
2022 年 3 月14 日
發布了 androidx.media3:media3-*:1.0.0-alpha03。查看 1.0.0-alpha03 版的修訂項。
這與 ExoPlayer 2.17.1 版相對應。
- 音訊:
- 修正在 HLS 中檢查 Dolby Atmos (E-AC3-JOC) 音訊功能時發生的錯誤。
- 擷取工具:
- FMP4:修正針對同時包含 v0 和 v1 emsg Atom 的串流,emsg 範例中繼資料可能以錯誤順序輸出的問題 (#9996)。
- 文字:
- 修正
SingleSampleMediaSource.Factory.setTrackId和MediaItem.SubtitleConfiguration.Builder.setId的互動方式,以便優先處理SubtitleConfiguration欄位;如果未設定,改回使用Factory值 (#10016)。
- 修正
- 廣告播放:
- 修正即時 HLS SSAI 串流中,廣告時段之間的音訊欠載問題。
1.0.0-alpha02 版
2022 年 3 月 2 日
發布了 androidx.media3:media3-*:1.0.0-alpha02。1.0.0-alpha02 版包含此連結所列的修訂項目。
這與 ExoPlayer 2.17.0 版相對應。
- 核心程式庫:
- 新增受保護的方法
DefaultRenderersFactory.getCodecAdapterFactory(),讓覆寫buildVideoRenderers()或buildAudioRenderers()的DefaultRenderersFactory子類別可以存取轉碼器轉接器工廠,並將其傳遞至所建立的MediaCodecRenderer執行個體。 - 將 ICY 標頭欄位
name和genre分別傳播至MediaMetadata.station和MediaMetadata.genre,這樣他們才能透過Player.Listener.onMediaMetadataChanged()到達應用程式 (#9677 )。 - 從
DefaultHttpDataSource#getResponseHeaders移除空值索引鍵。 - 建立
MediaCodec執行個體失敗時,休眠然後再試一次。這個方法適用於部分裝置將途徑從安全轉碼器切換至其他轉碼器時發生的問題 (#8696)。 - 新增
MediaCodecAdapter.getMetrics(),以便讓使用者從MediaCodec取得指標資料。(#9766)。 - 修正 Maven 依附元件解析度 (#8353)。
- 針對未啟用低延遲功能或使用者要求設定速度的直播,停用自動速度調整項 (#9329)。
- 將
DecoderCounters#inputBufferCount重新命名為queuedInputBufferCount。 - 將
SimpleExoPlayer.renderers設為私人。轉譯器可透過ExoPlayer.getRenderer存取。 - 已將部分
AnalyticsListener.EventFlags常數值更新為符合Player.EventFlags中的值。 - 將
AnalyticsCollector分割為介面和預設實作作業,若應用程式不需要,即可用 R8 將其移除。
- 新增受保護的方法
- 音軌選取:
- 在音軌選取中支援偏好的影片角色旗標 (#9402)。
- 更新影片音軌選取邏輯,在選取多重影片音軌以便調整時,採用偏好的 MIME 類型和角色旗標 (#9519)。
- 更新影片和音軌選取邏輯,僅選擇具有相同解碼器和硬體支援等級的可調整選項格式 (#9565)。
- 更新影片軌選取邏輯,如果主要的硬體加速解碼器支援多個轉碼器,則偏好選用效率較高的轉碼器 (#4835)。
- 偏好音訊內容偏好設定 (例如「預設」音軌或符合系統語言代碼語言的音軌),而不是技術音軌選取限制 (例如偏好的 MIME 類型或頻道數量上限)。
- 修正音軌選取問題:覆寫其中一個音軌組時,並未停用相同類型的其他音軌組 (#9675)。
- 修正未正確套用非空白及空白混合音軌覆寫的音軌選取問題 (#9649)。
TrackGroupArray中TrackGroup禁止重複。您隨時可以在TrackGroup建構函式中設定id,藉此區分TrackGroup。此做法修正使用主動音軌覆寫後,在應用程式背景作業後恢復播放時發生的異常終止問題 (#9718)。- 修正
AdaptiveTrackSelection中的邏輯,允許在網路頻寬足夠時提高品質,即使播放品質已非常接近目前最佳串流品質 (#9784)。
- 影片:
- 修正 Dolby Vision 中的解碼器備用邏輯,視需要使用相容的 H264/H265 解碼器。
- 音訊:
- 擷取工具:
- 文字:
- DRM:
- 從
DrmSessionManager.(pre)acquireSession中playbackLooper移除。當自訂MediaSource中的應用程式使用DrmSessionManager時,必須改將playbackLooper傳遞至DrmSessionManager.setPlayer。
- 從
- 廣告播放 / IMA:
- 新增 IMA 動態廣告插播 (DAI) 支援 (#8213)。
- 將方法新增至
AdPlaybackState以允許重設廣告群組,以便系統再次播放廣告群組 (#9615)。 - 在廣告播放期間強制執行 1.0 的播放速度 (#9018)。
- 修正廣告群組載入失敗,並導致播放立即重設的問題 (#9929)。
- UI:
- DASH:
- HLS:
- RTSP:
- 轉換程式:
- 將最低 API 版本提升至 21。
TransformationException現已用於描述轉換期間發生的錯誤。- 新增
TransformationRequest來指定轉換選項。 - 允許註冊多個事件監聽器。
- 修正轉換程式在部分轉碼器輸出讀取後卡住的問題。
- 修正釋出多工器時,
Transformer.getProgress中可能擲回的 NPE。 - 新增用於套用轉換的試用版應用程式。
- MediaSession 擴充功能:
- 根據預設,
MediaSessionConnector現在會在停止時清除播放清單。 如果希望應用程式保留播放清單,可在連接器上呼叫setClearMediaItemsOnStop(false)。
- 根據預設,
- Cast 擴充功能:
- FFmpeg 擴充功能:
- 讓
build_ffmpeg.sh依賴 LLVM 而非 GNU 的作業區公用程式 (#9933)。
- 讓
- Android 12 相容性:
- 升級 Cast 擴充功能,使其仰賴
com.google.android.gms:play-services-cast-framework:20.1.0。先前版本的play-services-cast-framework與指定 Android 12 的應用程式不相容,並在建立PendingIntent時會因IllegalArgumentException異常終止 (#9528)。
- 升級 Cast 擴充功能,使其仰賴
- 移除已淘汰的符號:
- 移除
Player.EventListener。改用Player.Listener。 - 移除
MediaSourceFactory#setDrmSessionManager、MediaSourceFactory#setDrmHttpDataSourceFactory和MediaSourceFactory#setDrmUserAgent。改用MediaSourceFactory#setDrmSessionManagerProvider。 - 移除
MediaSourceFactory#setStreamKeys。改用MediaItem.Builder#setStreamKeys。 - 移除
MediaSourceFactory#createMediaSource(Uri)。改用MediaSourceFactory#createMediaSource(MediaItem)。 - 將
setTag從DashMediaSource、HlsMediaSource和SsMediaSource中移除。改用MediaItem.Builder#setTag。 - 移除
DashMediaSource#setLivePresentationDelayMs(long, boolean)。使用MediaItem.Builder#setLiveConfiguration和MediaItem.LiveConfiguration.Builder#setTargetOffsetMs覆寫資訊清單,或使用DashMediaSource#setFallbackTargetLiveOffsetMs提供備用值。 - 移除
(Simple)ExoPlayer.setThrowsWhenUsingWrongThread。無法再選擇不採用執行緒強制執行功能。 - 移除
ActionFile和ActionFileUpgradeUtil。使用 ExoPlayer 2.16.1 以下版,以使用ActionFileUpgradeUtil將舊版操作檔案合併到DefaultDownloadIndex。 - 移除
ProgressiveMediaSource#setExtractorsFactory。改用ProgressiveMediaSource.Factory(DataSource.Factory, ExtractorsFactory)建構函式。 - 移除
ProgressiveMediaSource.Factory#setTag和ProgressiveMediaSource.Factory#setCustomCacheKey。改用MediaItem.Builder#setTag和MediaItem.Builder#setCustomCacheKey。 - 移除
DefaultRenderersFactory(Context, @ExtensionRendererMode int)和DefaultRenderersFactory(Context, @ExtensionRendererMode int, long)建構函式。改用DefaultRenderersFactory(Context)建構函式、DefaultRenderersFactory#setExtensionRendererMode和DefaultRenderersFactory#setAllowedVideoJoiningTimeMs。 - 移除所有公開的
CronetDataSource建構函式。改用CronetDataSource.Factory。
- 移除
- 請將下列
IntDefs變更為僅限@Target(TYPE_USE)。這可能會導致 Kotlin 環境中的用量編譯作業中斷,移動備註類型的註解可修正此問題 (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(com.google.android.exoplayer2.ext.flac套件中)@FlacExtractor.Flags(com.google.android.exoplayer2.extractor.flac套件中)@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
1.0.0-alpha01 版
2021 年 10 月 27 日
發布了 androidx.media3:media3-*:1.0.0-alpha01。1.0.0-alpha01 版本包含以下修訂項目。
新功能
Media3 是媒體支援程式庫 (包括 ExoPlayer) 的新園地。第一個 Alpha 版包含下列早期功能性程式庫實作,目的是用於實作媒體應用實例:
- ExoPlayer,這是 Android 的應用程式等級媒體播放器,易於自訂及擴充。
- 媒體工作階段功能,用於公開和控制播放。這個新的工作階段模組使用與 ExoPlayer 相同的
Player介面。 - 用於建立媒體播放使用者介面的 UI 元件。
- 其他程式庫中可與 ExoPlayer 搭配使用的模組包裝功能,例如透過 IMA SDK 插入廣告。
詳情請參閱 Media3 GitHub 專案。
ExoPlayer 先前是在另一個 ExoPlayer GitHub 專案中代管。在 Media3 中,其套件名稱為 androidx.media3.exoplayer。我們打算持續維護及發布 ExoPlayer GitHub 專案一段時間,讓應用程式有時間遷移至 Media3。Media3 將取代所有 ExoPlayer 模組 (舊版 Media2 和 mediasession 擴充功能除外,前述兩者會以新版 media3-session 模組取代)。如此一來,不需使用轉接器/連接器類別,就能直接整合播放器及媒體工作階段。