博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
AVS 端能力之蓝牙模块
阅读量:7111 次
发布时间:2019-06-28

本文共 5648 字,大约阅读时间需要 18 分钟。

该类为蓝牙端能力处理类,主要负责蓝牙设备配对和蓝牙音频播放功能。

功能简介

  • 实现蓝牙设备的启动发现模式、扫描蓝牙设备、建立蓝牙连接功能
  • 实现蓝牙设备音频播放、停止、上一首、下一首功能
  • 其它细节参考《AVS 端能力模块》

UML 图集

  • 完整类图

    1497698-20181112145447021-2128359170.png

  • 精简类图

    1497698-20181112145505430-498778571.png

  • 对象调用

    1497698-20181112145542353-1027757984.png

调用流程

// 创建对象并更新上下文Bluetooth:createBluetooth:initBlueZDeviceManager:getDiscoveredDevicesBluetooth:executeUpdateContext:buffer={"alexaDevice"\:{"friendlyName"\:"sprite-moon"}\,"pairedDevices"\:[]}Bluetooth:getConfiguration// 注册蓝牙指令处理DirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=Previous,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=Play,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=DisconnectDevice,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=Next,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=ConnectByProfile,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=EnterDiscoverableMode,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=PairDevice,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=ScanDevices,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=ExitDiscoverableMode,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=UnpairDevice,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=Stop,handler=0x55a9c2a48000,policy=NON_BLOCKINGDirectiveRouter:addDirectiveHandlers:action=added,namespace=Bluetooth,name=ConnectByDeviceId,handler=0x55a9c2a48000,policy=NON_BLOCKING############################       Thinking...       ############################// 接收到ConnectByProfile指令并执行预处理DirectiveSequencer:onDirective:directive={"directive"\:{"header"\:{"namespace"\:"Bluetooth"\,"name"\:"ConnectByProfile"\,"messageId"\:"90326566-00c6-436b-93ef-a9d7e0bf8558"\,"dialogRequestId"\:"5a6fa9c6-bdbb-4097-9d6a-d9e8ad5d5434"}\,"payload"\:{"profile"\:{"name"\:"A2DP-SOURCE"}}}}DirectiveRouter:preHandleDirective:messageId=90326566-00c6-436b-93ef-a9d7e0bf8558,action=callingCapabilityAgent:addingMessageIdToMap:messageId=90326566-00c6-436b-93ef-a9d7e0bf8558Bluetooth:preHandleDirective// 接收到EnterDiscoverableMode指令并执行预处理DirectiveSequencer:onDirective:directive={"directive"\:{"header"\:{"namespace"\:"Bluetooth"\,"name"\:"EnterDiscoverableMode"\,"messageId"\:"2836b54f-8e68-4147-86a4-8056d98cc7fe"\,"dialogRequestId"\:"5a6fa9c6-bdbb-4097-9d6a-d9e8ad5d5434"}\,"payload"\:{}}}DirectiveRouter:preHandleDirective:messageId=2836b54f-8e68-4147-86a4-8056d98cc7fe,action=callingCapabilityAgent:addingMessageIdToMap:messageId=2836b54f-8e68-4147-86a4-8056d98cc7feBluetooth:preHandleDirective############################       Speaking...       ############################// 处理ConnectByProfile指令DirectiveRouter:handleDirective:messageId=90326566-00c6-436b-93ef-a9d7e0bf8558,action=callingBluetooth:handleDirective// 处理EnterDiscoverableMode指令DirectiveRouter:handleDirective:messageId=2836b54f-8e68-4147-86a4-8056d98cc7fe,action=callingBluetooth:handleDirective// 解析ConnectByProfile指令内容连接执行后消息队列移除该消息Bluetooth:parseDirectivePayloadBluetooth:executeConnectByProfile:profileName=A2DP-SOURCE,profileVersion=Bluetooth:executeUpdateContext:buffer={"alexaDevice"\:{"friendlyName"\:"sprite-moon"}\,"pairedDevices"\:[]}Bluetooth:executeQueueEventAndRequestContext:eventName=ConnectByProfileFailedDirectiveProcessor:onHandlingCompeted:messageId=90326566-00c6-436b-93ef-a9d7e0bf8558,directiveBeingPreHandled=(nullptr)CapabilityAgent:removingMessageIdFromMap:messageId=90326566-00c6-436b-93ef-a9d7e0bf8558// 解析EnterDiscoverableMode指令内容连接执行后消息队列移除该消息Bluetooth:parseDirectivePayloadBluetooth:executeSetDiscoverableModeBluetooth:executeQueueEventAndRequestContext:eventName=EnterDiscoverableModeSucceededDirectiveProcessor:onHandlingCompeted:messageId=2836b54f-8e68-4147-86a4-8056d98cc7fe,directiveBeingPreHandled=(nullptr)CapabilityAgent:removingMessageIdFromMap:messageId=2836b54f-8e68-4147-86a4-8056d98cc7fe// Context可用时发送ConnectByProfileFailed事件Bluetooth:onContextAvailableLambdaEventBuilder:buildJsonEventString:messageId=ab2db07c-9095-4110-bec2-59719618417d,namespace=Bluetooth,name=ConnectByProfileFailedBluetooth:onContextAvailableLambda:event={"context":[{"header":{"namespace":"Bluetooth","name":"BluetoothState"},"payload":{"alexaDevice":{"friendlyName":"sprite-moon"},"pairedDevices":[]}}],"event":{"header":{"namespace":"Bluetooth","name":"ConnectByProfileFailed","messageId":"ab2db07c-9095-4110-bec2-59719618417d"},"payload":{"requester":"CLOUD","profileName":"A2DP-SOURCE"}}}AVSConnectionManager:sendMessage:event="报文内容同上,原始报文中的context包含所有端能力状态"// Context可用时发送EnterDiscoverableModeSucceeded事件Bluetooth:onContextAvailableLambdaEventBuilder:buildJsonEventString:messageId=6dcdbdad-eba3-4fd2-805f-48b2da365a62,namespace=Bluetooth,name=EnterDiscoverableModeSucceededBluetooth:onContextAvailableLambda:event={"context":[{"header":{"namespace":"Bluetooth","name":"BluetoothState"},"payload":{"alexaDevice":{"friendlyName":"sprite-moon"},"pairedDevices":[]}}],"event":{"header":{"namespace":"Bluetooth","name":"EnterDiscoverableModeSucceeded","messageId":"6dcdbdad-eba3-4fd2-805f-48b2da365a62"},"payload":{}}}AVSConnectionManager:sendMessage:event="报文内容同上,原始报文中的context包含所有端能力状态"

转载于:https://www.cnblogs.com/clxye/p/9946480.html

你可能感兴趣的文章
ActionBar详解
查看>>
Java编程的逻辑 (16) - 继承的细节
查看>>
基于keepalived搭建MySQL的高可用集群
查看>>
CTeX学习心得总结
查看>>
运算放大器相关参数基本知识(一)
查看>>
Maven中解决依赖冲突的问题
查看>>
Gcc编译过程
查看>>
iOS Json转换模型库:YYModel
查看>>
u-boot 2011.09 开启debug 调试
查看>>
Redis主从配置详细过程
查看>>
Swift和Objective-C混编注意
查看>>
沈阳赛区总结
查看>>
自然语言1_介绍和安装
查看>>
Lind.DDD.LindMQ的一些想法
查看>>
git: windows git ssh keys生成
查看>>
转: 系统分布式情况下最终一致性方案梳理
查看>>
Webpack学习笔记一:What is webpack
查看>>
判断一个变量的类型Object.prototype.toString.call
查看>>
linux磁盘空间查询
查看>>
windows中使用Findwindow函数与FindWindowEx函数来实现自动控制、触发第三方软件事件的方法...
查看>>