ESP8266-AP模式
首先介绍一下什么叫AP模式,将8266作为路由器类似使用,就像手机热点一样,提供给另外的用户接入使用。但是没有网络使用的,也就是你不能连接进行上网的。也有人利用这个功能做WiFi广告机,也就是制造虚拟的多个的WiFi名称,当然他的作用是物联网开发使用的。其他后续讲解。
#define ProjectName "AP_Mode" // 工程名宏定义
#define ESP8266_AP_SSID "ESP8266_JX" // 创建的WIFI名
#define ESP8266_AP_PASS "jixiaoxin" // 创建的WIFI密码
//==================================================================================
// 全局变量
//==================================================================================
os_timer_tOS_Timer_1; // 软件定时器结构体
//==================================================================================
// 毫秒延时函数
//===========================================
voidICACHE_FLASH_ATTRdelay_ms(u32 C_time)
{ for(;C_time>0;C_time--)
os_delay_us(1000);
}
//===========================================
// 初始化ESP8266_AP模式
//============================================================================================
voidICACHE_FLASH_ATTRESP8266_AP_Init_JX()
{
structsoftap_config AP_Config; // AP参数结构体
wifi_set_opmode(0x02); // 设置为AP模式,并保存到//Flash 0x01为STA模式 0x02为AP模式
// 结构体赋值(注意:【服务集标识符/密码】须设为字符串形式)
//--------------------------------------------------------------------------------------
os_memset(&AP_Config, 0,sizeof(structsoftap_config));
//
AP参数结构体= 0 将structsoftap_config赋值为0
//os_memset(void *s,int ch, size_t n)
//void *s:内存块指针//• int ch:填充值//• size_t n:填充⼤大⼩小
//实例os_memset(buffer,
0, sizeof(buffer));
os_strcpy(AP_Config.ssid,ESP8266_AP_SSID); // 设置SSID(将字符串复制到ssid数组)
//strcpy函数是复制字符串的,接受两个参数,一个是被复制字符串,另一个新字符串
//具体可以百度c语言中strcpy的用法
os_strcpy(AP_Config.password,ESP8266_AP_PASS); // 设置密码(将字符串复制到password数组)
AP_Config.ssid_len=os_strlen(ESP8266_AP_SSID); // 设置ssid长度(和SSID的长度一致)
AP_Config.channel=1; // 通道号1~13
AP_Config.authmode=AUTH_WPA2_PSK; // 设置加密模式
AP_Config.ssid_hidden=0; // 不隐藏SSID
AP_Config.max_connection=4; // 最大连接数
AP_Config.beacon_interval=100; // 信标间隔时槽100~60000 ms
wifi_softap_set_config(&AP_Config); // 设置soft-AP,并保存到Flash
// wifi_softap_set_config 设置 Wi-Fi SoftAP 接⼝口配置,并保存到 Flash
//wifi_softap_set_config
(struct softap_config *config)
}
//============================================================================================
// 定时的回调函数
//=====================================================================================================
voidICACHE_FLASH_ATTROS_Timer_1_cb(void)
{
structip_info ST_ESP8266_IP; // IP信息结构体
u8 ESP8266_IP[4]; // 点分十进制数组形式保存IP
// 查询并打印ESP8266的工作模式
//---------------------------------------------------------------------
switch(wifi_get_opmode()) // 输出工作模式
{
case0x01: os_printf("\nESP8266_Mode =
Station\n"); break;
case0x02: os_printf("\nESP8266_Mode =
SoftAP\n"); break;
case0x03: os_printf("\nESP8266_Mode =
Station+SoftAP\n"); break;
}
// 获取ESP8266_AP模式下的IP地址
//【AP模式下,如果开启DHCP(默认),并且未设置IP相关参数,ESP8266的IP地址=192.168.4.1】
//-----------------------------------------------------------------------------------
wifi_get_ip_info(SOFTAP_IF,&ST_ESP8266_IP); // 参数2:IP信息结构体指针
// ESP8266_AP_IP.ip.addr==32位二进制IP地址,将它转换为点分十进制的形式
//------------------------------------------------------------------------------------------
ESP8266_IP[0] = ST_ESP8266_IP.ip.addr; // 点分十进制IP的第一个数 <==> addr低八位
ESP8266_IP[1] = ST_ESP8266_IP.ip.addr>>8; // 点分十进制IP的第二个数 <==> addr次低八位
ESP8266_IP[2] = ST_ESP8266_IP.ip.addr>>16; // 点分十进制IP的第三个数 <==> addr次高八位
ESP8266_IP[3] = ST_ESP8266_IP.ip.addr>>24; // 点分十进制IP的第四个数 <==> addr高八位
// 打印ESP8266的IP地址
//-----------------------------------------------------------------------------------------------
os_printf("ESP8266_IP = %d.%d.%d.%d\n",ESP8266_IP[0],ESP8266_IP[1],ESP8266_IP[2],ESP8266_IP[3]);
OLED_ShowIP(24,2,ESP8266_IP); // 显示ESP8266的IP地址
// 查询并打印接入此WIFI的设备数量
//-----------------------------------------------------------------------------------------
os_printf("Number of devices connected to this
WIFI = %d\n",wifi_softap_get_station_num());
}
//=====================================================================================================
// 软件定时器初始化(ms毫秒)
//=====================================================================================
voidICACHE_FLASH_ATTROS_Timer_1_Init_JX(u32 time_ms, u8 time_repetitive)
{
os_timer_disarm(&OS_Timer_1); // 关闭定时器
os_timer_setfn(&OS_Timer_1,(os_timer_func_t*)OS_Timer_1_cb, NULL); // 设置定时器
os_timer_arm(&OS_Timer_1, time_ms,time_repetitive); // 使能定时器
}
//=====================================================================================
//
user_init:entry of user application, init
user function here
//==================================================================================
voidICACHE_FLASH_ATTRuser_init(void)
{
uart_init(115200,115200); // 初始化串口波特率
os_delay_us(10000); // 等待串口稳定
os_printf("\r\n=================================================\r\n");
os_printf("\t Project:\t%s\r\n", ProjectName);
os_printf("\t SDK version:\t%s", system_get_sdk_version());
os_printf("\r\n=================================================\r\n");
// OLED初始化
//---------------------
OLED_Init(); // |
OLED_ShowString(0,0,"ESP8266 = AP"); // |
OLED_ShowString(0,2,"IP:"); // |
//---------------------
ESP8266_AP_Init_JX(); // 设置ESP8266_AP模式相关参数
OS_Timer_1_Init_JX(1000,1); // 1秒软件定时
// while(1) system_soft_wdt_feed(); //死循环,测试用
os_printf("\r\n-------------------- user_init
OVER --------------------\r\n");
}
//==================================================================================
/******************************************************************************
* FunctionName : user_rf_cal_sector_set
* Description : SDK just reversed 4 sectors, used for rf init data and paramters.
* We add this function to forceusers to set rf cal sector, since
* we don't know which sector isfree in user's application.
* sector map for last severalsectors : ABCCC
* A : rf cal
* B : rf init data
* C : sdk parameters
* Parameters : none
* Returns : rf cal sector
*******************************************************************************/
uint32ICACHE_FLASH_ATTRuser_rf_cal_sector_set(void)
{
enum flash_size_map size_map =
system_get_flash_size_map();
uint32 rf_cal_sec = 0;
switch (size_map) {
case FLASH_SIZE_4M_MAP_256_256:
rf_cal_sec = 128 - 5;
break;
case FLASH_SIZE_8M_MAP_512_512:
rf_cal_sec = 256 - 5;
break;
case FLASH_SIZE_16M_MAP_512_512:
case FLASH_SIZE_16M_MAP_1024_1024:
rf_cal_sec = 512 - 5;
break;
case FLASH_SIZE_32M_MAP_512_512:
case FLASH_SIZE_32M_MAP_1024_1024:
rf_cal_sec = 1024 - 5;
break;
case FLASH_SIZE_64M_MAP_1024_1024:
rf_cal_sec = 2048 - 5;
break;
case FLASH_SIZE_128M_MAP_1024_1024:
rf_cal_sec = 4096 - 5;
break;
default:
rf_cal_sec = 0;
break;
}
return rf_cal_sec;
}
voidICACHE_FLASH_ATTRuser_rf_pre_init(void){}