安卓手机APP开发__媒体开发部分__用户界面定制

安卓手机APP开发__媒体开发部分__用户界面定制

目录

最佳实践

播放/暂停按钮

监听状态的更新

处理可用的指令


Media3提供了一个默认的播放器视图,这个视图提供了一些定制化的选项。

对于任何进一步的定制,APP开发者都期望实现他们的自己的用户界面的组件。

最佳实践

当实现的一个媒体用户界面连接到一个媒体3的播放器时,(例如ExoPlayer)

APP被期望遵循如下的最佳实践。

播放/暂停按钮

播放/暂停按钮不直接反馈到一个单独的播放器状态。例如,一个用户应用能够

重启动播放,这是在播放结束或者是播放失败时的情况,甚至是播放器没有暂停的状态下。

为了简化实现,媒体3提供了工具方法来决定显示哪一个按钮,并且处理按钮的响应。

Kotlin

Kotlin 复制代码
val shouldShowPlayButton: Boolean = Util.shouldShowPlayButton(player)
playPauseButton.setImageDrawable(if (shouldShowPlayButton) playDrawable else pauseDrawable)
playPauseButton.setOnClickListener { Util.handlePlayPauseButtonAction(player) }

监听状态的更新

用户界面的组件需要加到一个播放器的监听器中,保证在播放器状态改变时得到播放器的监听器

的通知,这会让用户界面进行更新。

刷新用户界面是有代价的,并且多个播放器事件会一起到来。为了避免刷新用户界面

太频繁了,仅监听onEvents,然后从那触发用户界面的更新比较好:

Kotlin

Kotlin 复制代码
player.addListener(object : Player.Listener{
  override fun onEvents(player: Player, events: Player.Events){
    if (events.containsAny(
        Player.EVENT_PLAY_WHEN_READY_CHANGED,
        Player.EVENT_PLAYBACK_STATE_CHANGED,
        Player.EVENT_PLAYBACK_SUPPRESSION_REASON_CHANGED)) {
      updatePlayPauseButton()
    }
    if (events.containsAny(Player.EVENT_REPEAT_MODE_CHANGED)) {
      updateRepeatModeButton()
    }
  }
})

处理可用的指令

一个通用的目的的用户界面的组件,可能需要和不同的播放器的实现一起工作。

应该检查可用的播放器的指令,来显示或者隐藏按钮,来避免调用了不支持的方法:

Kotlin

Kotlin 复制代码
nextButton.isEnabled = player.isCommandAvailable(Player.COMMAND_SEEK_TO_NEXT)
相关推荐
臻一8 小时前
rk3576+安卓14---uboot
android
2501_944521598 小时前
Flutter for OpenHarmony 微动漫App实战:主题配置实现
android·开发语言·前端·javascript·flutter·ecmascript
2501_944521599 小时前
Flutter for OpenHarmony 微动漫App实战:动漫卡片组件实现
android·开发语言·javascript·flutter·ecmascript
知1而N9 小时前
电脑上运行APK文件(Android应用程序包),需要借助特定的软件或功能,因为Windows/macOS/Linux系统无法原生直接运行安卓应用
android·macos·电脑
代码s贝多芬的音符10 小时前
HttpURLConnection post多个参数和一个图片
android·httpurlconn
草莓熊Lotso10 小时前
Qt 控件美化与交互进阶:透明度、光标、字体与 QSS 实战
android·java·开发语言·c++·人工智能·git·qt
氦客11 小时前
Android Compose : 解决列表滑动导致BottomSheet异常消失的问题
android·compose·滑动·lazygrid·bottomsheet·lazycolumn·异常消失
代码s贝多芬的音符11 小时前
android 相机人脸检测 人脸识别 画人脸边框 识别成功保存图片 mlkit 机器学习
android·数码相机·机器学习
晚霞的不甘11 小时前
Flutter for OpenHarmony 布局核心:Row 与 Column 深度解析与实战
android·前端·javascript·flutter
ll_god12 小时前
android compose ui 结合 ViewModel适配方案
android·ui