鸿蒙(HarmonyOS NEXT)开发实战:P2P模式开发指导

鸿蒙开发往期必看:

HarmonyOS NEXT应用开发性能实践总结

一分钟了解”纯血版!鸿蒙HarmonyOS Next应用开发!

“非常详细的” 鸿蒙HarmonyOS Next应用开发学习路线!(从零基础入门到精通)

 “一杯冰美式的时间” 了解鸿蒙HarmonyOS Next应用开发路径!


简介

P2P模式,主要提供了wlan设备的一种点对点连接技术,它可以在两台 STA 之间直接建立 TCP/IP 链接,并不需要AP的参与。

场景介绍

主要场景有:

  • 创建/删除P2P群组
  • 建立P2P连接

接口说明

完整的 JS API 说明以及实例代码请参考:P2P 接口

具体接口说明如下表。

接口名功能描述
createGroup()创建群组。
removeGroup()删除群组。
startDiscoverDevices()开始发现设备。
getP2pPeerDevices()获取P2P对端设备列表信息。
p2pConnect()执行P2P连接。
getP2pLinkedInfo()获取P2P连接信息。
on(type: 'p2pPersistentGroupChange')注册P2P永久组状态改变事件。
off(type: 'p2pPersistentGroupChange')取消注册P2P永久组状态改变事件。
on(type: 'p2pPeerDeviceChange')注册P2P对端设备状态改变事件。
off(type: 'p2pPeerDeviceChange')取消注册P2P对端设备状态改变事件。
on(type: 'p2pConnectionChange')注册P2P连接状态改变事件。
off(type: 'p2pConnectionChange')取消注册P2P连接状态改变事件。

主要场景开发步骤

创建/删除P2P群组

  1. import需要的WI-FI模块。
  2. 开启设备的WI-FI。
  3. 需要SystemCapability.Communication.WiFi.P2P系统能力。
  4. 创建/删除P2P群组。
  5. 示例代码:
import wifiManager from '@ohos.wifiManager';

// 创建群组,将当前设备当做GO使用时,需要该步骤
// netId:-1表示创建临时组,下次和已连接过的设备连接,需要重新进行GO协商,以及wps秘钥协商;
//        -2表示创建永久组,下次和已连接过的设备连接,不需要重新进行GO和wps秘钥协商;

let recvP2pPersistentGroupChangeFunc = () => {
    console.info("p2p persistent group change receive event");
  
    // 永久组创建好后需要处理的业务
}
// 创建永久组,需要注册永久组状态改变事件回调
wifiManager.on("p2pPersistentGroupChange", recvP2pPersistentGroupChangeFunc);
try {
    let config:wifiManager.WifiP2PConfig = {
        deviceAddress: "00:11:22:33:44:55",
        deviceAddressType: 1,
        netId: -2,
        passphrase: "12345678",
        groupName: "testGroup",
        goBand: 0
    }
    wifiManager.createGroup(config);    
}catch(error){
    console.error("failed:" + JSON.stringify(error));
}
    
// 删除群组
try {
    wifiManager.removeGroup();    
}catch(error){
    console.error("failed:" + JSON.stringify(error));
}
  1. 错误码请参见WIFI错误码

建立P2P连接

  1. import需要的WI-FI模块。
  2. 开启设备的WI-FI。
  3. 需要SystemCapability.Communication.WiFi.P2P系统能力。
  4. 注册"p2pPeerDeviceChange"事件回调,并在回调实现中执行P2P连接。
  5. 开始P2P设备发现。
  6. 示例代码:
import wifiManager from '@ohos.wifiManager';
  
let recvP2pConnectionChangeFunc = (result:wifiManager.WifiP2pLinkedInfo) => {
    console.info("p2p connection change receive event: " + JSON.stringify(result));
    wifiManager.getP2pLinkedInfo((err, data) => {
        if (err) {
            console.error('failed to get getP2pLinkedInfo: ' + JSON.stringify(err));
            return;
        }
        console.info("get getP2pLinkedInfo: " + JSON.stringify(data));
        // 添加P2P连接成功或者失败场景的业务处理
    });
}
// P2P连接完成,会调用"p2pConnectionChange"事件回调
wifiManager.on("p2pConnectionChange", recvP2pConnectionChangeFunc);
  
let recvP2pPeerDeviceChangeFunc = (result:wifiManager.WifiP2pDevice[]) => {
    console.info("p2p peer device change receive event: " + JSON.stringify(result));
    wifiManager.getP2pPeerDevices((err, data) => {
        if (err) {
            console.error('failed to get peer devices: ' + JSON.stringify(err));
            return;
        }
        console.info("get peer devices: " + JSON.stringify(data));
        let len = data.length;
        for (let i = 0; i < len; ++i) {
            // 选择符合条件的对端P2P设备
            if (data[i].deviceName === "my_test_device") {
                console.info("p2p connect to test device: " + data[i].deviceAddress);
                let config:wifiManager.WifiP2PConfig = {
                    deviceAddress:data[i].deviceAddress,
                    deviceAddressType: 1,
                    netId:-2,
                    passphrase:"",
                    groupName:"",
                    goBand:0,
                }
                // 执行P2P连接
                wifiManager.p2pConnect(config);
            }
        }
    });
}
// P2P扫描结果上报时会调用"p2pPeerDeviceChange"事件回调
wifiManager.on("p2pPeerDeviceChange", recvP2pPeerDeviceChangeFunc);
  
setTimeout(() => {wifiManager.off("p2pConnectionChange", recvP2pConnectionChangeFunc);}, 125 * 1000);
setTimeout(() =>  {wifiManager.off("p2pPeerDeviceChange", recvP2pPeerDeviceChangeFunc);}, 125 * 1000);
// 开始发现P2P设备,即,开始P2P扫描
console.info("start discover devices -> " + wifiManager.startDiscoverDevices());
  1. 错误码请参见WIFI错误码

最后

小编在之前的鸿蒙系统扫盲中,我明显感觉到一点,那就是许多人参与鸿蒙开发,但是又不知道从哪里下手,有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以有一份实用的鸿蒙(HarmonyOS NEXT)路线图、文档、视频、用来跟着学习是非常有必要的。 

如果你是一名有经验的资深Android移动开发、Java开发、前端开发、对鸿蒙感兴趣以及转行人员

→  鸿蒙全栈最新学习笔记 希望这一份鸿蒙学习文档能够给大家带来帮助 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值