libxr  1.0
Want to be the best embedded framework
Loading...
Searching...
No Matches
LibXR::ESP32WifiClient Class Reference

ESP32 Wi-Fi 客户端实现 / ESP32 Wi-Fi client implementation. More...

#include <esp_wifi_client.hpp>

Inheritance diagram for LibXR::ESP32WifiClient:
[legend]
Collaboration diagram for LibXR::ESP32WifiClient:
[legend]

Public Member Functions

bool Enable () override
 启用网络接口(WiFi) / Enable the network interface
 
void Disable () override
 禁用网络接口(WiFi) / Disable the network interface
 
WifiError Connect (const Config &config) override
 连接到指定 WiFi 网络 / Connect to a WiFi network
 
WifiError Disconnect () override
 断开当前 WiFi 连接 / Disconnect from the WiFi network
 
bool IsConnected () const override
 检查是否已连接 / Check if currently connected
 
IPAddressRaw GetIPAddress () const override
 获取当前 IP 地址 / Get current IP address
 
MACAddressRaw GetMACAddress () const override
 获取当前 MAC 地址 / Get MAC address
 
WifiError Scan (ScanResult *out_list, size_t max_count, size_t &out_found) override
 扫描可用网络 / Scan for available WiFi networks
 
int GetRSSI () const override
 获取当前 WiFi 信号强度(RSSI) / Get current signal strength
 
- Public Member Functions inherited from LibXR::WifiClient
virtual ~WifiClient ()=default
 析构函数 / Destructor
 
- Public Member Functions inherited from LibXR::NetworkInterface

Private Member Functions

bool RegisterHandlers ()
 
void UnregisterHandlers ()
 
void ResetConnectionState ()
 
void DrainEvents ()
 

Static Private Member Functions

static void EventHandler (void *arg, esp_event_base_t event_base, int32_t event_id, void *event_data)
 事件处理回调 / Event handler callback
 

Private Attributes

bool init_ok_ = false
 
bool enabled_ = false
 是否启用 / Whether WiFi is enabled
 
bool handlers_registered_ = false
 
bool connected_ = false
 是否连接 / Whether WiFi is connected
 
bool got_ip_ = false
 是否获取 IP / Whether IP is acquired
 
char ip_str_ [16] = {}
 当前 IP 字符串 / Current IP string
 
esp_event_handler_instance_t wifi_connected_handler_ = nullptr
 
esp_event_handler_instance_t wifi_disconnected_handler_ = nullptr
 
esp_event_handler_instance_t got_ip_handler_ = nullptr
 
esp_event_handler_instance_t lost_ip_handler_ = nullptr
 
LibXR::Semaphore semaphore_
 状态同步信号量 / Event wait semaphore
 

Static Private Attributes

static bool is_initialized_
 ESP 网络是否已初始化 / Netif initialized.
 
static esp_netif_t * netif_ = nullptr
 ESP 默认 netif 对象 / Default netif.
 

Additional Inherited Members

- Public Types inherited from LibXR::WifiClient
enum class  WifiError {
  NONE , ALREADY_ENABLED , NOT_ENABLED , CONNECTION_TIMEOUT ,
  AUTHENTICATION_FAILED , DHCP_FAILED , SSID_NOT_FOUND , INVALID_CONFIG ,
  HARDWARE_FAILURE , SCAN_FAILED , UNKNOWN
}
 WiFi 错误码 / Enumeration of WiFi error codes. More...
 
enum class  Security { OPEN , WPA2_PSK , WPA2_ENTERPRISE , UNKNOWN }
 WiFi 安全类型 / WiFi security types. More...
 
using WifiCallback = LibXR::Callback<WifiError>
 WiFi 状态回调类型 / Callback type for WiFi status.
 

Detailed Description

ESP32 Wi-Fi 客户端实现 / ESP32 Wi-Fi client implementation.

基于 ESP-IDF 提供连接、断开、扫描、RSSI 查询等接口。 Provides connect/disconnect/scan/RSSI operations via ESP-IDF.

Definition at line 19 of file esp_wifi_client.hpp.

Constructor & Destructor Documentation

◆ ESP32WifiClient()

LibXR::ESP32WifiClient::ESP32WifiClient ( )

Definition at line 92 of file esp_wifi_client.cpp.

