news 2026/5/20 9:07:46

音频流转实战:如何让手机正在播放的音乐,自动流转到鸿蒙智能音箱上?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
音频流转实战:如何让手机正在播放的音乐,自动流转到鸿蒙智能音箱上?

🔊 前言:为什么不直接用蓝牙?

维度蓝牙 (Bluetooth A2DP)鸿蒙流转 (Distributed Audio)
传输介质蓝牙 (带宽低,易受干扰)Wi-Fi / 软总线 (高带宽,无损音质)
手机状态必须做解码和传输,耗电仅做控制,省电
多设备控制一对一连接全屋设备组网,随意切换
延迟100ms - 300ms< 40ms (唇音同步)

🏗️ 一、 架构原理:AVSession 是指挥官

要实现流转,你的 App 必须接入AVSession (音视频会话)
系统通过 AVSession 知道你的 App 正在放什么歌、进度是多少。当用户点击“流转”或手机靠近音箱时,系统接管 AVSession,将其“投影”到远端设备。

流转原理图 (Mermaid):

1. 创建会话
2. 报告状态: 正在播放 <十年> 01:23
3. 点击流转 / 碰一碰
4. 发现设备
5. 建立投射连接
6. 传输音频流/播放指令

手机 App (网易云/QQ音乐)

AVSession (系统服务)

系统播控中心

用户动作

分布式软总线

智能音箱 (接收端)


🛠️ 二、 实战步骤:从发现到连接

在 HarmonyOS Next 中,流转主要依赖AVCastControllerAudioRoutingManager。这里我们演示最通用的AVSession 投射模式

1. 基础准备:创建 AVSession

这是所有播放类 App 的起手式。不写这个,系统根本不知道你在放歌。

