播放期間
媒體中繼資料可在播放期間透過多種方式擷取。最直接的方式就是監聽 Player.Listener#onMediaMetadataChanged
事件,這樣就能提供要使用的 MediaMetadata
物件,其中包含 title
和 albumArtist
等欄位。或者,呼叫 Player#getMediaMetadata
會傳回同一個物件。
Kotlin
override fun onMediaMetadataChanged(mediaMetadata: MediaMetadata) { mediaMetadata.title?.let(::handleTitle) }
Java
@Override public void onMediaMetadataChanged(MediaMetadata mediaMetadata) { if (mediaMetadata.title != null) { handleTitle(mediaMetadata.title); } }
如果應用程式需要存取特定的 Metadata.Entry
物件,則應監聽 Player.Listener#onMetadata
(針對播放期間傳送的動態中繼資料)。如果您需要查看靜態中繼資料,可以透過 TrackSelections#getFormat
存取。Player#getMediaMetadata
會從這兩個來源填入。
沒有播放內容
如果不需要播放,使用 MetadataRetriever
擷取中繼資料會更有效率,因為這樣就不必建立和準備播放器。
Kotlin
val trackGroupsFuture = MetadataRetriever.retrieveMetadata(context, mediaItem) Futures.addCallback( trackGroupsFuture, object : FutureCallback<TrackGroupArray?> { override fun onSuccess(trackGroups: TrackGroupArray?) { if (trackGroups != null) handleMetadata(trackGroups) } override fun onFailure(t: Throwable) { handleFailure(t) } }, executor )
Java
ListenableFuture<TrackGroupArray> trackGroupsFuture = MetadataRetriever.retrieveMetadata(context, mediaItem); Futures.addCallback( trackGroupsFuture, new FutureCallback<TrackGroupArray>() { @Override public void onSuccess(TrackGroupArray trackGroups) { handleMetadata(trackGroups); } @Override public void onFailure(Throwable t) { handleFailure(t); } }, executor);
動態相片
此外,您也可以擷取動態相片的中繼資料,其中包含圖片和影片偏移及長度等。支援的格式包括:
- Google Pixel 和 Samsung 相機應用程式錄製的 JPEG 動態相片。此格式可以由 ExoPlayer 播放,因此您可以使用播放器或
MetadataRetriever
擷取相關聯的中繼資料。 - Google Pixel 和 Samsung 相機應用程式錄製的 HEIC 動態相片。ExoPlayer 目前無法播放這種格式,因此請使用
MetadataRetriever
擷取相關的中繼資料。
針對動態相片,使用 MetadataRetriever
取得的 TrackGroupArray
包含 TrackGroup
,其中包含一個 Format
涵蓋一個 MotionPhotoMetadata
中繼資料項目。
Kotlin
0.until(trackGroups.length) .asSequence() .mapNotNull { trackGroups[it].getFormat(0).metadata } .filter { metadata -> metadata.length() == 1 } .map { metadata -> metadata[0] } .filterIsInstance<MotionPhotoMetadata>() .forEach(::handleMotionPhotoMetadata)
Java
for (int i = 0; i < trackGroups.length; i++) { TrackGroup trackGroup = trackGroups.get(i); Metadata metadata = trackGroup.getFormat(0).metadata; if (metadata != null && metadata.length() == 1) { Metadata.Entry metadataEntry = metadata.get(0); if (metadataEntry instanceof MotionPhotoMetadata) { MotionPhotoMetadata motionPhotoMetadata = (MotionPhotoMetadata) metadataEntry; handleMotionPhotoMetadata(motionPhotoMetadata); } } }