93{
95 {
96 init_ok_ = true;
97 return;
98 }
99
100 esp_err_t err = nvs_flash_init();
101 if ((err == ESP_ERR_NVS_NO_FREE_PAGES) || (err == ESP_ERR_NVS_NEW_VERSION_FOUND))
102 {
103 if (nvs_flash_erase() != ESP_OK)
104 {
105 return;
106 }
107 err = nvs_flash_init();
108 }
109 if (err != ESP_OK)
110 {
111 return;
112 }
113
114 err = esp_netif_init();
115 if ((err != ESP_OK) && (err != ESP_ERR_INVALID_STATE))
116 {
117 return;
118 }
119
120 err = esp_event_loop_create_default();
121 if ((err != ESP_OK) && (err != ESP_ERR_INVALID_STATE))
122 {
123 return;
124 }
125
126 netif_ = esp_netif_create_default_wifi_sta();
127 if (netif_ == nullptr)
128 {
129 return;
130 }
131
132 wifi_init_config_t cfg = WIFI_INIT_CONFIG_DEFAULT();
133 err = esp_wifi_init(&cfg);
134 if ((err != ESP_OK) && (err != ESP_ERR_INVALID_STATE))
135 {
136 return;
137 }
138
139 is_initialized_ = true;
140 init_ok_ = true;
141}
static bool is_initialized_
ESP 网络是否已初始化 / Netif initialized.
static esp_netif_t * netif_
ESP 默认 netif 对象 / Default netif.

Member Function Documentation

◆ Connect()

WifiClient::WifiError LibXR::ESP32WifiClient::Connect ( const Config & config)
overridevirtual

连接到指定 WiFi 网络 / Connect to a WiFi network

Parameters
[in]configWiFi 连接配置 / Configuration parameters
Returns
WifiError 连接结果 / Error code

Implements LibXR::WifiClient.

Definition at line 184 of file esp_wifi_client.cpp.

185{
186 if (!enabled_) return WifiError::NOT_ENABLED;
187
188 ResetConnectionState();
189 DrainEvents();
190
191 wifi_config_t wifi_config{};
192 CopyToWifiField(wifi_config.sta.ssid, sizeof(wifi_config.sta.ssid), config.ssid);
193 CopyToWifiField(wifi_config.sta.password, sizeof(wifi_config.sta.password),
194 config.password);
195 if (esp_wifi_set_config(WIFI_IF_STA, &wifi_config) != ESP_OK)
196 {
198 }
199 if (esp_wifi_connect() != ESP_OK)
200 {
202 }
203
204 if (!WaitForPredicate(semaphore_, kWifiConnectTimeoutMs, [&]() { return connected_; }))
205 {
207 }
208
209 if (!WaitForPredicate(semaphore_, kWifiDhcpTimeoutMs,
210 [&]() { return got_ip_ || !connected_; }))
211 {
213 }
215 if (!got_ip_) return WifiError::DHCP_FAILED;
216
217 return WifiError::NONE;
218}
bool connected_
是否连接 / Whether WiFi is connected
LibXR::Semaphore semaphore_
状态同步信号量 / Event wait semaphore
bool enabled_
是否启用 / Whether WiFi is enabled
bool got_ip_
是否获取 IP / Whether IP is acquired
@ DHCP_FAILED
DHCP 获取失败 / DHCP acquisition failed.
@ INVALID_CONFIG
配置无效 / Invalid configuration
@ HARDWARE_FAILURE
硬件故障 / Hardware failure
@ NOT_ENABLED
未启用 / Not enabled
@ NONE
无错误 / No error
@ CONNECTION_TIMEOUT
连接超时 / Connection timeout

◆ Disable()

void LibXR::ESP32WifiClient::Disable ( )
overridevirtual

禁用网络接口(WiFi) / Disable the network interface

Implements LibXR::WifiClient.

Definition at line 174 of file esp_wifi_client.cpp.

175{
176 if (!enabled_) return;
177
178 (void)esp_wifi_stop();
179 enabled_ = false;
180 ResetConnectionState();
181 UnregisterHandlers();
182}

◆ Disconnect()

WifiClient::WifiError LibXR::ESP32WifiClient::Disconnect ( )
overridevirtual

断开当前 WiFi 连接 / Disconnect from the WiFi network

Returns
WifiError 断开结果 / Error code

Implements LibXR::WifiClient.

Definition at line 220 of file esp_wifi_client.cpp.

221{
222 if (!enabled_) return WifiError::NOT_ENABLED;
223 if (!connected_) return WifiError::NONE;
224
225 DrainEvents();
226 if (esp_wifi_disconnect() != ESP_OK)
227 {
229 }
230
231 if (!WaitForPredicate(semaphore_, kWifiDisconnectTimeoutMs,
232 [&]() { return !connected_; }))
233 {
234 return WifiError::UNKNOWN;
235 }
236
237 return WifiError::NONE;
238}
@ UNKNOWN
未知错误 / Unknown error

