使用鸿蒙原始WiFI API接口进行编程,整个过程稍显繁琐,为此咱们对鸿蒙原始WiFi API接口作了一层封装,造成了一套更简单易用的接口。python
简化后的API接口 STA模式git
// 链接WiFi热点,并启动DHCP客户端;成功会返回一个netId,失败返回 -1 int ConnectToHotspot(WifiDeviceConfig* apConfig);编程
// 断开WiFi链接,以及中止DHCP客户端 void DisconnectWithHotspot(int netId);json
AP模式服务器
// 打开WiFi热点,同时启动DHCP服务器,成功返回SUCCESS int StartHotspot(const HotspotConfig* config);app
void StopHotspot(void);post
使用示例ui
STA模式,链接其余热点:code
// setup your AP params WifiDeviceConfig apConfig = {0}; strcpy(apConfig.ssid, "ABCD"); strcpy(apConfig.preSharedKey, "12345678"); apConfig.securityType = WIFI_SEC_TYPE_PSK; int netId = ConnectToHotspot(&apConfig);
断开到WiFi热点的链接:blog
DisconnectWithHotspot(netId);
AP模式,开启WiFi热点:
// 准备AP的配置参数 HotspotConfig config = {0}; strcpy(config.ssid, "HiSpark-AP"); strcpy(config.preSharedKey, "12345678"); config.securityType = WIFI_SEC_TYPE_PSK; WifiErrorCode errCode = StartHotspot(&config); printf("StartHotspot: %d\n", errCode);
关闭热点:
StopHotspot();
固然,整个实现代码也不复杂,你能够再此基础之上参考着本身从新实现,或者进行一些修改。
完整demo代码,能够在本帖附件下载。
如何编译 本项目下有两个示例代码,源码位于demo目录下,编译请按照以下流程进行;
将附件代码解压到本地openharmony源码的顶层目录; 修改openharmony的build\lite\product\wifiiot.json文件:将"//applications/sample/wifi-iot/app"替换为"easy_wifi:app" 执行编译命令:python build.py wifiiot 如需编译AP模式的demo,请修改demo目录下的BUILD.gn文件;注释掉"wifi_connect_demo.c"行,放开"wifi_hotspot_demo.c"行;
鸿蒙原始WiFiService接口
使用鸿蒙原始WiFI API接口进行编程,STA模式须要使用原始STA接口以及一些DHCP客户端接口。
STA模式 鸿蒙WiFi STA模式的API接口有:
以及Hi3861 SDK的DHCP客户端接口:
AP模式
使用鸿蒙原始WiFI API接口进行编程,AP模式须要使用原始AP模式接口以及一些DHCP服务端接口。
鸿蒙WiFi STA模式的API接口有:
以及Hi3861 DHCP服务端接口:
项目地址:https://gitee.com/hihopeorg/easy_wifi
若是发现有什么错误,或者能够改进的地方欢迎在这里评论,或者到码云上提交 Issue
做者:许思惟
想了解更多内容,请访问: 51CTO和华为官方战略合做共建的鸿蒙技术社区https://harmonyos.51cto.com