采用以下容器格式的视频流可以直接由 ExoPlayer 播放。还必须支持所包含的音频和视频示例格式(如需了解详情,请参阅示例格式部分)。
容器格式 | 支持 | 评论 |
---|---|---|
MP4 | 是 | |
M4A | 是 | |
FMP4 | 是 | |
WebM | 是 | |
马特罗斯卡 | 是 | |
MP3 | 是 | 有些视频流只能使用恒定比特率搜寻** |
奥格 | 是 | 包含 Vorbis、Opus 和 FLAC |
WAV | 是 | |
MPEG-TS | 是 | |
MPEG-PS | 是 | |
FLV | 是 | 不可查找* |
ADTS (AAC) | 是 | 只能使用恒定比特率搜寻** |
FLAC | 是 | 使用 ExoPlayer 库中的 FLAC 库或 FLAC 提取器*** |
AMR | 是 | 只能使用恒定比特率搜寻** |
JPEG 动态照片 | 是 | 只会提取 MP4 内容 |
* 系统不支持跳转,因为容器不提供元数据(例如样本索引)来支持媒体播放器高效执行跳转操作。 如果需要跳转,我们建议使用更合适的容器格式。
** 这些提取器具有 FLAG_ENABLE_CONSTANT_BITRATE_SEEKING
标记,用于根据恒定比特率假设启用近似搜寻。默认情况下,此功能未启用。要为支持此功能的所有提取器启用此功能,最简单的方法是使用 DefaultExtractorsFactory.setConstantBitrateSeekingEnabled
,如此处所述。
*** FLAC 库提取器输出原始音频,框架可以在所有 API 级别上处理这些音频。ExoPlayer 库 FLAC 提取器输出 FLAC 音频帧,因此依赖于 FLAC 解码器(例如,处理 FLAC 的 MediaCodec
解码器(API 级别 27 要求)或启用了 FLAC 的 FFmpeg 库。如果应用是使用 FLAC 库构建的,则 DefaultExtractorsFactory
会使用扩展提取器。否则,它会使用 ExoPlayer 库提取器。
使用 MediaItem
如需播放渐进式流,请使用媒体 URI 创建 MediaItem
并将其传递给播放器。
Kotlin
// Create a player instance. val player = ExoPlayer.Builder(context).build() // Set the media item to be played. player.setMediaItem(MediaItem.fromUri(progressiveUri)) // Prepare the player. player.prepare()
Java
// Create a player instance. ExoPlayer player = new ExoPlayer.Builder(context).build(); // Set the media item to be played. player.setMediaItem(MediaItem.fromUri(progressiveUri)); // Prepare the player. player.prepare();
使用 ProgressiveMediaSource
如需使用更多自定义选项,您可以创建 ProgressiveMediaSource
并直接发送到播放器,而不是 MediaItem
。
Kotlin
// Create a data source factory. val dataSourceFactory: DataSource.Factory = DefaultHttpDataSource.Factory() // Create a progressive media source pointing to a stream uri. val mediaSource: MediaSource = ProgressiveMediaSource.Factory(dataSourceFactory) .createMediaSource(MediaItem.fromUri(progressiveUri)) // 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 progressive media source pointing to a stream uri. MediaSource mediaSource = new ProgressiveMediaSource.Factory(dataSourceFactory) .createMediaSource(MediaItem.fromUri(progressiveUri)); // 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();
自定义播放
ExoPlayer 为您提供了多种方式来根据应用的需求定制播放体验。如需查看相关示例,请参阅“自定义”页面。