鸿蒙next开发:华为星闪开发(使用星闪传输数据)
提供星闪数传相关的端口通道建立和数据传输等功能........
·
往期鸿蒙全套实战文章必看:(附带鸿蒙全栈学习资料)
使用星闪传输数据
提供星闪数传相关的端口通道建立和数据传输等功能,同一设备可以同时承担数据发送端和接收端的角色。
场景介绍
星闪设备间已建立起逻辑链路基础上,支持应用基于Nearlink技术进行设备间的数据传输。
注意
1. 数据传输通道不保证链路加密。如需加密数传,需先进行配对流程,通过startPairing接口发起。
2. 链路是否加密可通过getAcbState接口查询,ENCRYPTED状态表示链路已加密。
接口说明
接口名 |
描述 |
---|---|
createPort(uuid: string): void |
注册端口服务。 |
connect(params: ConnectionParams): Promise<void> |
连接远端设备,建立端口通道。 |
writeData(params: DataParams): Promise<void> |
通过设备地址和UUID向远端设备发数据。 |
on(type: 'connectionStateChanged', callback: Callback<ConnectionResult>): void |
订阅端口通道连接状态变更事件。 |
on(type: 'readData', callback: Callback<DataParams>): void |
订阅端口通道数据接收事件。 |
开发步骤
- 导入相关模块。
import { dataTransfer } from '@kit.NearLinkKit'; import { remoteDevice } from '@kit.NearLinkKit'; import { BusinessError } from '@kit.BasicServicesKit';
- 与远端设备配对加密(可选,如需加密数传,则需执行此步骤)。该步骤执行后,将依据本端与远端设备的输入输出能力标识弹出不同类型的弹窗,需使用者进一步确认。目前支持免输入配对弹窗、数字比较弹窗与通行码鉴权弹窗。
let addr: string = '00:11:22:33:AA:FF'; // 扫描获取到的远端设备地址 let device: remoteDevice.RemoteDevice; try { device = remoteDevice.createRemoteDevice(addr); device.startPairing().then(()=>{ console.info('start pairing success'); }).catch ((err: BusinessError) => { console.error('errCode: ' + err.code + ', errMessage: ' + err.message); }); } catch (err) { console.error('errCode: ' + (err as BusinessError).code + ', errMessage: ' + (err as BusinessError).message); }
- 注册端口通道,发送端和接收端均需注册,并需保证发送端和接收端UUID相同。
let serviceUuid: string = 'FFFFFFFF-FC70-11EA-B720-000078951234'; // 星闪服务UUID,此处举例为自定义服务UUID try { dataTransfer.createPort(serviceUuid); console.info('create port success'); } catch (err) { console.error('errCode: ' + (err as BusinessError).code + ', errMessage: ' + (err as BusinessError).message); }
- 订阅端口通道连接状态变更事件。
let onReceiveConnectionStateEvent:(data: dataTransfer.ConnectionResult) => void = (data: dataTransfer.ConnectionResult) => { console.info('data: ' + JSON.stringify(data)); } try { dataTransfer.on('connectionStateChanged', onReceiveConnectionStateEvent); } catch (err) { console.error('errCode: ' + (err as BusinessError).code + ', errMessage: ' + (err as BusinessError).message); }
- 订阅端口通道数据接收事件。
let onReceiveReadDataEvent:(data: dataTransfer.DataParams) => void = (data: dataTransfer.DataParams) => { console.info('data: ' + JSON.stringify(data)); } try { dataTransfer.on('readData', onReceiveReadDataEvent); } catch (err) { console.error('errCode: ' + (err as BusinessError).code + ', errMessage: ' + (err as BusinessError).message); }
- 连接远端设备,建立端口通道。其中UUID要与步骤3中注册的UUID相同。
// 构造端口通道建立的参数 let connectionParams:dataTransfer.ConnectionParams = { address: addr, // 扫描获取到的远端设备地址 uuid: serviceUuid, // 星闪服务UUID mtu: 1024, // 期望发送数据包的字节大小,可选参数 }; try { dataTransfer.connect(connectionParams).then(()=>{ console.info('connect success'); }).catch ((err: BusinessError) => { console.error('errCode: ' + err.code + ', errMessage: ' + err.message); }); } catch (err) { console.error('errCode: ' + (err as BusinessError).code + ', errMessage: ' + (err as BusinessError).message); }
- 通过设备地址和UUID向远端设备发数据。其中UUID要与步骤3中注册的UUID相同。
// 构造发送数据参数 let transferValueBuffer: Uint8Array = new Uint8Array(4); transferValueBuffer[0] = 1; transferValueBuffer[1] = 2; transferValueBuffer[2] = 3; transferValueBuffer[3] = 4; let dataParams: dataTransfer.DataParams = { address: addr, // 星闪远端设备地址 uuid: serviceUuid, // 星闪服务UUID data: transferValueBuffer.buffer, // 星闪设备间传输的数据 }; try { dataTransfer.writeData(dataParams).then(() => { console.info('writeData success'); }).catch ((err: BusinessError) => { console.error('errCode: ' + err.code + ', errMessage: ' + err.message); }); } catch (err) { console.error('errCode: ' + (err as BusinessError).code + ', errMessage: ' + (err as BusinessError).message); }

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。
更多推荐
所有评论(0)