鸿蒙OS P2P功能章

2020-09-18 15:40 更新

场景介绍

WLAN P2P 功能用于设备与设备之间的点对点数据传输,应用可以通过接口完成以下功能:

  1. 发现对端设备。
  2. 建立与移除群组。
  3. 向对端设备发起连接。
  4. 获取 P2P 相关信息。

接口说明

WifiP2pController 提供 WLAN P2P 功能,接口说明如下。

接口名 描述 所需权限
init(EventRunner eventRunner, WifiP2pCallback callback) 初始化 P2P 的信使,当且仅当信使被成功初始化,P2P 的其他功能才可以正常使用。 ohos.permission.GET_WIFI_INFOohos.permission.SET_WIFI_INFO
discoverDevices(WifiP2pCallback callback) 搜索附近可用的 P2P 设备。 ohos.permission.GET_WIFI_INFO
stopDeviceDiscovery(WifiP2pCallback callback) 停止搜索附近的 P2P  设备。 ohos.permission.GET_WIFI_INFO
createGroup(WifiP2pConfig wifiP2pConfig, WifiP2pCallback callback) 建立 P2P 群组。 ohos.permission.GET_WIFI_INFO
removeGroup(WifiP2pCallback callback) 移除 P2P 群组。 ohos.permission.GET_WIFI_INFO
requestP2pInfo(int requestType, WifiP2pCallback callback) 请求 P2P 相关信息,如群组信息、连接信息、设备信息等。 ohos.permission.GET_WIFI_INFO
connect(WifiP2pConfig wifiP2pConfig, WifiP2pCallback callback) 向指定设备发起连接。 ohos.permission.GET_WIFI_INFO
cancelConnect(WifiP2pCallback callback) 取消向指定设备发起的连接。 ohos.permission.GET_WIFI_INFO

启动与停止 P2P 搜索的开发步骤

  1. 调用 WifiP2pController 的 getInstance(Context context) 接口,获取 P2P 控制器实例,用于管理 P2P 操作。

  1. 调用 init(EventRunner eventRunner, WifiP2pCallback callback)初始化 P2P 控制器实例。

  1. 发起 P2P 搜索。

  1. 获取 P2P 搜索回调信息。

  1. 停止 P2P 搜索。

  1. try {
  2. // 获取P2P管理对象
  3. WifiP2pController wifiP2pController = WifiP2pController.getInstance(this);
  4. // 初始化P2P管理对象,用于建立P2P信使等行为
  5. wifiP2pController.init(EventRunner.create(true), null);
  6. // 创建P2P回调对象
  7. P2pDiscoverCallBack p2pDiscoverCallBack = new P2pDiscoverCallBack();
  8. // 发起P2P搜索
  9. wifiP2pController.discoverDevices(p2pDiscoverCallBack);
  10. // 停止P2P搜索
  11. wifiP2pController.stopDeviceDiscovery(p2pDiscoverCallBack);
  12. } catch (RemoteException re) {
  13. HiLog.warn(LABEL, "exception happened.");
  14. }
  15. // 获取P2P启动与停止搜索的回调信息(失败或者成功)
  16. private class P2pDiscoverCallBack extends WifiP2pCallback {
  17. @Override
  18. public void eventExecFail(int reason) {
  19. HiLog.info(LABEL, "discoverDevices eventExecFail reason : %{public}d", reason);
  20. }
  21. @Override
  22. public void eventExecOk() {
  23. HiLog.info(LABEL, "discoverDevices eventExecOk");
  24. }
  25. }

创建与移除群组的开发步骤

  1. 调用 WifiP2pController 的 getInstance(Context context)接口,获取 P2P 控制器实例,用于管理 P2P 操作。

  1. 调用 init(EventRunner eventRunner, WifiP2pCallback callback)初始化 P2P 控制器实例。

  1. 创建 P2P 群组。

  1. 移除 P2P 群组。

  1. try {
  2. // 获取P2P管理对象
  3. WifiP2pController wifiP2pController = WifiP2pController.getInstance(this);
  4. // 初始化P2P管理对象,用于建立P2P信使等行为
  5. wifiP2pController.init(EventRunner.create(true), null);
  6. // 创建用于P2P建组需要的配置
  7. WifiP2pConfig wifiP2pConfig = new WifiP2pConfig("DEFAULT_GROUP_NAME", "DEFAULT_PASSPHRASE");
  8. wifiP2pConfig.setDeviceAddress("02:02:02:02:03:04");
  9. wifiP2pConfig.setGroupOwnerBand(0);
  10. // 创建P2P回调对象
  11. P2pCreateGroupCallBack p2pCreateGroupCallBack = new P2pCreateGroupCallBack();
  12. // 创建P2P群组
  13. wifiP2pController.createGroup(wifiP2pConfig, p2pCreateGroupCallBack);
  14. // 移除P2P群组
  15. wifiP2pController.removeGroup(p2pCreateGroupCallBack);
  16. } catch (RemoteException re) {
  17. HiLog.warn(LABEL, "exception happened.");
  18. }
  19. private class P2pCreateGroupCallBack extends WifiP2pCallback {
  20. @Override
  21. public void eventExecFail(int reason) {
  22. HiLog.info(LABEL, "CreateGroup eventExecFail reason : %{public}d", reason);
  23. }
  24. @Override
  25. public void eventExecOk() {
  26. HiLog.info(LABEL, "CreateGroup eventExecOk");
  27. }
  28. }

