ExoPlayer mendukung format gambar berikut. Lihat Library Pemuatan Gambar untuk mengetahui cara berintegrasi dengan library eksternal yang dapat memberikan dukungan untuk kumpulan format yang berbeda.
Format gambar | Didukung | Catatan |
---|---|---|
BMP | YA | |
GIF | TIDAK | Tidak ada dukungan Pengekstrak |
JPEG | YA | |
Foto Gerakan JPEG | YA | Gambar diam dan video didukung |
JPEG Ultra HDR | YA | Kembali ke SDR sebelum Android 14 atau di layar non-HDR |
PNG | YA | |
WebP | YA | |
HEIF/HEIC | YA | |
Foto Motion HEIC | Sebagian | Hanya gambar diam yang didukung* |
AVIF (dasar pengukuran) | YA | Hanya didekode di Android 14+ |
* Bagian video dari foto gerakan HEIC dapat diperoleh dengan MetadataRetriever dan diputar sebagai file mandiri.
Menggunakan MediaItem
Untuk memutar gambar sebagai bagian dari playlist, buat MediaItem
dengan URI gambar
dan teruskan ke pemutar. MediaItem
harus memiliki imageDurationMs
untuk
menentukan durasi gambar yang akan ditampilkan.
Kotlin
// Create a player instance. val player = ExoPlayer.Builder(context).build() // Set the media item to be played with the desired duration. player.setMediaItem( MediaItem.Builder().setUri(imageUri).setImageDurationMs(2000).build()) // Prepare the player. player.prepare()
Java
// Create a player instance. ExoPlayer player = new ExoPlayer.Builder(context).build(); // Set the media item to be played with the desired duration. player.setMediaItem( new MediaItem.Builder().setUri(imageUri).setImageDurationMs(2000).build()); // Prepare the player. player.prepare();
Foto Motion
Foto motion adalah file yang menggabungkan gambar diam dengan video singkat.
- Jika durasi gambar ditentukan dengan
setImageDuration
, foto gerakan akan ditampilkan selama durasi yang dideklarasikan sebagai gambar diam. - Jika durasi gambar tidak ditentukan, foto motion akan diputar sebagai video.
Menggunakan ProgressiveMediaSource
Untuk opsi penyesuaian lainnya, Anda dapat membuat ProgressiveMediaSource
dan
meneruskannya langsung ke pemutar, bukan MediaItem
.
Kotlin
// Create a data source factory. val dataSourceFactory = DefaultHttpDataSource.Factory() // Create a media item with the image URI and the desired duration. val mediaItem = MediaItem.Builder().setUri(imageUri).setImageDurationMs(2000).build() // Create a progressive media source for this media item. val mediaSource = ProgressiveMediaSource.Factory(dataSourceFactory) .createMediaSource(mediaItem) // Create a player instance. val player = ExoPlayer.Builder(context).build() // Set the media source to be played. player.setMediaSource(mediaSource) // Prepare the player. player.prepare()
Java
// Create a data source factory. DataSource.Factory dataSourceFactory = new DefaultHttpDataSource.Factory(); // Create a media item with the image URI and the desired duration. MediaItem mediaItem = new MediaItem.Builder().setUri(imageUri).setImageDurationMs(2000).build(); // Create a progressive media source for this media item. MediaSource mediaSource = new ProgressiveMediaSource.Factory(dataSourceFactory) .createMediaSource(mediaItem); // Create a player instance. ExoPlayer player = new ExoPlayer.Builder(context).build(); // Set the media source to be played. player.setMediaSource(mediaSource); // Prepare the player. player.prepare();
Menyesuaikan pemutaran
ExoPlayer menyediakan beberapa cara bagi Anda untuk menyesuaikan pengalaman pemutaran dengan kebutuhan aplikasi. Lihat Halaman penyesuaian untuk mengetahui contohnya.
Library Pemuatan Gambar
Gambar sering kali dikelola oleh library pemuatan gambar eksternal, misalnya Glide atau Coil.
Mengintegrasikan library ini ke dalam pipeline pemutaran memerlukan 3 langkah:
- Tentukan
MediaItem
dengan jenis MIMEAPPLICATION_EXTERNALLY_LOADED_IMAGE
. - Berikan decoder gambar untuk mengambil
Bitmap
dari library pemuatan gambar. - Menyediakan loader eksternal untuk memicu penyimpanan dalam cache dan pramuat.
MediaItem dengan jenis MIME gambar yang dimuat secara eksternal
MediaItem
yang ditambahkan ke Player
harus menentukan
jenis MIME APPLICATION_EXTERNALLY_LOADED_IMAGE
secara eksplisit untuk menggunakan jalur
kode library pemuatan gambar:
Kotlin
val mediaItem = MediaItem.Builder() .setUri(imageUri) .setMimeType(MimeTypes.APPLICATION_EXTERNALLY_LOADED_IMAGE) .build()
Java
MediaItem mediaItem = new MediaItem.Builder() .setUri(imageUri) .setMimeType(MimeTypes.APPLICATION_EXTERNALLY_LOADED_IMAGE) .build();
Decoder gambar menggunakan library pemuatan gambar
Perender gambar memerlukan ExternallyLoadedImageDecoder
untuk mengambil
Bitmap
dari Uri
. Dekoder ini dapat disediakan dengan mengganti
DefaultRenderersFactory.getImageDecoderFactory
.
Contoh berikut menggunakan Glide untuk memuat gambar:
Kotlin
val glideImageDecoderFactory: ImageDecoder.Factory = ExternallyLoadedImageDecoder.Factory { request: ExternalImageRequest -> GlideFutures.submit(Glide.with(context).asBitmap().load(request.uri)) } val player: Player = ExoPlayer.Builder(context) .setRenderersFactory( object : DefaultRenderersFactory(context) { override fun getImageDecoderFactory(): ImageDecoder.Factory { return glideImageDecoderFactory } } ) .build()
Java
ImageDecoder.Factory glideImageDecoderFactory = new ExternallyLoadedImageDecoder.Factory( request -> GlideFutures.submit( Glide.with(context).asBitmap().load(request.uri))); Player player = new ExoPlayer.Builder(context) .setRenderersFactory( new DefaultRenderersFactory(context) { @Override protected ImageDecoder.Factory getImageDecoderFactory() { return glideImageDecoderFactory; } }) .build();
Pemuatan awal gambar dengan library pemuatan gambar
Selama pemutaran, pemutar meminta untuk memuat gambar berikutnya secara preload setelah item
sebelumnya dalam playlist dimuat sepenuhnya. Saat menggunakan library pemuatan gambar
eksternal, Anda harus menentukan ExternalLoader
untuk memicu pramuat ini. Jika tidak
memungkinkan atau diperlukan pemuatan awal, loader ini masih perlu disediakan, tetapi
tidak dapat melakukan apa pun.
Contoh berikut menggunakan Glide untuk memastikan bahwa gambar yang diminta dimuat sebelumnya ke disk:
Kotlin
val glidePreloader = ExternalLoader { request: LoadRequest -> GlideFutures.submit( Glide.with(context) .asFile() .apply( RequestOptions.diskCacheStrategyOf(DiskCacheStrategy.DATA) .priority(Priority.HIGH) .skipMemoryCache(true) ) .load(request.uri) ) }
Java
ExternalLoader glidePreloader = request -> GlideFutures.submit( Glide.with(context) .asFile() .apply( diskCacheStrategyOf(DiskCacheStrategy.DATA) .priority(Priority.HIGH) .skipMemoryCache(true)) .load(request.uri));