◆ DrainEvents()

void LibXR::ESP32WifiClient::DrainEvents ( )
private

Definition at line 441 of file esp_wifi_client.cpp.

442{
443 while (semaphore_.Wait(0) == ErrorCode::OK)
444 {
445 }
446}
ErrorCode Wait(uint32_t timeout=UINT32_MAX)
等待(减少)信号量 Waits (decrements) the semaphore
Definition semaphore.cpp:25

◆ Enable()

bool LibXR::ESP32WifiClient::Enable ( )
overridevirtual

启用网络接口(WiFi) / Enable the network interface

Returns
true 表示成功 / true if enabled successfully

Implements LibXR::WifiClient.

Definition at line 143 of file esp_wifi_client.cpp.

144{
145 if (enabled_) return true;
146
147 if (!init_ok_)
148 {
149 return false;
150 }
151
152 if (!RegisterHandlers())
153 {
154 return false;
155 }
156
157 if (esp_wifi_set_mode(WIFI_MODE_STA) != ESP_OK)
158 {
159 UnregisterHandlers();
160 return false;
161 }
162
163 ResetConnectionState();
164 DrainEvents();
165 if (esp_wifi_start() != ESP_OK)
166 {
167 UnregisterHandlers();
168 return false;
169 }
170 enabled_ = true;
171 return true;
172}

◆ EventHandler()

void LibXR::ESP32WifiClient::EventHandler ( void * arg,
esp_event_base_t event_base,
int32_t event_id,
void * event_data )
staticprivate

事件处理回调 / Event handler callback

Parameters
arg用户数据 / User pointer
event_base事件域 / Event base type
event_id事件编号 / Event ID
event_data附加数据 / Event payload

Definition at line 313 of file esp_wifi_client.cpp.

315{
316 auto* self = static_cast<ESP32WifiClient*>(arg);
317
318 if (event_base == WIFI_EVENT)
319 {
320 switch (event_id)
321 {
322 case WIFI_EVENT_STA_CONNECTED:
323 self->connected_ = true;
324 self->semaphore_.Post();
325 break;
326 case WIFI_EVENT_STA_DISCONNECTED:
327 self->connected_ = false;
328 self->got_ip_ = false;
329 self->ip_str_[0] = '\0';
330 self->semaphore_.Post();
331 break;
332 default:
333 break;
334 }
335 }
336
337 if (event_base == IP_EVENT)
338 {
339 switch (event_id)
340 {
341 case IP_EVENT_STA_GOT_IP:
342 {
343 ip_event_got_ip_t* event = reinterpret_cast<ip_event_got_ip_t*>(event_data);
344 self->got_ip_ = true;
345 esp_ip4addr_ntoa(&event->ip_info.ip, self->ip_str_, sizeof(self->ip_str_));
346 self->semaphore_.Post();
347 break;
348 }
349 case IP_EVENT_STA_LOST_IP:
350 self->got_ip_ = false;
351 self->ip_str_[0] = '\0';
352 self->semaphore_.Post();
353 break;
354 default:
355 break;
356 }
357 }
358}

◆ GetIPAddress()

IPAddressRaw LibXR::ESP32WifiClient::GetIPAddress ( ) const
overridevirtual

获取当前 IP 地址 / Get current IP address

Returns
当前 IP 地址(结构形式) / Current IP address in raw form

Implements LibXR::WifiClient.

Definition at line 242 of file esp_wifi_client.cpp.

243{
244 return IPAddressRaw::FromString(ip_str_);
245}
char ip_str_[16]
当前 IP 字符串 / Current IP string

◆ GetMACAddress()

MACAddressRaw LibXR::ESP32WifiClient::GetMACAddress ( ) const
overridevirtual

获取当前 MAC 地址 / Get MAC address

Returns
当前 MAC 地址(结构形式) / Current MAC address in raw form

Implements LibXR::WifiClient.

Definition at line 247 of file esp_wifi_client.cpp.

248{
249 uint8_t mac[6] = {};
250 esp_wifi_get_mac(WIFI_IF_STA, mac);
251 MACAddressRaw result;
252 std::memcpy(result.bytes, mac, 6);
253 return result;
254}

◆ GetRSSI()

int LibXR::ESP32WifiClient::GetRSSI ( ) const
overridevirtual

获取当前 WiFi 信号强度(RSSI) / Get current signal strength

Returns
信号强度(dBm) / Signal strength in dBm