发起 P2P 连接的开发步骤

  1. 调用 WifiP2pController 的 getInstance(Context context) 接口,获取 P2P 控制器实例,用于管理 P2P 操作。

  1. 调用 init(EventRunner eventRunner, WifiP2pCallback callback)初始化 P2P 控制器实例。

  1. 调用 requestP2pInfo()查询 P2P 可用设备信息。

  1. 根据场景不同,从可用设备信息中选择目标设备。

  1. 调用 connect 接口发起连接。

  1. try {
  2. // 获取P2P管理对象
  3. WifiP2pController wifiP2pController = WifiP2pController.getInstance(this);
  4. // 初始化P2P管理对象,用于建立P2P信使等行为
  5. wifiP2pController.init(EventRunner.create(true), null);
  6. // 查询可用P2P设备信息,通过回调获取P2P设备信息
  7. P2pRequestPeersCallBack p2pRequestPeersCallBack = new P2pRequestPeersCallBack();
  8. wifiP2pController.requestP2pInfo(WifiP2pController.DEVICE_LIST_REQUEST, p2pRequestPeersCallBack);
  9. } catch (RemoteException re) {
  10. HiLog.warn(LABEL, "exception happened.");
  11. }
  12. private class P2pRequestPeersCallBack extends WifiP2pCallback {
  13. @Override
  14. public void eventP2pDevicesList(List<WifiP2pDevice> devices) {
  15. HiLog.info(LABEL, "eventP2pDevicesList when start connect group");
  16. // 根据场景不同,选择不同的设备进行连接,这里,通过MAC地址搜索到指定设备
  17. WifiP2pConfig wifiP2pConfig = getSameP2pConfigFromDevices(devices);
  18. try {
  19. if (wifiP2pConfig != null) {
  20. // 向指定的设备发起连接
  21. wifiP2pController.connect(wifiP2pConfig, null);
  22. }
  23. } catch (RemoteException re) {
  24. HiLog.warn(LABEL, "exception happened in connect.");
  25. }
  26. }
  27. }
  28. private WifiP2pConfig getSameP2pConfigFromDevices(List<WifiP2pDevice> devices) {
  29. if (devices == null) {
  30. return null;
  31. }
  32. for (int i = 0; i < devices.size(); i++) {
  33. WifiP2pDevice p2pDevice = devices.get(i);
  34. HiLog.info(LABEL, "p2pDevice.getDeviceAddress() : %{private}s", p2pDevice.getDeviceAddress());
  35. if (p2pDevice.getDeviceAddress() != null
  36. && p2pDevice.getDeviceAddress().equals(TARGET_P2P_MAC_ADDRESS)) {
  37. HiLog.info(LABEL, "received same mac address");
  38. WifiP2pConfig wifiP2pConfig = new WifiP2pConfig("DEFAULT_GROUP_NAME", "DEFAULT_PASSPHRASE");
  39. wifiP2pConfig.setDeviceAddress(p2pDevice.getDeviceAddress());
  40. return wifiP2pConfig;
  41. }
  42. }
  43. return null;
  44. }

请求P2P相关信息的开发步骤

  1. 调用 WifiP2pController 的 getInstance()接口,获取 P2P 控制器实例,用于管理 P2P 操作。

  1. 调用 init()初始化 P2P 控制器实例。

  1. 调用 requestP2pInfo()查询 P2P 群组信息。

  1. 调用 requestP2pInfo()查询 P2P 设备信息。

  1. 根据场景不同,可以调用 requestP2pInfo 获取需要的信息。

  1. try {
  2. // 获取P2P管理对象
  3. WifiP2pController wifiP2pController = WifiP2pController.getInstance(this);
  4. // 初始化P2P管理对象,用于建立P2P信使等行为
  5. wifiP2pController.init(EventRunner.create(true), null);
  6. // 查询可用P2P群组信息,通过回调获取P2P群组信息
  7. P2pRequestGroupInfoCallBack p2pRequestGroupInfoCallBack = new P2pRequestGroupInfoCallBack();
  8. wifiP2pController.requestP2pInfo(WifiP2pController.GROUP_INFO_REQUEST, p2pRequestGroupInfoCallBack);
  9. // 查询可用P2P设备信息,通过回调获取P2P设备信息
  10. P2pRequestDeviceInfoCallBack p2pRequestDeviceInfoCallBack = new P2pRequestDeviceInfoCallBack();
  11. wifiP2pController.requestP2pInfo(WifiP2pController.DEVICE_INFO_REQUEST, p2pRequestDeviceInfoCallBack);
  12. // 通过调用requestP2pInfo接口,可以查询以下关键信息
  13. wifiP2pController.requestP2pInfo(WifiP2pController.NETWORK_INFO_REQUEST, callback); // 网络信息
  14. wifiP2pController.requestP2pInfo(WifiP2pController.DEVICE_LIST_REQUEST, callback); // 设备列表信息
  15. } catch (RemoteException re) {
  16. HiLog.warn(LABEL, "exception happened.");
  17. }
  18. // 群组信息回调
  19. private class P2pRequestGroupInfoCallBack extends WifiP2pCallback {
  20. @Override
  21. public void eventP2pGroup(WifiP2pGroup group) {
  22. HiLog.info(LABEL, "P2pRequestGroupInfoCallBack eventP2pGroup");
  23. doSthFor(group);
  24. }
  25. }
  26. // 设备信息回调
  27. private class P2pRequestDeviceInfoCallBack extends WifiP2pCallback {
  28. @Override
  29. public void eventP2pGroup(WifiP2pDevice p2pDevice) {
  30. HiLog.info(LABEL, "eventP2pGroup");
  31. doSthFor(p2pDevice);
  32. }
  33. }
以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号