鸿蒙分布式投屏

鸿蒙AVSession Kit------ ArkTS 与 C/C++ 双语言、Provider 与 Controller 全角 - 掘金

适用:API 12+ / ArkTS & C++ / 手机→智慧屏、耳机、车机等任意分布式设备


一、投播全景图

flowchart LR A["手机播放器"] -->|"AVSession\nsetAVMetadata/State"| M["本地会话"] M -->|"AVCastPicker.show()"| P["投播面板"] P -->|"用户选择设备"| D["远端设备\n智慧屏/耳机/车机"] D -->|"AVSessionController"| R["远端播放器"] M -.->|"投播生命周期事件"| A

二、核心概念 1 张表

概念 作用 备注 AVCastPicker 系统 UI,列出可投设备 一行代码唤起 AVCastController 跨设备会话控制器 与本地 AVSessionController 同族 CastState 枚举:IDLE / CONNECTING / CONNECTED / DISCONNECTING 监听投播链路状态 CastPlayback 投播过程中的播放状态 仍通过本地 AVSession 同步


三、ArkTS 最小落地(4 步 8 行)

  1. 准备本地会话(与本地播放完全一致)
ts 复制代码
const session = await avSession.createAVSession(getContext(), 'MusicCast', 'audio');
await session.setAVMetadata({...});
await session.setAVPlaybackState({...});
await session.activate();
  1. 唤起投播面板
ts 复制代码
import { avCast } from '@kit.AVSessionKit';
const picker = new avCast.AVCastPicker();
picker.show(session.sessionId);          // ① 一行弹出设备列表
  1. 监听投播状态
ts 复制代码
session.on('castStateChange', (state: avCast.CastState) => {
  console.info('投播状态', state);       // ② 连接/断开/失败
});
  1. 远端控制
ts 复制代码
const castCtrl = await session.createCastController(); // ③ 拿到跨设备控制器
await castCtrl.sendControlCommand({ command: 'pause' });

四、C/C++ NDK 最小落地

cpp 复制代码
// 1. 创建本地会话
OH_AVSession* session;
OH_AVSession_Create("CastDemo", SESSION_TYPE_AUDIO,
                    "com.demo", "MainAbility", &session);

// 2. 唤起投播面板
OH_AVCastPicker_Show(session);

// 3. 监听状态
OH_AVSession_RegisterCastStateCallback(session,
  [](OH_AVSession*, CastState state, void*){ /* 处理 */ }, nullptr);

// 4. 远端控制
OH_AVCastController* castCtrl;
OH_AVCastController_Create(session, &castCtrl);
OH_AVControllerCommand cmd = { .command = COMMAND_PAUSE };
OH_AVCastController_SendCommand(castCtrl, &cmd);

五、投播生命周期事件

事件 触发时机 建议动作 castStateChange 连接/断开/失败 切换 UI(本地 ↔ 远端) castPlaybackStateChange 远端播放状态变化 同步进度条 castOutputDeviceChange 可用设备列表变化 刷新投播面板

注册示例(ArkTS)

ts 复制代码
session.on('castPlaybackStateChange', (state) => updateProgress(state.position));
session.on('castOutputDeviceChange',   (list) => refreshPicker(list));

六、后台投播 checklist

  • 本地会话已激活并设置元数据
  • 申请了 AUDIO_PLAYBACK 长时任务(投播期间仍在后台播放)
  • 监听 castStateChange,在 DISCONNECTED 时切回本地播放器
  • 远端设备断开后主动 release() CastController 避免泄漏

七、一句话总结

"把本地 AVSession 搭好,加一行 AVCastPicker.show(),其余全部复用现有播放逻辑。"

相关推荐
安卓开发者14 小时前
鸿蒙NEXT应用接入快捷栏:一键直达,提升用户体验
java·harmonyos·ux
HMS Core14 小时前
消息推送策略:如何在营销与用户体验间找到最佳平衡点
华为·harmonyos·ux
Brianna Home14 小时前
【案例实战】鸿蒙分布式调度:跨设备协同实战
华为·wpf·harmonyos
Bert丶seven14 小时前
鸿蒙Harmony实战开发教学(No.4)-RichText组件基础到高阶介绍篇
华为·harmonyos·arkts·鸿蒙·鸿蒙系统·arkui·开发教程
鸿蒙小白龙16 小时前
openharmony之分布式蓝牙实现多功能场景设备协同实战
分布式·harmonyos·鸿蒙·鸿蒙系统·open harmony
爱吃水蜜桃的奥特曼16 小时前
玩Android Harmony next版,通过项目了解harmony项目快速搭建开发
android·harmonyos
鸿蒙小白龙17 小时前
openharmony之分布式购物车开发实战
分布式·harmonyos·鸿蒙·鸿蒙系统·open harmony
鸿蒙小白龙17 小时前
openharmony之分布式相机开发:预览\拍照\编辑\同步\删除\分享教程
分布式·harmonyos·鸿蒙·鸿蒙系统·open harmony
安卓开发者20 小时前
鸿蒙NEXT鼠标光标开发完全指南
华为·计算机外设·harmonyos
●VON1 天前
重生之我在大学自学鸿蒙开发第九天-《分布式流转》
学习·华为·云原生·harmonyos·鸿蒙