import{avSession}from'@kit.AVSessionKit';letsession:avSession.AVSession;asyncfunctioninitSession(context:Context){// 1. 创建会话,类型为音频 (AUDIO)session=awaitavSession.createAVSession(context,'MyMusicApp','audio');// 2. 激活会话awaitsession.activate();// 3. 设置元数据 (歌名、歌手、封面)// 这一步很重要,流转到音箱后,如果音箱有屏幕,会显示这些信息letmetadata:avSession.AVMetadata={assetId:'123',title:'海阔天空',artist:'Beyond',mediaImage:'https://example.com/cover.jpg'};awaitsession.setAVMetadata(metadata);console.info('AVSession 初始化完成');}
2. 核心逻辑:发现并流转到音箱

我们要调用AVCastController来扫描局域网内的鸿蒙设备(音箱、智慧屏),并指定输出。

import{avSession}from'@kit.AVSessionKit';import{BusinessError}from'@kit.BasicServicesKit';asyncfunctioncastToSpeaker(){if(!session)return;// 1. 获取投射控制器letcastController=awaitsession.getAVCastController();// 2. 监听设备发现 (类似于蓝牙扫描,但是是在 Wi-Fi/软总线上扫)castController.on('castDeviceChange',(state:avSession.AVCastDeviceState,device:avSession.AVCastDeviceInfo)=>{console.info(`发现设备:${device.deviceId}, 状态:${state}`);// 3. 简单的自动流转逻辑:发现是“音箱”,就直接切过去// 实际业务中,应该弹窗让用户选择if(state===avSession.AVCastDeviceState.DEVICE_STATE_CONNECTED){// 设备已连接,准备就绪}});// 4. 发起流转指令// startCast 会触发系统的设备选择弹窗 (AirPlay 风格)// 如果你想自己写 UI,需要使用 getOutputDevices() 手动切换try{// 这里的 'audio' 表示我们只投射音频awaitcastController.startCast('audio');console.info('已拉起系统流转弹窗');}catch(err){leterror=errasBusinessError;console.error(`流转失败:${error.message}`);}}
3. 处理流转后的状态 (同步播放进度)

当流转成功后,音频实际上是从音箱发出的。你的 App 需要监听来自音箱的指令(比如用户对着音箱喊“下一首”)。

// 监听远端指令session.on('play',()=>{// 音箱发来“播放”指令player.play();});session.on('pause',()=>{// 音箱发来“暂停”指令player.pause();});session.on('playNext',()=>{// 音箱发来“下一首”指令playNextSong();});

📡 三、 进阶:如何实现“碰一碰”自动流转?

上面的代码是“手动点击”触发流转。如果要实现华为音乐那种“手机碰一下音箱就流转”,需要结合NFCWant机制。

逻辑极其简单:

  1. NFC 标签写入:在音箱的 NFC 贴纸里写入你的 App 的Ability信息。
  2. 手机读取:手机碰到 NFC,系统读取到 Ability 信息,自动拉起你的 App。
  3. 触发流转
    在 App 的onCreateonNewWant生命周期中,判断启动来源。如果是NFC触发,直接执行上面的castToSpeaker()逻辑,并指定 deviceId(NFC数据里通常包含音箱的 MAC/ID)。
// EntryAbility.tsonNewWant(want:Want,launchParam:AbilityConstant.LaunchParam){// 判断是否由 NFC 碰一碰触发if(want.parameters&&want.parameters['ohos.extra.param.deviceType']==='speaker'){// 获取音箱 IDletspeakerId=want.parameters['deviceId'];// 执行静默流转AudioManager.transferTo(speakerId);}}

🚧 四、 避坑指南

  1. 权限问题:跨设备发现和连接需要ohos.permission.DISTRIBUTED_DATASYNC权限,且这是个 ACL 权限(需要签名证书授权)。
  2. 网络环境:流转的前提是设备必须在同一 Wi-Fi下,或者登录了同一个华为账号(利用超级终端能力)。
  3. 流转模式
  • 本地解码 (Remote Audio):手机下载解码,传 PCM 给音箱。适合实时性要求高的(游戏)。
  • 远端解码 (Cast):手机传 URL 给音箱,音箱自己下载。适合听歌,音质最好,手机最省电。
  • AVSession 默认倾向于智能选择模式。

🎯 总结

鸿蒙的音频流转,把**“连接”变成了“服务”**。
通过AVSession,你开发的不是一个孤立的播放器,而是一个可以在全屋设备间自由穿梭的“音乐精灵”。

Next Step:
如果你手里没有华为音箱,可以找两台鸿蒙手机。一台装你的 App,另一台作为“接收端”(在设置里打开“超级终端 -> 允许被发现”)。尝试用你的 App 搜索另一台手机,你会发现它也会出现在设备列表里,点击它,音乐就会神奇地从另一台手机里飘出来!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 11:28:39

HY-MT1.5-7B部署成本分析:相比商用方案节省70%费用实战

HY-MT1.5-7B部署成本分析&#xff1a;相比商用方案节省70%费用实战 1. 引言&#xff1a;开源翻译模型的降本增效新路径 随着全球化业务的加速推进&#xff0c;高质量、低延迟的机器翻译能力已成为企业出海、内容本地化和跨语言服务的核心基础设施。然而&#xff0c;依赖商业翻…

作者头像 李华
网站建设 2026/5/10 10:17:52

10.1 高性能磁轴承设计:高速高负载轴承、低损耗多极独立控制、高温磁轴承等前沿设计挑战

10.1 高性能磁轴承设计:高速高负载轴承、低损耗多极独立控制、高温磁轴承等前沿设计挑战 随着“双碳”战略的深入实施及高端装备向极致性能迈进,磁悬浮轴承技术的应用边界正被不断拓展。传统设计已难以满足先进工业装备对超高转速、极大负载、极致能效及在极端环境下稳定运行…

作者头像 李华
网站建设 2026/5/12 0:28:31

Qwen3-VL图像分析实战:云端GPU10分钟出结果,3块钱玩转

Qwen3-VL图像分析实战&#xff1a;云端GPU10分钟出结果&#xff0c;3块钱玩转 1. 为什么设计师需要云端GPU跑Qwen3-VL&#xff1f; 作为设计师&#xff0c;当你需要测试AI模型的图片描述生成能力时&#xff0c;本地RTX3060显卡&#xff08;通常只有12GB显存&#xff09;面对Q…

作者头像 李华
网站建设 2026/5/15 15:28:19

腾讯翻译大模型教程:多语言聊天机器人开发

腾讯翻译大模型教程&#xff1a;多语言聊天机器人开发 随着全球化进程加速&#xff0c;跨语言交流需求激增。传统翻译服务在实时性、多语言支持和上下文理解方面存在明显短板&#xff0c;尤其在构建多语言聊天机器人时&#xff0c;面临延迟高、语义断裂、方言识别弱等挑战。腾…

作者头像 李华
网站建设 2026/5/11 2:51:57

实时翻译系统搭建:HY-MT1.5-1.8B边缘部署案例

实时翻译系统搭建&#xff1a;HY-MT1.5-1.8B边缘部署案例 随着多语言交流需求的不断增长&#xff0c;实时、高质量的翻译系统成为智能设备、跨语言服务和全球化应用的核心组件。传统云端翻译方案虽性能强大&#xff0c;但存在延迟高、隐私泄露风险和依赖网络等局限。为此&…

作者头像 李华
网站建设 2026/5/7 15:13:22

AI智能实体侦测服务SLA保障:服务稳定性优化部署方案

AI智能实体侦测服务SLA保障&#xff1a;服务稳定性优化部署方案 1. 引言&#xff1a;AI 智能实体侦测服务的业务价值与挑战 随着非结构化文本数据在新闻、政务、金融等领域的爆炸式增长&#xff0c;如何高效提取关键信息成为智能化处理的核心需求。AI 智能实体侦测服务&#…

作者头像 李华