Implements LibXR::WifiClient.

Definition at line 360 of file esp_wifi_client.cpp.

361{
362 if (!connected_) return -127;
363
364 wifi_ap_record_t ap_info;
365 if (esp_wifi_sta_get_ap_info(&ap_info) == ESP_OK)
366 {
367 return ap_info.rssi;
368 }
369 return -127;
370}

◆ IsConnected()

bool LibXR::ESP32WifiClient::IsConnected ( ) const
overridevirtual

检查是否已连接 / Check if currently connected

Returns
true 如果连接上了 / true if connected

Implements LibXR::WifiClient.

Definition at line 240 of file esp_wifi_client.cpp.

240{ return connected_; }

◆ RegisterHandlers()

bool LibXR::ESP32WifiClient::RegisterHandlers ( )
private

Definition at line 372 of file esp_wifi_client.cpp.

373{
374 if (handlers_registered_)
375 {
376 return true;
377 }
378
379 if ((esp_event_handler_instance_register(WIFI_EVENT, WIFI_EVENT_STA_CONNECTED,
380 &EventHandler, this,
381 &wifi_connected_handler_) != ESP_OK) ||
382 (esp_event_handler_instance_register(WIFI_EVENT, WIFI_EVENT_STA_DISCONNECTED,
383 &EventHandler, this,
384 &wifi_disconnected_handler_) != ESP_OK) ||
385 (esp_event_handler_instance_register(IP_EVENT, IP_EVENT_STA_GOT_IP, &EventHandler,
386 this, &got_ip_handler_) != ESP_OK) ||
387 (esp_event_handler_instance_register(IP_EVENT, IP_EVENT_STA_LOST_IP, &EventHandler,
388 this, &lost_ip_handler_) != ESP_OK))
389 {
390 UnregisterHandlers();
391 return false;
392 }
393
394 handlers_registered_ = true;
395 return true;
396}
static void EventHandler(void *arg, esp_event_base_t event_base, int32_t event_id, void *event_data)
事件处理回调 / Event handler callback

◆ ResetConnectionState()

void LibXR::ESP32WifiClient::ResetConnectionState ( )
private

Definition at line 434 of file esp_wifi_client.cpp.

435{
436 connected_ = false;
437 got_ip_ = false;
438 ip_str_[0] = '\0';
439}

◆ Scan()

WifiClient::WifiError LibXR::ESP32WifiClient::Scan ( ScanResult * out_list,
size_t max_count,
size_t & out_found )
overridevirtual

扫描可用网络 / Scan for available WiFi networks

Parameters
[out]out_list扫描结果数组 / Output list buffer
[in]max_count最大可填入数量 / Max result count
[out]out_found实际找到数量 / Number found
Returns
WifiError 错误码 / Scan result code

Implements LibXR::WifiClient.

Definition at line 256 of file esp_wifi_client.cpp.

258{
259 out_found = 0;
260 if (!enabled_)
261 {
263 }
264 if ((out_list == nullptr) && (max_count != 0U))
265 {
267 }
268
269 wifi_scan_config_t scan_config = {};
270 if (esp_wifi_scan_start(&scan_config, true) != ESP_OK)
271 {
273 }
274
275 uint16_t ap_num = 0;
276 if (esp_wifi_scan_get_ap_num(&ap_num) != ESP_OK)
277 {
279 }
280
281 uint16_t copy_count = ap_num;
282 if (copy_count > max_count)
283 {
284 copy_count = static_cast<uint16_t>(max_count);
285 }
286 if (copy_count > kMaxScanResults)
287 {
288 copy_count = kMaxScanResults;
289 }
290
291 wifi_ap_record_t ap_records[kMaxScanResults] = {};
292 if ((copy_count > 0U) &&
293 (esp_wifi_scan_get_ap_records(&copy_count, ap_records) != ESP_OK))
294 {
296 }
297
298 out_found = copy_count;
299 for (uint16_t i = 0; i < copy_count; ++i)
300 {
301 CopyToCharField(out_list[i].ssid, sizeof(out_list[i].ssid),
302 reinterpret_cast<const char*>(ap_records[i].ssid));
303 out_list[i].rssi = ap_records[i].rssi;
304 out_list[i].security = (ap_records[i].authmode == WIFI_AUTH_OPEN) ? Security::OPEN
305 : (ap_records[i].authmode == WIFI_AUTH_WPA2_PSK)
307 : Security::UNKNOWN;
308 }
309
310 return WifiError::NONE;
311}
Security
WiFi 安全类型 / WiFi security types.
@ WPA2_PSK
WPA2-PSK / WPA2-PSK.
@ OPEN
开放网络 / Open network
@ SCAN_FAILED
扫描失败 / Scan failed

