HarmonyOS学习路之开发篇—网络与连接(WLAN开发 二)

这篇具有很好参考价值的文章主要介绍了HarmonyOS学习路之开发篇—网络与连接(WLAN开发 二)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

不信任热点配置

场景介绍

应用可以添加指定的热点,其选网优先级低于已保存热点。如果扫描后判断该热点为最合适热点,自动连接该热点。

应用或者其他模块可以通过接口完成以下功能:

  1. 设置第三方的热点配置。
  2. 删除第三方的热点配置。

接口说明

WifiDevice提供WLAN的不信任热点配置功能,其接口说明如下。

表1 不信任热点配置功能的主要接口

接口名

描述

所需权限

getInstance(Context context)

获取WLAN功能管理对象实例,通过该实例调用不信任热点配置的API。

NA

addUntrustedConfig​(WifiDeviceConfig config)

添加不信任热点配置,选网优先级低于已保存热点。

ohos.permission.SET_WIFI_INFO

removeUntrustedConfig(WifiDeviceConfig config)

删除不信任热点配置。

ohos.permission.SET_WIFI_INFO

添加不信任热点配置

  1. 调用WifiDevice的getInstance​(Context context)接口,获取WifiDevice实例,用于管理本机WLAN操作。
  2. 调用addUntrustedConfig(WifiDeviceConfig config)接口,设置三方添加的不信任配置。
// 获取WLAN管理对象
WifiDevice wifiDevice = WifiDevice.getInstance(context);
// 设置三方添加的不信任配置
WifiDeviceConfig config = new WifiDeviceConfig();
config.setSsid("untrusted-exist");
config.setPreSharedKey("123456789");
config.setHiddenSsid(false);
config.setSecurityType(WifiSecurity.PSK);
boolean isSuccess = wifiDevice.addUntrustedConfig(config);

删除不信任热点配置

  1. 调用WifiDevice的getInstance​(Context context)接口,获取WifiDevice实例,用于管理本机WLAN操作。
  2. 调用removeUntrustedConfig(WifiDeviceConfig config)接口,删除三方添加的不信任配置。
// 获取WLAN管理对象
WifiDevice wifiDevice = WifiDevice.getInstance(context);
// 设置删除三方添加的不信任配置
WifiDeviceConfig config = new WifiDeviceConfig();
config.setSsid("untrusted-exist");
config.setPreSharedKey("123456789");
config.setHiddenSsid(false);
config.setSecurityType(WifiSecurity.PSK);
boolean isSuccess = wifiDevice.removeUntrustedConfig(config);

P2P功能

场景介绍

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

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

接口说明

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

表1 WifiP2pController的主要接口

接口名

描述

所需权限

init(EventRunner eventRunner, WifiP2pCallback callback)

初始化P2P的信使,当且仅当信使被成功初始化,P2P的其他功能才可以正常使用。

ohos.permission.GET_WIFI_INFO

ohos.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操作。
  2. 调用init(EventRunner eventRunner, WifiP2pCallback callback)初始化P2P控制器实例。
  3. 发起P2P搜索。
  4. 获取P2P搜索回调信息。
  5. 停止P2P搜索。
try {
    // 获取P2P管理对象
    WifiP2pController wifiP2pController = WifiP2pController.getInstance(this);
    // 初始化P2P管理对象,用于建立P2P信使等行为
    wifiP2pController.init(EventRunner.create(true), null);
    // 创建P2P回调对象
    P2pDiscoverCallBack p2pDiscoverCallBack = new P2pDiscoverCallBack();
    // 发起P2P搜索
    wifiP2pController.discoverDevices(p2pDiscoverCallBack);
    // 停止P2P搜索
    wifiP2pController.stopDeviceDiscovery(p2pDiscoverCallBack);
} catch (RemoteException re) {
    HiLog.error(LABEL, "exception happened.");
}

