以下容器格式的流可由 ExoPlayer 直接播放。所含的音频和视频样本格式也必须受支持(有关详情,请参阅样本格式部分)。有关图像容器和格式支持,请参阅图像。
容器格式 | 支持 | 备注 |
---|---|---|
MP4 | 是 | |
M4A | 是 | |
FMP4 | 是 | |
WebM | 是 | |
Matroska | 是 | |
MP3 | 是 | 某些流仅支持使用恒定比特率寻道** |
Ogg | 是 | 包含 Vorbis、Opus 和 FLAC |
WAV | 是 | |
MPEG-TS | 是 | |
MPEG-PS | 是 | |
FLV | 是 | 不可寻道* |
ADTS (AAC) | 是 | 仅支持使用恒定比特率寻道** |
FLAC | 是 | 使用FLAC 库或ExoPlayer 库中的 FLAC 提取器*** |
AMR | 是 | 仅支持使用恒定比特率寻道** |
*不支持寻道,因为容器未提供元数据(例如样本索引),以允许媒体播放器高效地执行寻道。如果需要寻道,我们建议使用更合适的容器格式。
**这些提取器具有 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 提供了多种方式来根据您的应用需求自定义播放体验。有关示例,请参阅自定义页面。