当前位置: 首页 > news >正文

Compose - 使用 Media3(ExoPlayer)

View版及更多功能使用:详见

一、概念

1.1 实现方式选择

media3-ui-composemedia3-ui-compose-material3
界面组件基础组件。开箱即用,含预设样式的按钮或控件。
状态管理提供 remember***State 状态持有者来管理逻辑。在内部管理状态,但仍可根据需要访问状态容器。
使用场景使用自定义风格构建播放器界面。使用 Material3 预设快速构建。

1.2 显示组件

ContentFrame

@Composable
fun ContentFrame(
player: Player?,
modifier: Modifier = Modifier,
surfaceType: @SurfaceType Int = SURFACE_TYPE_SURFACE_VIEW,
contentScale: ContentScale = ContentScale.Fit,
keepContentOnReset: Boolean = false,
shutter: @Composable () -> Unit = { Box(Modifier.fillMaxSize().background(Color.Black)) },
)

参数 contentScale:视频缩放。

参数 keepContentOnReset:为 true 播放器重置时将保持最后一帧画面显示,为 false 则会清空渲染表面。

参数 shutter:用于在需要覆盖视频渲染表面时显示。默认情况下,它显示为黑色背景。

1.3 控制组件

组件中可以直接拿到对应状态里的属性/方法(推荐通过this调用方便阅读)。

通用组件PlayPauseButton播放和暂停。
SeekBackButton根据预设值,向前调整播放进度。
SeekForwardButton根据预设值,向后调整播放进度。
NextButton跳转到下一个媒体项。
PreviousButton跳转到上一个媒体项。
RepeatButton切换重复模式。
ShuffleButton切换随机模式。
MuteButton切换静音模式。
TimeText显示时长相关文本。
Material3PositionAndDurationText当前位置和总时长的文本。
PositionText当前位置的文本。
DurationText总时长的文本。
RemainingDurationText剩余时长的文本。

自定义方式:

PlayPauseButton(player) { Icon( modifier = Modifier .size(20.dp) .clickable( enabled = this.isEnabled, onClick = { this.onClick() } ), imageVector = if (this.showPlay) Icons.Default.PlayArrow else Icons.Default.PauseCircle, contentDescription = if (this.showPlay) "Play" else "Pause" ) }

Material3 方式:

Row { SeekBackButton(player) PlayPauseButton(player) SeekForwardButton(player) }

1.4 状态(自定义控制组件)

如果上面没有需要的组件,可以自行通过状态来构建自定义组件。

状态获取方式
播放暂停rememberPlayPauseButtonState
上一项rememberPreviousButtonState
下一项rememberNextButtonState
重复模式rememberRepeatButtonState
随机模式rememberShuffleButtonState
播放速度rememberPlaybackSpeedState
val state = rememberPlayPauseButtonState(player) Icon( modifier = Modifier .size(20.dp) .clickable( enabled = state.isEnabled, onClick = { state.onClick() } ), imageVector = if (state.showPlay) Icons.Default.PlayArrow else Icons.Default.PauseCircle, contentDescription = if (state.showPlay) "Play" else "Pause" )

二、添加依赖

最新版本

[versions] media3 = "1.9.0" [libraries] media3-exoplayer = { module = "androidx.media3:media3-exoplayer", version.ref = "media3" } media3-datasource-okhttp = { module = "androidx.media3:media3-datasource-okhttp", version.ref = "media3" } #二选一 media3-ui-compose = { module = "androidx.media3:media3-ui-compose", version.ref = "media3" } media3-ui-compose-material3 = { moudle = "androidx.media3:media3-ui-compose-material3", version.ref = "media3" }

三、实现方式

3.1 ViewModel

在 ViewModel 中提供 ExoPlayer,将业务和UI分离。

class PlayerVM : ViewModel() { private val playlist = mutableListOf<MediaItem>() private val playerListener by lazy { object : Player.Listener { } } val player by lazy { ExoPlayer.Builder(APP.context) .setSeekBackIncrementMs(10000) .setSeekForwardIncrementMs(10000) .build() .apply { addListener(playerListener) setMediaItem(MediaItem.fromUri("https://www.w3schools.com/html/movie.mp4")) prepare() playWhenReady = true } } override fun onCleared() { super.onCleared() player.release() } }

3.2 UI

@Composable private fun Demo( viewModel: PlayerVM = viewModel() ) { ContentFrame(viewModel.player) }
http://www.cnnetsun.cn/news/163639.html

相关文章:

  • 零基础也能做数字人?Linly-Talker全栈技术详解
  • 海外代理IP购买选哪家?海外动态住宅代理服务器供应商
  • Linly-Talker百度飞桨PaddlePaddle兼容性验证完成
  • PredictorsGPT:一个非预测系统的工程设计取舍与伦理边界
  • 如何避免 MySQL 死锁?——从原理到实战的系统性解决方案
  • Linly-Talker开发者激励计划上线:提交插件赢取奖励
  • 专业固液混合电容怎么选?这份指南告诉你哪个好
  • Linly-Talker驱动的AI心理陪伴机器人设想
  • Langchain-Chatchat能否支持文档加密上传解密?
  • 跨平台兼容性测试:Linly-Talker在Windows/Linux表现一致
  • Linly-Talker背后的技术栈:Transformer+Diffusion组合应用
  • Langchain-Chatchat OpenTelemetry统一观测知识平台
  • Linly-Talker支持多语言吗?中文语音合成表现实测
  • 25、Windows 容器与服务器维护全解析
  • Langchain-Chatchat新人培训知识问答系统
  • Langchain-Chatchat Consul服务发现知识库
  • 24、Linux系统管理与维护全攻略
  • 18、管理和维护运行Windows Vista的系统及网络配置与故障排除
  • Langchain-Chatchat性能监控指标知识库
  • Langchain-Chatchat可用性管理知识问答系统
  • Gateway 对比 Kong(二)
  • 7、跨平台办公软件与文件处理全解析
  • Langchain-Chatchat IFRS9准则应用知识查询平台
  • 搜维尔科技:隆重推出DEX-EE灵巧手,市场上最坚固、最灵巧的机器人手
  • 9大高级RAG技术详解:提升大模型检索效果的实战指南
  • Langchain-Chatchat移动设备安全管理知识库
  • Langchain-Chatchat JWT令牌机制知识库构建
  • Langchain-Chatchat文件共享权限管理问答系统
  • Langchain-Chatchat IOC指标查询问答工具
  • Langchain-Chatchat渗透测试报告生成辅助工具