// 获取P2P启动与停止搜索的回调信息(失败或者成功)
private class P2pDiscoverCallBack extends WifiP2pCallback {
    @Override
    public void eventExecFail(int reason) {
        HiLog.warn(LABEL, "discoverDevices eventExecFail reason : %{public}d", reason);
    }

    @Override
    public void eventExecOk() {
        HiLog.info(LABEL, "discoverDevices eventExecOk");
    }
}

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

  1. 调用WifiP2pController的getInstance​(Context context)接口,获取P2P控制器实例,用于管理P2P操作。
  2. 调用init(EventRunner eventRunner, WifiP2pCallback callback)初始化P2P控制器实例。
  3. 创建P2P群组。
  4. 移除P2P群组。
try {
    // 获取P2P管理对象
    WifiP2pController wifiP2pController = WifiP2pController.getInstance(this);
    // 初始化P2P管理对象,用于建立P2P信使等行为
    wifiP2pController.init(EventRunner.create(true), null);
    // 创建用于P2P建组需要的配置
    WifiP2pConfig wifiP2pConfig = new WifiP2pConfig("DEFAULT_GROUP_NAME", "DEFAULT_PASSPHRASE");
    wifiP2pConfig.setDeviceAddress("02:02:02:02:03:04");
    wifiP2pConfig.setGroupOwnerBand(0);
    // 创建P2P回调对象
    P2pCreateGroupCallBack p2pCreateGroupCallBack = new P2pCreateGroupCallBack();
    // 创建P2P群组
    wifiP2pController.createGroup(wifiP2pConfig, p2pCreateGroupCallBack);
    // 移除P2P群组
    wifiP2pController.removeGroup(p2pCreateGroupCallBack);
} catch (RemoteException re) {
    HiLog.error(LABEL, "exception happened.");
}

private class P2pCreateGroupCallBack extends WifiP2pCallback {
    @Override
    public void eventExecFail(int reason) {
        HiLog.warn(LABEL, "CreateGroup eventExecFail reason : %{public}d", reason);
    }

    @Override
    public void eventExecOk() {
        HiLog.info(LABEL, "CreateGroup eventExecOk");
    }
}

发起P2P连接的开发步骤

  1. 调用WifiP2pController的getInstance​(Context context)接口,获取P2P控制器实例,用于管理P2P操作。
  2. 调用init(EventRunner eventRunner, WifiP2pCallback callback)初始化P2P控制器实例。
  3. 调用requestP2pInfo()查询P2P可用设备信息。
  4. 根据场景不同,从可用设备信息中选择目标设备。
  5. 调用connect接口发起连接。
try {
    // 获取P2P管理对象
    WifiP2pController wifiP2pController = WifiP2pController.getInstance(this);
    // 初始化P2P管理对象,用于建立P2P信使等行为
    wifiP2pController.init(EventRunner.create(true), null);
    // 查询可用P2P设备信息,通过回调获取P2P设备信息
    P2pRequestPeersCallBack p2pRequestPeersCallBack = new P2pRequestPeersCallBack();
    wifiP2pController.requestP2pInfo(WifiP2pController.DEVICE_LIST_REQUEST, p2pRequestPeersCallBack);
} catch (RemoteException re) {
    HiLog.error(LABEL, "exception happened.");
}

private class P2pRequestPeersCallBack extends WifiP2pCallback {
    @Override
    public void eventP2pDevicesList(List<WifiP2pDevice> devices) {
        HiLog.info(LABEL, "eventP2pDevicesList when start connect group");
        // 根据场景不同,选择不同的设备进行连接,通过MAC地址搜索到指定设备
        WifiP2pConfig wifiP2pConfig = getSameP2pConfigFromDevices(devices);
        try {
            if (wifiP2pConfig != null) {
                // 向指定的设备发起连接
                wifiP2pController.connect(wifiP2pConfig, null);
            }
        } catch (RemoteException re) {
            HiLog.error(LABEL, "exception happened in connect.");
        }
    }
}