◆ UnregisterHandlers()

void LibXR::ESP32WifiClient::UnregisterHandlers ( )
private

Definition at line 398 of file esp_wifi_client.cpp.

399{
400 if ((wifi_connected_handler_ == nullptr) && (wifi_disconnected_handler_ == nullptr) &&
401 (got_ip_handler_ == nullptr) && (lost_ip_handler_ == nullptr))
402 {
403 handlers_registered_ = false;
404 return;
405 }
406
407 if (wifi_connected_handler_ != nullptr)
408 {
409 (void)esp_event_handler_instance_unregister(WIFI_EVENT, WIFI_EVENT_STA_CONNECTED,
410 wifi_connected_handler_);
411 wifi_connected_handler_ = nullptr;
412 }
413 if (wifi_disconnected_handler_ != nullptr)
414 {
415 (void)esp_event_handler_instance_unregister(WIFI_EVENT, WIFI_EVENT_STA_DISCONNECTED,
416 wifi_disconnected_handler_);
417 wifi_disconnected_handler_ = nullptr;
418 }
419 if (got_ip_handler_ != nullptr)
420 {
421 (void)esp_event_handler_instance_unregister(IP_EVENT, IP_EVENT_STA_GOT_IP,
422 got_ip_handler_);
423 got_ip_handler_ = nullptr;
424 }
425 if (lost_ip_handler_ != nullptr)
426 {
427 (void)esp_event_handler_instance_unregister(IP_EVENT, IP_EVENT_STA_LOST_IP,
428 lost_ip_handler_);
429 lost_ip_handler_ = nullptr;
430 }
431 handlers_registered_ = false;
432}

Field Documentation

◆ connected_

bool LibXR::ESP32WifiClient::connected_ = false
private

是否连接 / Whether WiFi is connected

Definition at line 66 of file esp_wifi_client.hpp.

◆ enabled_

bool LibXR::ESP32WifiClient::enabled_ = false
private

是否启用 / Whether WiFi is enabled

Definition at line 64 of file esp_wifi_client.hpp.

◆ got_ip_

bool LibXR::ESP32WifiClient::got_ip_ = false
private

是否获取 IP / Whether IP is acquired

Definition at line 67 of file esp_wifi_client.hpp.

◆ got_ip_handler_

esp_event_handler_instance_t LibXR::ESP32WifiClient::got_ip_handler_ = nullptr
private

Definition at line 71 of file esp_wifi_client.hpp.

◆ handlers_registered_

bool LibXR::ESP32WifiClient::handlers_registered_ = false
private

Definition at line 65 of file esp_wifi_client.hpp.

◆ init_ok_

bool LibXR::ESP32WifiClient::init_ok_ = false
private

Definition at line 63 of file esp_wifi_client.hpp.

◆ ip_str_

char LibXR::ESP32WifiClient::ip_str_[16] = {}
private

当前 IP 字符串 / Current IP string

Definition at line 68 of file esp_wifi_client.hpp.

68{};

◆ is_initialized_

bool LibXR::ESP32WifiClient::is_initialized_
inlinestaticprivate
Initial value:
=
false

ESP 网络是否已初始化 / Netif initialized.

Definition at line 59 of file esp_wifi_client.hpp.

◆ lost_ip_handler_

esp_event_handler_instance_t LibXR::ESP32WifiClient::lost_ip_handler_ = nullptr
private

Definition at line 72 of file esp_wifi_client.hpp.

◆ netif_

esp_netif_t* LibXR::ESP32WifiClient::netif_ = nullptr
inlinestaticprivate

ESP 默认 netif 对象 / Default netif.

Definition at line 61 of file esp_wifi_client.hpp.

◆ semaphore_

LibXR::Semaphore LibXR::ESP32WifiClient::semaphore_
private

状态同步信号量 / Event wait semaphore

Definition at line 74 of file esp_wifi_client.hpp.

◆ wifi_connected_handler_

esp_event_handler_instance_t LibXR::ESP32WifiClient::wifi_connected_handler_ = nullptr
private

Definition at line 69 of file esp_wifi_client.hpp.

◆ wifi_disconnected_handler_

esp_event_handler_instance_t LibXR::ESP32WifiClient::wifi_disconnected_handler_ = nullptr
private

Definition at line 70 of file esp_wifi_client.hpp.


The documentation for this class was generated from the following files: