applications_app_samples/code/SystemFeature/Media/AVSession/MediaController
zwx1126739 f979134bd1 添加runtimeOS修复编译报错
Signed-off-by: zwx1126739 <zhanghong121@huawei.com>
2024-07-08 11:59:09 +08:00
..
AppScope MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00
entry MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00
hvigor MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00
screenshots/device MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00
build-profile.json5 添加runtimeOS修复编译报错 2024-07-08 11:59:09 +08:00
hvigorfile.ts MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00
hvigorw MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00
hvigorw.bat MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00
oh-package.json5 MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00
ohosTest.md MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00
README.md MediaController迁移, BasicFeature -> SystemFeature 2024-04-25 10:33:29 +08:00

媒体会话——控制方(仅对系统应用开放)

介绍

本示例主要展示了媒体会话(媒体控制方)的相关功能,使用@ohos.multimedia.avsession等接口实现媒体提供方与媒体控制方自定义信息的交互功能。

注意: 此示例中媒体控制方所使用的能力仅对系统应用开放,更多信息请参见约束与限制。 此示例仅展示媒体控制方的相关功能,如果需要媒体会话提供的完整的自定义信息交互功能,请将本示例与媒体提供方示例共同使用。

效果预览

主页 显示歌词信息 显示播放列表信息
Index Index Index

使用说明(需与媒体提供方一起使用)

  1. 打开媒体控制方示例应用,可以看到音乐应用的历史记录。
  2. 点击播放按钮,应用的播放状态发生变化。
  3. 点击暂停按钮,应用的播放状态开始变化。
  4. 点击上一首按钮,界面展示播放列表中的上一首歌曲的信息。
  5. 点击下一首按钮,界面展示播放列表中的下一首歌曲的信息。
  6. 点击歌词按钮,界面中出现歌词。
  7. 点击播放列表按钮,界面中出现播放列表。
  8. 点击播放列表中的歌曲,媒体提供方切换到对应的歌曲。

工程目录

给出项目中关键的目录结构并描述它们的作用,示例如下:

entry/src/main/ets/
|---common
|---|---Log.ets                             //日志打印封装
|---feature
|---|---MediaController.ets                 //逻辑实现
|---pages
|---|---PresentPage.ets                    //界面实现

具体实现

  • 界面相关的实现都封装在pages/Index.ets下源码参考pages/Index.ets

    • 使用@StorageLink来设置与逻辑代码同步更新的变量,当逻辑代码中对应的变量更新时,界面会同步的刷新。

    • 通过引入逻辑代码对应的类创建出对象实现对onClick事件的响应关键代码段

      import control from '../feature/MediaController';
      
      controller = new control(); // 创建对象
      
      await this.controller.startControl(); // 通过类的对象来调用逻辑代码
      
  • 逻辑相关的实现都封装在feature/MediaController.ets下源码参考feature/MediaController.ets

    应用的初始化相关操作

    • 链接变量

      通过AppStorage.SetAndLink()将逻辑代码中的变量与界面代码中使用@StorageLink声明的变量连接起来,通过set()get()操作来修改或获取变量的值,关键代码段:

      private isPlayingLink = undefined;
      this.isPlayingLink = AppStorage.SetAndLink('isPlaying', undefined);
      this.isPlayingLink.set(false); // 设置变量的值
      let currentState : boolean = this.isPlayingLink.get(); // 获取变量的值
      
    • 获取当前设备中会话并创建Controller

      通过接口getAllSessionDescriptors()获取当前设备中的媒体会话;

      通过接口createController()创建媒体会话对应的控制器;

      通过接口getHistoricalSessionDescriptors()获取当前设备中的媒体会话历史记录;

      通过接口on(metadataChange | playbackStateChange | queueItemsChange | queueTitleChange | sessionEvent)开启对媒体提供方发送事件的监听,对媒体提供方的事件进行处理;

    应用在运行中相关的操作

    • 发送基础控制命令到媒体提供方

      基础控制命令可以通过接口sendControlCommand()发送。本示例中,从媒体控制方到媒体提供方的基础控制命令主要包括play, pause, playPrevious, playNext。发送命令的参考代码如下:

      let command : AVSessionManager.AVControlCommand = {
        command : 'play',
        parameter : undefined
      } // 构造AVControlCommand参数
      await controller.sendControlCommand(command); // 媒体会话控制器与媒体会话一一对应通过sendControlCommand发送命令
      
    • 获取自定义会话数据(以获取歌词为例)

      说明:

      本示例中,媒体会话控制方会发送给媒体会话提供方一个“打开歌词”的命令,媒体会话提供方接收到命令后,会在歌词信息更新时发送歌词给媒体会话控制方。

      媒体控制方可以使用接口sendCommonCommand()发送自定义控制命令,示例代码如下:

      let paramStruct = {'lyrics' : this.isLyric};
      await controller.sendCommonCommand('lyrics', paramStruct);
      

      当媒体会话提供方接收到命令后,会通过接口dispatchSessionEvent()与接口setExtras()将歌词信息发送给媒体会话控制方。此部分请参见媒体会话提供方Sample

    • 获取当前会话信息

      通过接口getAVQueueItems()获取当前歌曲列表信息;

      通过接口getAVQueueTitle()获取当前歌曲列表名称信息;

      通过接口getAVPlaybackState()获取当前歌曲播放状态信息;

      通过接口getAVMetadata()获取当前歌曲媒体会话元数据信息;

相关权限

系统应用权限

因为媒体控制方相关接口仅对系统应用开放,开发媒体控制方应用前需要确认是否是系统应用。

网络权限(可选)

如果需要展示媒体提供方提供的网络资源例如Url形式的图片需要获取网络权限ohos.permission.INTERNET

请在需要获取网络权限的Ability的module.json5中添加以下配置:

{
  "module": {
      "requestPermissions": [
        {
          "name": "ohos.permission.INTERNET"
        }
      ]
  }
}

Bundle相关权限可选

如果需要通过媒体提供方的包名来获取媒体提供方的应用名与应用图标需要申请Bundle权限ohos.permission.GET_BUNDLE_INFO_PRIVILEGED

请在需要获取Bundle信息权限的Ability的module.json5中添加以下配置:

{
  "module": {
      "requestPermissions": [
        {
          "name": "ohos.permission.GET_BUNDLE_INFO_PRIVILEGED"
        }
      ]
  }
}

依赖

此示例仅展示媒体控制方的相关功能,如果需要媒体会话提供的完整的自定义信息交互功能,请将本示例与媒体提供方示例共同使用。

约束与限制

  1. 本示例仅支持标准系统上运行支持设备RK3568。

  2. 本示例为Stage模型支持API10版本SDKSDK版本号(API Version 10 Release),镜像版本号(4.0 Release)

  3. 本示例需要使用DevEco Studio 版本号(4.0 Release)及以上版本才可编译运行。

  4. 本示例涉及系统接口,需要配置系统应用签名,可以参考特殊权限配置方法 把配置文件中的“app-feature”字段信息改为“hos_system_app”。

下载

如需单独下载本工程,执行如下命令:

git init
git config core.sparsecheckout true
echo code/SystemFeature/Media/AVSession/MediaController > .git/info/sparse-checkout
git remote add origin https://gitee.com/openharmony/applications_app_samples.git
git pull origin master