private WifiP2pConfig getSameP2pConfigFromDevices(List<WifiP2pDevice> devices) {
    if (devices == null || devices.isEmpty()) {
        return null;
    }
    for (int i = 0; i < devices.size(); i++) {
        WifiP2pDevice p2pDevice = devices.get(i);
        HiLog.info(LABEL, "p2pDevice.getDeviceAddress() : %{private}s", p2pDevice.getDeviceAddress());
        if (p2pDevice.getDeviceAddress() != null
                && p2pDevice.getDeviceAddress().equals(TARGET_P2P_MAC_ADDRESS)) {
            HiLog.info(LABEL, "received same mac address");
            WifiP2pConfig wifiP2pConfig = new WifiP2pConfig("DEFAULT_GROUP_NAME", "DEFAULT_PASSPHRASE"); // 根据实际情况配置名字和密码
            wifiP2pConfig.setDeviceAddress(p2pDevice.getDeviceAddress());
            return wifiP2pConfig;
        }
    }
    return null;
}

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

  1. 调用WifiP2pController的getInstance​()接口,获取P2P控制器实例,用于管理P2P操作。
  2. 调用init()初始化P2P控制器实例。
  3. 调用requestP2pInfo()查询P2P群组信息。
  4. 调用requestP2pInfo()查询P2P设备信息。
  5. 根据场景不同,可以调用requestP2pInfo获取需要的信息。
try {
    // 获取P2P管理对象
    WifiP2pController wifiP2pController = WifiP2pController.getInstance(this);
    // 初始化P2P管理对象,用于建立P2P信使等行为
    wifiP2pController.init(EventRunner.create(true), null);
    // 查询可用P2P群组信息,通过回调获取P2P群组信息
    P2pRequestGroupInfoCallBack p2pRequestGroupInfoCallBack = new P2pRequestGroupInfoCallBack();
    wifiP2pController.requestP2pInfo(WifiP2pController.GROUP_INFO_REQUEST, p2pRequestGroupInfoCallBack);
    // 查询可用P2P设备信息,通过回调获取P2P设备信息
    P2pRequestDeviceInfoCallBack p2pRequestDeviceInfoCallBack = new P2pRequestDeviceInfoCallBack();
    wifiP2pController.requestP2pInfo(WifiP2pController.DEVICE_INFO_REQUEST, p2pRequestDeviceInfoCallBack);
    // 通过调用requestP2pInfo接口,可以查询以下关键信息
    wifiP2pController.requestP2pInfo(WifiP2pController.NETWORK_INFO_REQUEST, callback); // 网络信息
    wifiP2pController.requestP2pInfo(WifiP2pController.DEVICE_LIST_REQUEST, callback); // 设备列表信息
} catch (RemoteException re) {
    HiLog.error(LABEL, "exception happened.");
}

// 群组信息回调
private class P2pRequestGroupInfoCallBack extends WifiP2pCallback {
    @Override
    public void eventP2pGroup(WifiP2pGroup group) {
        HiLog.info(LABEL, "P2pRequestGroupInfoCallBack eventP2pGroup");
        doSthFor(group);
    }
}
// 设备信息回调
private class P2pRequestDeviceInfoCallBack extends WifiP2pCallback {
    @Override
    public void eventP2pDevice(WifiP2pDevice p2pDevice) {
        HiLog.info(LABEL, "P2pRequestDeviceInfoCallBack eventP2pDevice");
        doSthFor(p2pDevice);
    }
}

WLAN消息通知

场景介绍

WLAN消息通知(Notification)是HarmonyOS内部或者与应用之间跨进程通讯的机制,注册者在注册消息通知后,一旦符合条件的消息被发出,注册者即可接收到该消息并获取消息中附带的信息。

接口说明

表1 WLAN消息通知的相关广播介绍

描述

通知名

附加参数

WLAN状态

usual.event.wifi.POWER_STATE

active_state

WLAN扫描

usual.event.wifi.SCAN_FINISHED

scan_state

WLAN RSSI变化

usual.event.wifi.RSSI_VALUE

rssi_value

WLAN连接状态

usual.event.wifi.CONN_STATE

conn_state

Hotspot状态

usual.event.wifi.HOTSPOT_STATE

hotspot_active_state

Hotspot连接状态

usual.event.wifi.WIFI_HS_STA_JOIN usual.event.wifi.WIFI_HS_STA_LEAVE

-

P2P状态

usual.event.wifi.p2p.STATE_CHANGE

p2p_state

P2P连接状态

usual.event.wifi.p2p.CONN_STATE_CHANGE

linked_info

net_info

group_info

P2P设备列表变化

usual.event.wifi.p2p.DEVICES_CHANGE

-

P2P搜索状态变化

usual.event.wifi.p2p.PEER_DISCOVERY_STATE_CHANGE

peers_discovery

P2P当前设备变化

usual.event.wifi.p2p.CURRENT_DEVICE_CHANGE

p2p_device文章来源地址https://www.toymoban.com/news/detail-515557.html

开发步骤

  1. 构建消息通知接收者WifiEventSubscriber。
  2. 注册WLAN变化消息。
  3. WifiEventSubscriber接收并处理WLAN广播消息。
// 构建消息接收者/注册者
class WifiEventSubscriber extends CommonEventSubscriber {
    WifiEventSubscriber(CommonEventSubscribeInfo info) {
        super(info);
    }

    @Override
    public void onReceiveEvent(CommonEventData commonEventData) {
        if (commonEventData == null || commonEventData.getIntent() == null) {
            return;
        }
        if (WifiEvents.EVENT_ACTIVE_STATE.equals(commonEventData.getIntent().getAction())) {
            // 获取附带参数
            IntentParams params = commonEventData.getIntent().getParams();
            if (params == null) {
                return;
            }
            int wifiState= (int) params.getParam(WifiEvents.PARAM_ACTIVE_STATE);
            
            if (wifiState== WifiEvents.STATE_ACTIVE) { // 处理WLAN被打开消息
                HiLog.info(LABEL, "Receive WifiEvents.STATE_ACTIVE %{public}d", wifiState);
            } else if (wifiState == WifiEvents.STATE_INACTIVE) { // 处理WLAN被关闭消息  
                HiLog.info(LABEL, "Receive WifiEvents.STATE_INACTIVE %{public}d", wifiState);
            } else { // 处理WLAN异常状态
                HiLog.warn(LABEL,"Unknown wifi state");
            }
        }
    }
}

// 注册消息
MatchingSkills match = new MatchingSkills();
// 增加获取WLAN状态变化消息
match.addEvent(WifiEvents.EVENT_ACTIVE_STATE);
CommonEventSubscribeInfo subscribeInfo = new CommonEventSubscribeInfo(match);
subscribeInfo.setPriority(100); 
WifiEventSubscriber subscriber = new WifiEventSubscriber(subscribeInfo);

try {
    CommonEventManager.subscribeCommonEvent(subscriber);
} catch (RemoteException e) {
    HiLog.warn(LABEL, "subscribe in wifi events failed!");
}

