赞
踩
先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新HarmonyOS鸿蒙全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上鸿蒙开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip204888 (备注鸿蒙)
在Harmony OS上STA模式扫描其他WiFi热点,需要注意以下事项
WifiErrorCode
类型的返回值:WIFI_SUCCESS
,用于确认是否调用成功;WIFI_SUCCESS
表示失败,通过枚举值查找错误原因;EnableWifi
接口使能STA模式之前:RegisterWifiEvent
接口,向系统注册状态监听函数,用于接收状态通知,STA模式需要绑定如下两个回调函数;OnWifiScanStateChanged
用于绑定扫描状态监听函数,该回调函数有两个参数state
和size
;state
表示扫描状态,取值为0和1,1表示扫描动作完成;编程时可以与WifiEventState
枚举值的WIFI_STATE_NOT_AVALIABLE
,WIFI_STATE_AVALIABLE
进行比较,避免魔法数字;size
表示扫描到的热点个数;OnWifiConnectionChanged
用于绑定WiFi连接状态监听函数,该回调函数有两个参数state
和info
;state
表示WiFi连接状态,连接成功是WIFI_STATE_AVALIABLE
值为1,连接失败时WIFI_STATE_NOT_AVALIABLE
值为0;info
类型为WifiLinkedInfo*
,WifiLinkedInfo
有多个成员,包括ssid
,bssid
,rssi
,connState
,disconnectedReason
;Scan
接口只是触发扫描动作,并不会等到扫描完成才返回;Scan
接口进行扫描之前,EnableWifi
接口,并成功使能了STA模式;GetScanInfoList
函数(否则会有运行时异常报错),正确用法:GetScanInfoList
函数获取扫描结果;GetScanResult
函数有两个参数:第一个参数result
指向用于存放结果的数组,需要大于等于WIFI_SCAN_HOTSPOT_LIMIT
,
第二个参数size
类型为指针是为了内部能够修改它的值,返回后size指向的值是实际搜索到的热点个数;
调用GetScanResult
函数前,第二个参数size
指向的实际值不能为0,否则会包参数错误;
DisableWifi
关闭STA模式;在Harmony OS上STA模式连接其他WiFi热点,需要注意的事项和扫描WiFi热点类似,一下介绍差异的部分:
RegisterWifiEvent
接口,向系统注册状态监听函数,STA模式需要绑定两个回调;AddDeviceConfig
接口,向系统添加热点配置,它有两个参数;config
,类型为const WifiDeviceConfig*
,用于指定热点配置;result
,类型为int*
,用于操作成功时返回netId
;ConnectTo
接口,他有一个参数;netId
,类型为int
,应该使用AddDeviceConfig
接口调用成功之后result
参数得到值填充;ConnectTo
是同步的,连接成功失败会通过返回值体现;struct netif* iface = netifapi_netif_find("wlan0");
获取STA模式的网络接口err_t netifapi_dhcp_start(struct netif*)
接口,启动DHCP客户端;Disconnect
接口,无需参数,端口之前需要:err_t netifapi_dhcp_stop(struct netif*)
接口,停止DHCP客户端;RemoveDevice
,参数和ConnectTo
类似,AddDeviceConfig
接口调用成功之后result
参数得到值填充;在Harmony OS上创建WiFi热点,通用有一些事项需要注意:
RegisterWifiEvent
接口,向系统注册扫描状态监听函数,用于接收扫描状态通知,AP模式需要绑定三个函数;OnHotspotStaJoin
回调函数,其他设备连上当前热点时会被调用,参数StationInfo* info
,其中包含macAddress
和disconnectedReason
;OnHotspotStaLeave
回调函数,其他设备断开当前热点时会被调用,参数StationInfo* info
;OnHotspotStateChanged
回调函数,当热点本身状态变化时会被调用,参数int state
表示热点状态;SetHotspotConfig
接口,向系统设置当前热点配置信息;EnableHotspot
接口,开启热点,无需参数;g_iface = netifapi_netif_find("ap0");
,获取AP模式的网口netifapi_netif_set_addr
接口设置热点本身的IP地址、网关、子网掩码;netifapi_dhcps_start
接口启动DHCP服务端;netifapi_dhcps_stop
接口停止DHCP服务端;DisableHotspot
接口关闭热点;UnRegisterWifiEvent
接口解除事件监听;有两种方法可以编译此目录下的样例程序:
前两章中的方法——将当前目录下的*.c
文件和BUILD.gn
拷贝到openharmony源码的applications\sample\wifi-iot\app\iothardware
目录下;
再修改openharmony源码的applications\sample\wifi-iot\app\BUILD.gn
文件,将其中的 features
改为:iothardware:wifi_demo
;
再修改applications\sample\wifi-iot\app\iothardware\BUILD.gn
文件,决定需要编译哪个.c
文件;
在openharmony源码顶层目录执行:python build.py wifiiot
可以将本仓整体拷贝到openharmony源码树下,和applications
同级;
修改openharmony源码的build\lite\product\wifiiot.json
文件,将其中的:
//applications/sample/wifi-iot/app
替换为://HarmonyOS-IoT-Application-Development:app
2. 在openharmony源码顶层目录执行:python build.py wifiiot
为了能让大家更好的学习鸿蒙(HarmonyOS NEXT)开发技术,这边特意整理了《鸿蒙开发学习手册》(共计890页),希望对大家有所帮助:https://qr21.cn/FV7h05
https://qr21.cn/FV7h05
https://qr21.cn/FV7h05
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注鸿蒙)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
取:vip204888 (备注鸿蒙)**
[外链图片转存中…(img-W81yeUW3-1713130809338)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。