到了这里,关于HarmonyOS学习路之开发篇—网络与连接(WLAN开发 二)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • HarmonyOS学习路之开发篇—设备管理(位置开发)

    移动终端设备已经深入人们日常生活的方方面面,如查看所在城市的天气、新闻轶事、出行打车、旅行导航、运动记录。这些习以为常的活动,都离不开定位用户终端设备的位置。 当用户处于这些丰富的使用场景中时,系统的位置能力可以提供实时准确的位置数据。对于开发

    2024年02月16日
    浏览(27)
  • HarmonyOS学习路之开发篇—AI功能开发(实体识别)

    实体识别能够从自然语言中提取出具有特定意义的实体,并在此基础上完成搜索等一系列相关操作及功能。 实体识别覆盖范围大,能够满足日常开发中对实体识别的需求,让应用体验更好。识别准确率高,能够准确地提取到实体信息,对应用基于信息的后续服务形成关键影响

    2024年02月11日
    浏览(28)
  • HarmonyOS学习路之开发篇—AI功能开发(语音播报)

    语音播报(Text to Speech,下文简称TTS),基于华为智慧引擎(HUAWEI HiAI Engine)中的语音播报引擎,向开发者提供人工智能应用层API。该技术提供将文本转换为语音并进行播报的能力。 支持超长文本播报,最大文本长度为100000个字符。 语音播报不支持多线程调用。 实时语音交

    2024年02月11日
    浏览(58)
  • HarmonyOS学习路之开发篇—多媒体开发(相机开发 二)

    Camera操作类,包括相机预览、录像、拍照等功能接口。 接口名 描述 triggerSingleCapture​(FrameConfig frameConfig) 启动相机帧的单帧捕获。 triggerMultiCapture​(ListFrameConfig frameConfigs) 启动相机帧的多帧捕获。 configure​(CameraConfig config) 配置相机。 flushCaptures​() 停止并清除相机帧的捕获

    2024年02月11日
    浏览(32)
  • HarmonyOS学习路之开发篇—多媒体开发(图像开发 二)

    图像编码就是将PixelMap图像编码成不同存档格式图片,用于后续其他处理,比如保存、传输等。当前仅支持JPEG格式。 ImagePacker主要用于图像编码。 接口名 描述 create() 创建图像打包器实例。 initializePacking(byte[] data, PackingOptions opts) 初始化打包任务,将字节数组设置为打包后输

    2024年02月11日
    浏览(32)
  • HarmonyOS学习路之开发篇—多媒体开发(相机开发 一)

    HarmonyOS相机模块支持相机业务的开发,开发者可以通过已开放的接口实现相机硬件的访问、操作和新功能开发,最常见的操作如:预览、拍照、连拍和录像等。 相机静态能力 用于描述相机的固有能力的一系列参数,比如朝向、支持的分辨率等信息。 物理相机 物理相机就是独

    2024年02月10日
    浏览(45)
  • HarmonyOS学习路之开发篇—多媒体开发(图像开发 一)

    HarmonyOS图像模块支持图像业务的开发,常见功能如图像解码、图像编码、基本的位图操作、图像编辑等。当然,也支持通过接口组合来实现更复杂的图像处理逻辑。 图像解码 图像解码就是不同的存档格式图片(如JPEG、PNG等)解码为无压缩的位图格式,以方便在应用或者系统

    2024年02月11日
    浏览(28)
  • HarmonyOS学习路之方舟开发框架—方舟开发框架(ArkUI)概述

    方舟开发框架(简称ArkUI)为HarmonyOS应用的UI开发提供了完整的基础设施,包括简洁的UI语法、丰富的UI功能(组件、布局、动画以及交互事件),以及实时界面预览工具等,可以支持开发者进行可视化界面开发。 UI: 即用户界面。开发者可以将应用的用户界面设计为多个功能

    2024年02月16日
    浏览(31)
  • HarmonyOS学习路之开发篇—AI功能开发(文档检测校正)

    文档校正提供了文档翻拍过程的辅助增强功能,包含两个子功能: 文档检测:能够自动识别图片中的文档,返回文档在原图中的位置信息。这里的文档泛指外形方正的事物,比如书本、相片、画框等。 文档校正:能根据文档在原始图片中的位置信息校正文档的拍摄角度,自

    2024年02月11日
    浏览(50)
  • HarmonyOS学习路之开发篇—Java UI框架(动画开发)

    动画是组件的基础特性之一,精心设计的动画使UI变化更直观,有助于改进应用程序的外观并改善用户体验。Java UI框架提供了帧动画、数值动画和属性动画,并提供了将多个动画同时操作的动画集合。 帧动画是利用视觉暂留现象,将一系列静止的图片按序播放,给用户产生动

    2024年02月09日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包