当前位置: 首页 > news >正文

ESP8266-01S、手机、STM32连接

1、ESP8266-01S的工作原理

1.1、AP和STA

ESP8266-01S为WIFI的透传模块,主要模式如下图:

上节说到,我们需要用到AT固件进行局域网应用(ESP8266连接的STM32和手机进行连接)。

  1. ESP8266为一个WiFi透传模块,和蓝牙透传模块具有主从两种工作模式一样,也具有两种工作模式:STA模式(Station)和AP模式(Access Point),一般WiFi模块还会有一个STA+AP模式,即可以在两种模式下切换的状态。
  2. AP模式下,WiFi模块产生热点,提供无线接入服务,允许其它无线设备接入,提供数据访问,一般的无线路由/网桥工作在该模式下。该模式对应TCP传输协议中的服务端(TCP Server)。
  3. STA模式下,WiFi模块为连接到无线网络的终端(站点),可以连接到AP,一般无线网卡工作在STA模式下。该模式对应TCP传输协议中的客户端(TCP Client)。

1.2、TCP/UDP/透传的概念,以及他们之间的不同点和相同点

TCP:

  1. TCP是一种面向连接的,提供可靠交付服务和全双工通信的,基于字节流的端到端的传输层通信协议。
  2. TCP在传输数据之前必须先建立连接,数据传输结束后要释放连接。
  3. 每一条TCP连接只能有2个端点,故TCP不提供广播或多播服务。
  4. TCP提供可靠交付,通过TCP连接传输的数据,无差错、不丢失、不重复、并且按序到达。
  5. TCP是面向字节流的。虽然应用进程和TCP的交互是一次一个数据块(大小不等),但TCP把应用程序交下来的数据看成仅仅是一连串的无结构的字节流。TCP并不知道所传输的字节流的含义。


UDP:

  1. UDP是一种无连接的,尽最大努力交付的,基于报文的端到端的传输层通信协议。
  2. UDP,在发送数据之前不需要建立连接。
  3. UDP不保证可靠交付,主机不需要位置复杂的连接状态。
  4. UDP是面向报文的。UDP对应用层交下来的报文,既不合并,也不拆分,而是保留这些报文的的边界,即应用层交给UDP多长的报文,UDP就照样发送,即一次发送一个报文。在接收端,UDP一次交付一个完整的报文。
  5. UDP没有拥塞控制,网络出现的拥塞不会使源主机的发送速率降低。
  6. UDP支持一对一、一对多、多对一和多对多的交互通信。
  7. UDP的首部开销小,只有8个字节,比TCP的20个字节的首部要短。


透传:

  1. 透传,又称透明传输,具体来说就是“输入即输出(如从WiFi模块串口输入的字符会透传到服务器端)”,数据不改变,不同协议之间的转换(如串口到WiFi、蓝牙等)由模块完成。使用者无需关心内部具体实现,因此模块对于使用者是“透明的”、似乎不存在的(因为可无视中间的实现原理)。一个高度封装的模块,应该隐藏内部实现细节,仅对外提供使用接口

1.3、固件

固件:

固件是写入存储器中的程序,在单片机中就是写到Flash中的程序。即烧写进程序的flash(ROM),硬件根据该固件运行。

1.4、连接方式

 2、AT指令原理和配置

esp8266-01s在烧入固件后根据固件运行,固件中固定有配置和反馈指令,对其通过串口发送对应的指令,esp8266-01s会进行响应的配置。所以固件要根据自己的实际情况进行选择。你发对应指令,模块就会做相应的工作。

使用 AT 指令配置 ESP8266

通过 AT 指令,您可以对 ESP8266 进行各种配置,包括 Wi-Fi 连接、服务器设置等。以下是常用的 AT 指令以及如何使用它们配置 ESP8266 的步骤。

2.1、准备工作
  • 硬件连接:

    • 将 ESP8266 模块与 USB 转 TTL 适配器连接。
    • 确保正确接线(TX 到 RX,RX 到 TX,VCC 接 3.3V,GND 接地)。
  • 环境准备:

    • 使用串口工具(如 PuTTY、CoolTerm 或 Arduino Serial Monitor)打开串口通讯。
2.2、配置步骤AP模式
2.2.1 建立AP------------------------------------------------------------------------------------------------
1) 测试连接,串口对esp8266进行发送
AT
  • 如果返回 OK,表示与 ESP8266 的串口连接正常。

2) 查看固件版本
AT+GMR
  • 返回当前固件信息。

3) 设置工作模式
  • STA 模式(连接 Wi-Fi):
AT+CWMODE=1
  • AP 模式(创建热点):

AT+CWMODE=2
  • 混合模式(同时作为热点和客户端):
AT+CWMODE=3 
  • 查看工作模式
AT+CWMODE?
4) 设置AP名称

AT+CWSAP="Your_AP_Name","Your_Password",5,3

  • Your_AP_Name: 自定义的热点名称。
  • Your_Password: 热点的 Wi-Fi 密码(8 到 64 个字符)。
  • 5: 信道,值从 1 到 13。选择一个不冲突的信道。
  • 3: 安全模式(0:开放,1:WEP,2:WPA-PSK,3:WPA2-PSK,4:WPA/WPA2-PSK)。

5). 启动 AP
  • 设置 AP 后立即启动:
    • 上述 AT+CWSAP 指令执行后,ESP8266 会自动启动您配置的 AP。
6)获取 AP 配置信息
  • 查看当前 AP 配置:

AT+CWSAP?

7) 关闭 AP
  • 关闭当前 AP:

AT+CWQAP

8)查看当前连接状态
  • 检查已连接的客户端:

AT+CIPSTAMAC?
  • 用于获取已连接设备的 MAC 地址。
9)查看已接入设备的IP信息

AT+CWLIF

10)获取本设备IP

AT+CIFSR

2.2.2、Server 方法收发(可连接多设备)-----------------------------------------------------------------
1)、开启多连接模式

AT+CIPMUX=1

0-单路连接模式,1-多路连接模式(Server模式)

2)、创建服务器

AT+CIPSERVER=1,8080

  • 0-关闭 server 模式,1-开启 server 模式
  • 端口号,缺省值为 333

(1) AT+ CIPMUX=1 时才能开启服务器;关闭 server 模式需要重启

(2)开启 server 后自动建立 server 监听,当有 client 接入会自动按顺序占用一个连接。

3)关闭连接,关闭 server 模式需要重启,重启使用AT+ CIPMUX=1,重启后创建服务器AT+CIPSERVER=1,8080(例如)

AT+CIPSERVER=0

关闭服务器

 通过 fireTools.exe连接

串口助手 软件工具等
链接:百度网盘 请输入提取码    提取码:3p7y

可以看到连接失败,ESP8266默认ip为192.168.4.1,通过指令AT+CIFSR可以查看ESP8266自身的IP

需要设置超时时间,否则无数据时会超时自动断连,断联后需要重开服务器:需要再发一遍

AT+CIPMUX=1,AT+CIPSERVER=1,8080

4)设置超时时间s为单位,(开启服务器后才能设置)

AT+CIPSTO=2880

服务器超时时间,0~2880,单位为 s

5)然后电脑连接ESP8266-01S

此处网络为配置AP时设置的名称和密码,我们此处举例为ESP_01S;12345678,电脑连接模块的WIFI,然后通过 fireTools.exe调试助手连接TPC服务器(模块)

串口助手 软件工具等(下载工具),在TCP网络调试菜单进行调试
链接:百度网盘 请输入提取码    提取码:3p7y

协议类型表示上位机使用端的类型,为客户机;服务器ip即esp8266-01s的ip,默认为192.168.4.1,端口为自己配置的8080。esp8266的配置可通过AT+CWSAP?命令查看,esp8266的IP可通过AT+CIFSR查看。

如图,连接和断连都会显示

6)查看当前的设备

AT+CIPSTATUS

返回:STATUS: + CIPSTATUS:,,,,

  • :连接的 id 号 0-4
  • :字符串参数,类型 TCP 或 UDP
  • :字符串参数,IP 地址
  • :端口号
  • : 0-本模块做 client 的连接,1-本模块做 server 的连接

7)向连接设备发送数据

AT+CIPSEND=0,6(设置指令) (通过上一条指令 AT+CIPSTATUS 得知 ID=0)

1)单路连接时(+CIPMUX=0),指令为:AT+CIPSEND=

2)多路连接时(+CIPMUX=1) (Server模式),指令为:AT+CIPSEND= 0,6

多路连接参数1:0表示多路连接的设备0

多路连接参数2:6表示向指定设备发送6Byte数据,若发送字节数小于6,则在发送数据结尾每次会自动补充0D 0A,直到足够6Byte。若发送字节数大于6,则截取前6BYTE。最大长度为 2048。

ESP8266收到此命令后先换行返回”>”,然后开始接收串口数据

1是电脑调试助手发送给ESP8266的数据,发了两次,

发送完毕ESP826601S会返回Recv 6 bytes SEND OK,如果未建立连接或连接被断开,返回 ERROR

8)接收数据

从设备(电脑模拟的),可直接发送数据,接收到

发送接收也可以使用ASIIC,一个汉字占2BYTE(好像是)

2.2.3 Client收发数据方法-----------------------------------------------------------------------------------------
1)关闭Server服务器(不管之前开没开启过,都可以走一下这个流程)

AT+CIPSERVER=0

指令:AT+CIPSERVER=[,]                 

说明::0-关闭 server 模式,1-开启 server 模式

:端口号,缺省值为 333

响应:OK

说明:(1) AT+ CIPMUX=1 时才能开启服务器;关闭 server 模式需要重启

(2)开启 server 后自动建立 server 监听,当有 client 接入会自动按顺序占用一个连

接。

AT+RST重启一下

2)使用其他设备或调试助手创建服务器,示例使用fireTools.exe

3)开启多路连接模式(一个客户机(esp826601s)可以连接多个服务器)

AT+CIPMUX=1

0-单路连接模式,1-多路连接模式

4)建立TCP连接

AT+CIPSTART=0,"TCP","192.168.4.2",8080

表示建立id为0的TCP连接,后面是服务器ip和端口号

指令:

1)单路连接时(+CIPMUX=0),指令为:AT+CIPSTART= ,,

2)多路连接时(+CIPMUX=1),指令为:AT+CIPSTART=,,,

响应:

如果格式正确且连接成功,返回 OK,否则返回 ERROR

如果连接已经存在,返回 ALREAY CONNECT

说明:

0-4,连接的 id 号

字符串参数,表明连接类型,”TCP”-建立 tcp 连接,”UDP”-建立 UDP 连接

字符串参数,远程服务器 IP 地址

远程服务器端口号

5)向服务器发送数据

AT+CIPSEND=0,10(通过上一条指令 AT+CIPSTART 设置为 ID=0)

指令:

1)单路连接时(+CIPMUX=0),指令为:AT+CIPSEND=

2)多路连接时(+CIPMUX=1) ,指令为: AT+CIPSEND=  , 

响应:

收到此命令后先换行返回”>”,然后开始接收串口数据

每次发送会自动补0D、0A,当数据长度满 length 时发送数据。

如果未建立连接或连接被断开,返回 ERROR

如果数据发送成功,返回 SEND OK

说明:

需要用于传输连接的 id 号 0-4

数字参数,表明发送数据的长度,最大长度为 2048

2.3. 其他常用指令
  • 重启 ESP8266
AT+RST
  • 设置无回显模式(有时需要):
ATE0
  • 恢复工厂设置

AT+RESTORE

二、实际操作

1、ESP8266配置

1.1使用安可信助手连接ESP8266模块(方法见上一文章,需要烧写固件等)

1.2指令配置

1、AT,测试


2、AT+CWMODE=2,AP模式配置

3、AT+RST,复位

4、AT+CWSAP="Your_AP_Name","Your_Password",1,3      ,配置ESP8266的WIFI热点名称和密码

  • Your_AP_Name: 自定义的热点名称。
  • Your_Password: 热点的 Wi-Fi 密码(8 到 64 个字符)。
  • 5: 信道,值从 1 到 13。选择一个不冲突的信道。
  • 3: 安全模式(0:开放,1:WEP,2:WPA-PSK,3:WPA2-PSK,4:WPA/WPA2-PSK)。

5、AT+CIPMUX=1 ,开启多连接模式

6、AT+CIPSERVER=1,a (为端口号,默认333),ESP8266-01S作为server进行连接

  • 0-关闭 server 模式,1-开启 server 模式
  • 端口号,缺省值为 333

9、完成以上指令后,基本上就设置完成了,当用手机app连接时,app随便下一个网络调试助手就行,选择TCP客户端,连接时需要8266模块的ip,和之前设置的端口,默认端口为333,模块的ip可以通过指令查询:AT+CIFSR

一般默认192.168.4.1

2、手机作为客户端进行连接,当用手机app连接时,app随便下一个网络调试助手就行

若与与手机端在一定时间内不通信,则模块会断开此连接,默认为3分钟。

2.1、设置超时时间

2.2、连接

手机直接连接刚才创建的服务器,和指定的端口,通过

多路连接,连接的通断会显示,好像是0-4通道,默认从0开始

通过指令可以查看当前连接的设备通道和ip和端口等。

AT+CIPSTATUS

返回:STATUS: + CIPSTATUS:,,,,

  • :连接的 id 号 0-4
  • :字符串参数,类型 TCP 或 UDP
  • :字符串参数,IP 地址
  • :端口号
  • : 0-本模块做 client 的连接,1-本模块做 server 的连接​​​​​​​​​​​​​​

2.3、收发

手机直接发送,ESP826601S可以接收到

ESP接收到数据

ESP826601S发送:

 AT+CIPSEND=0,6

多路连接参数1:0表示多路连接的设备0

多路连接参数2:6表示向指定设备发送6Byte数据,若发送字节数小于6,则在发送数据结尾每次会自动补充0D 0A,直到足够6Byte。若发送字节数大于6,则截取前6BYTE。最大长度为 2048。下图发送的两次1。

ESP8266收到此命令后先换行返回”>”,然后开始接收串口数据

1是电脑调试助手发送给ESP8266的数据,发了两次,

发送完毕ESP826601S会返回Recv 6 bytes SEND OK,如果未建立连接或连接被断开,返回 ERROR

测试完成表明连接已经成功,功能无异常!

三、ESP8266-01S----STM32----手机

以STM32串口3为例

  • 串口3,esp8266模块连接串口3资源
  • 定时器5,为什么使用定时器?在esp8266接受数据产生中断时,因为我们并不知道接收的有多少数据,什么时候接收结束,所以采用一个定时器,当定时器清零前下一个数据到来表示是连续数据,重置定时器,若定时器时间到了还没有接收到下一条数据则表示数据接收完成,可进入定时器中断服务程序进行数据处理,添加接收完成标志位,如下代码

定时器5初始化:


#include "timer5.h"
extern u8 start3;//串口中断接收完成标志//定时器5中断服务程序		    
void TIM5_IRQHandler(void)
{ 	if (TIM_GetITStatus(TIM5, TIM_IT_Update) != RESET)//是更新中断{	 			   start3=1;	//标记串口数据接收完成TIM_ClearITPendingBit(TIM5, TIM_IT_Update  );  //清除TIM5更新中断标志    TIM_Cmd(TIM5, DISABLE);  //关闭TIM5}	    
}//通用定时器中断初始化
//这里始终选择为APB1的2倍,而APB1为36M
//arr:自动重装值。
//psc:时钟预分频数		 
void TIM5_Int_Init(u16 arr,u16 psc)
{	NVIC_InitTypeDef NVIC_InitStructure;TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM5, ENABLE);//TIM7时钟使能    //定时器TIM7初始化TIM_TimeBaseStructure.TIM_Period = arr; //设置在下一个更新事件装入活动的自动重装载寄存器周期的值	TIM_TimeBaseStructure.TIM_Prescaler =psc; //设置用来作为TIMx时钟频率除数的预分频值TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //设置时钟分割:TDTS = Tck_timTIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIM向上计数模式TIM_TimeBaseInit(TIM5, &TIM_TimeBaseStructure); //根据指定的参数初始化TIMx的时间基数单位TIM_ITConfig(TIM5,TIM_IT_Update,ENABLE ); //使能指定的TIM5中断,允许更新中断NVIC_InitStructure.NVIC_IRQChannel = TIM5_IRQn;NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ;//抢占优先级0NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;		//子优先级1NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;			//IRQ通道使能NVIC_Init(&NVIC_InitStructure);	//根据指定的参数初始化VIC寄存器}

串口3初始化:

//初始化IO 串口3
//bound:波特率	  void usart3_init(u32 bound)
{  USART_InitTypeDef USART_InitStructure;  NVIC_InitTypeDef NVIC_InitStructure;   GPIO_InitTypeDef GPIO_InitStructure;    //声明一个结构体变量,用来初始化GPIO  //使能串口的RCC时钟  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB , ENABLE); //使能UART3所在GPIOB的时钟  RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE);  //串口使用的GPIO口配置  // Configure USART3 Tx (PB.10) as alternate function push-pull  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;  GPIO_Init(GPIOB, &GPIO_InitStructure); // Configure USART3 Rx (PB.11) as input floating    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;  GPIO_Init(GPIOB, &GPIO_InitStructure);   //串口中断配置  //Configure the NVIC Preemption Priority Bits     // NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);  // Enable the USART3 Interrupt   NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn;   NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=1 ;//抢占优先级3NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;        //子优先级3NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;  NVIC_Init(&NVIC_InitStructure);  //配置串口  USART_InitStructure.USART_BaudRate = bound;  USART_InitStructure.USART_WordLength = USART_WordLength_8b;  USART_InitStructure.USART_StopBits = USART_StopBits_1;  USART_InitStructure.USART_Parity = USART_Parity_No;  USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;  USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;  // Configure USART3   USART_Init(USART3, &USART_InitStructure);//配置串口3 // Enable USART3 Receive interrupts 使能串口接收中断  USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);  // Enable the USART3   USART_Cmd(USART3, ENABLE);//使能串口3  USART_ClearFlag(USART3, USART_FLAG_TC);		TIM5_Int_Init(1000-1,8400-1);		//100ms中断TIM_Cmd(TIM5, DISABLE); //关闭定时器7}

串口3中断处理函数:

//定义接收数组,接收缓冲,最大USART3_MAX_RECV_LEN个字节,宏定义为400
unsigned char USART3_RX_BUF[USART3_MAX_RECV_LEN]; 				
u16 USART3_RX_STA=0;  //数组标志位
u8 start3=0; //接收状态标志位
void USART3_IRQHandler(void)
{u8 res;	 if(USART_GetITStatus(USART3, USART_IT_RXNE) != RESET)//接收到数据{	 res =USART_ReceiveData(USART3);	TIM_SetCounter(TIM5,0);//计数器清空        				 		TIM_Cmd(TIM5, ENABLE);  //使能定时器5  		USART3_RX_BUF[USART3_RX_STA]=res;		//记录接收到的值USART3_RX_STA++; 						 
}  
}

串口3发送字符串函数:

//串口3,printf 函数
//确保一次发送数据不超过USART3_MAX_SEND_LEN字节
void u3_printf(char* fmt,...)  
{  u16 i,j;va_list ap;va_start(ap,fmt);vsprintf((char*)USART3_TX_BUF,fmt,ap);va_end(ap);i=strlen((const char*)USART3_TX_BUF);//此次发送数据的长度for(j=0;j<i;j++)//循环发送数据{while(USART_GetFlagStatus(USART3,USART_FLAG_TC)==RESET);  //等待上次传输完成 USART_SendData(USART3,(uint8_t)USART3_TX_BUF[j]); 	 //发送数据到串口3 }}

esp8266初始化:

//清空每次中断接收完成后的数组
void Clear_Buffer(void)//清空缓存
{u8 i;for(i=0;i<=USART3_RX_STA;i++)USART3_RX_BUF[i]=0;//缓存USART3_RX_STA=0;Delay_ms(100);
}//模块初始化
void esp8266_start_trans(void)
{esp8266_send_cmd("AT+CWMODE=2","OK",50);Clear_Buffer();//Wifi模块重启esp8266_send_cmd("AT+RST","OK",20);Delay_ms(1000);         //延时3S等待重启成功Delay_ms(1000);Delay_ms(1000);	//AP模式esp8266_send_cmd("AT+CWSAP=\"想学ESP8266吗\",\"12345678\",11,3","OK",200);Clear_Buffer();esp8266_send_cmd("AT+CIPMUX=1","OK",20);Clear_Buffer();esp8266_send_cmd("AT+CIPSERVER=1","OK",200);Clear_Buffer();}	u8 esp8266_send_cmd(u8 *cmd,u8 *ack,u16 waittime)
{u8 res=0; USART3_RX_STA=0;u3_printf("%s\r\n",cmd);	//发送命令printf("%s\r\n",cmd);Delay_ms(waittime);if(strstr((const char*)USART3_RX_BUF,"OK")){Uart1_SendStr((char*)USART3_RX_BUF);}return res;
}

主函数main:

extern u8 start3;extern unsigned char USART3_RX_BUF[USART3_MAX_RECV_LEN]; int main ( void )
{/* 初始化 */USART1_Config ();usart3_init(115200);  CPU_TS_TmrInit();	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_3);  	esp8266_start_trans();                                                      while ( 1 ){if(start3==1)//接收中断完成标志位{//判断接收的数据是否为密码数据,自己设置就行if(strstr((const char*)USART3_RX_BUF,"12345678")){		printf("开门成功\r\n");	}								if(!strstr((const char*)USART3_RX_BUF,"12345678")){printf("密码错误\r\n");	}				Clear_Buffer();		start3=0;}}
}

相关文章:

ESP8266-01S、手机、STM32连接

1、ESP8266-01S的工作原理 1.1、AP和STA ESP8266-01S为WIFI的透传模块&#xff0c;主要模式如下图&#xff1a; 上节说到&#xff0c;我们需要用到AT固件进行局域网应用&#xff08;ESP8266连接的STM32和手机进行连接&#xff09;。 ESP8266为一个WiFi透传模块&#xff0c;和…...

Web开发 -前端部分-CSS-2

一 长度单位 代码实现&#xff1a; <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document<…...

【QT用户登录与界面跳转】

【QT用户登录与界面跳转】 1.前言2. 项目设置3.设计登录界面3.1 login.pro参数3.2 界面设置3.2.1 登录界面3.2.2 串口主界面 4. 实现登录逻辑5.串口界面6.测试功能7.总结 1.前言 在Qt应用程序开发中&#xff0c;实现用户登录及界面跳转功能是构建交互式应用的重要步骤之一。下…...

记录一次关于spring映射postgresql的jsonb类型的转化器事故,并使用hutool的JSONArray完成映射

事件的起因是这样的&#xff0c;那次事故发生的起因是因为WebFlux和postgreSQL去重新做鱼皮的鱼图图项目&#xff08;鱼图图作业&#xff09;。 在做到picture表的时候&#xff0c;发现postgreSQL中有个jsonb的类型可以更好的支持json数组。 出于锻炼新技术的目的&#xff0c;…...

基于 HTML5 Canvas 制作一个精美的 2048 小游戏--day2

为了使 2048 游戏的设计更加美观和用户友好&#xff0c;我们可以进行以下几项优化&#xff1a; 改善颜色方案&#xff1a;使用更温馨的颜色组合。添加动画效果&#xff1a;为方块的移动和合并添加渐变效果。优化分数显示&#xff1a;在分数增加时使用动画效果。 以下是改进后…...

Django框架:python web开发

1.环境搭建&#xff1a; &#xff08;a&#xff09;开发环境&#xff1a;pycharm &#xff08;b&#xff09;虚拟环境&#xff08;可有可无&#xff0c;优点&#xff1a;使用虚拟环境可以把使用的包自动生成一个文件&#xff0c;其他人需要使用时可以直接选择导入包&#xff…...

MySQL、HBase、ES的特点和区别

MySQL&#xff1a;关系型数据库&#xff0c;主要面向OLTP&#xff0c;支持事务&#xff0c;支持二级索引&#xff0c;支持sql&#xff0c;支持主从、Group Replication架构模型&#xff08;本文全部以Innodb为例&#xff0c;不涉及别的存储引擎&#xff09;。 HBase&#xff1…...

联发科MTK6762/MT6762安卓核心板_4G智能模块应用

MT6762安卓核心板是一款工业级高性能、可运行 android9.0 操作系统的 4G智能模块。MT6762平台打造具备 AI 体验、先进双摄像头拍摄效果且具备丰富连接功能的智能手机主板。 MT6762安卓核心板 是一款髙性能低功耗的 4G 全网通安卓智能模块。此模块支持 2G/3G/4G 移动&#xff0c…...

Windows7系统下载安装Source Code Pro字库

Source Code Pro字库介绍 Source Code Pro是由Adobe推出的一款专为代码展示和编写设计的开源等宽字体‌。它不仅在编程社区中广受好评&#xff0c;还被广泛应用于各种编辑器环境中&#xff0c;以提升代码的可读性和编程体验‌。 Source Code Pro的设计充分考虑了编程符号的呈…...

Navicat 17 功能简介 | 商业智能 BI

Navicat 17 功能简介 | 商业智能BI 随着 17 版本的发布&#xff0c;Navicat 也带来了众多的新特性&#xff0c;包括兼容更多数据库、全新的模型设计、可视化智能 BI、智能数据分析、可视化查询解释、高质量数据字典、增强用户体验、扩展 MongoDB 功能、轻松固定查询结果、便捷U…...

C# winodw TableLayoutPanel 料盒生产状态UI自动生成

料盒生产状态UI自动生成&#xff0c;效果如下 以前公司项目的这些都是手动拖控件做的。每个设备的料盒数量不一样&#xff0c;层数不一样时都要发好几个小时去改相关细节和代码。上次改了一次。这个又来了。上次就有想法做成根据参数自动生成。但项目时间有限有没有去深入思路和…...

提示词的艺术----AI Prompt撰写指南(个人用)

提示词的艺术 写在前面 制定提示词就像是和朋友聊天一样&#xff0c;要求我们能够清楚地表达问题。通过这个过程&#xff0c;一方面要不断练习提高自己地表达能力&#xff0c;另一方面还要锻炼自己使用更准确精炼的语言提出问题的能力。 什么样的提示词有用&#xff1f; 有…...

哪些前端打印插件可以实现监听用户选择了打印还是取消

在前端实现监听用户是否选择了打印还是取消的功能&#xff0c;确实是一个挑战&#xff0c;因为浏览器的打印行为是通过原生对话框处理的&#xff0c;而这些对话框的行为无法直接被 JavaScript 控制或监听。不过&#xff0c;有一些插件和方法可以帮助你更接近这个目标&#xff1…...

【PyCharm】连接Jupyter Notebook

【PyCharm】相关链接 【PyCharm】连接 Git【PyCharm】连接Jupyter Notebook【PyCharm】快捷键使用【PyCharm】远程连接Linux服务器【PyCharm】设置为中文界面 【PyCharm】连接Jupyter Notebook PyCharm连接Jupyter Notebook的过程可以根据不同的需求分为 本地连接 和 远程连…...

【Linux系统编程】—— 深入理解Linux中的环境变量与程序地址空间

文章目录 环境变量常见的环境变量查看环境变量环境变量的修改与使用环境变量的组织⽅式环境变量的命令通过代码如何获取环境变量环境变量的继承 前言&#xff1a;在Linux系统中&#xff0c;环境变量和程序地址空间是系统管理和进程运行的重要组成部分。本文将详细探讨环境变量的…...

Spark常见面试题-部分待更新

1. 简述hadoop 和 spark 的不同点&#xff08;为什么spark更快&#xff09; Hadoop是一个分布式管理、存储、计算的生态系统&#xff0c;包括HDFS&#xff08;分布式文件系统&#xff09;、MapReduce&#xff08;计算引擎&#xff09;和YARN&#xff08;资源调度器&#xff09;…...

Android BitmapShader实现狙击瞄具十字交叉线准星,Kotlin

Android BitmapShader实现狙击瞄具十字交叉线准星&#xff0c;Kotlin <?xml version"1.0" encoding"utf-8"?> <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"xmlns:tools"http://schemas.android.…...

linux通过web向mac远程传输字符串,mac收到后在终端中直接打印。

要通过Web从Linux向Mac远程传输字符串&#xff0c;并在Mac的终端中直接打印&#xff0c;可以使用以下方法。这里假设Linux作为服务器&#xff0c;Mac作为客户端。 方法 1&#xff1a;使用Python的HTTP服务器 在Linux上启动一个简单的HTTP服务器&#xff0c;Mac通过curl获取字符…...

海云安开发者安全智能助手D10荣膺 “ AI标杆产品 ” 称号,首席科学家齐大伟博士入选2024年度 “ 十大杰出青年 ”

2024年12月27日&#xff0c;粤港澳大湾区AI领袖峰会在深圳成功举办&#xff0c;大会表彰了在人工智能技术创新、应用实践和产业发展等方面取得优异成绩的企业和个人&#xff0c;深圳海云安网络安全技术有限公司开发者安全智能助手D10荣膺“AI标杆产品”称号。同时&#xff0c;公…...

Spring Boot + Apache POI 实现 Excel 导出:BOM物料清单生成器(支持中文文件名、样式美化、数据合并)

目录 引言 Apache POI操作Excel的实用技巧 1.合并单元格操作 2.设置单元格样式 1. 创建样式对象 2. 设置边框 3. 设置底色 4. 设置对齐方式 5. 设置字体样式 6.设置自动换行 7. 应用样式到单元格 3. 定位和操作指定单元格 4.实现标签-值的形式 5.列宽设置 1. 设…...

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…...

【Java学习笔记】Arrays类

Arrays 类 1. 导入包&#xff1a;import java.util.Arrays 2. 常用方法一览表 方法描述Arrays.toString()返回数组的字符串形式Arrays.sort()排序&#xff08;自然排序和定制排序&#xff09;Arrays.binarySearch()通过二分搜索法进行查找&#xff08;前提&#xff1a;数组是…...

MFC内存泄露

1、泄露代码示例 void X::SetApplicationBtn() {CMFCRibbonApplicationButton* pBtn GetApplicationButton();// 获取 Ribbon Bar 指针// 创建自定义按钮CCustomRibbonAppButton* pCustomButton new CCustomRibbonAppButton();pCustomButton->SetImage(IDB_BITMAP_Jdp26)…...

循环冗余码校验CRC码 算法步骤+详细实例计算

通信过程&#xff1a;&#xff08;白话解释&#xff09; 我们将原始待发送的消息称为 M M M&#xff0c;依据发送接收消息双方约定的生成多项式 G ( x ) G(x) G(x)&#xff08;意思就是 G &#xff08; x ) G&#xff08;x) G&#xff08;x) 是已知的&#xff09;&#xff0…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端

&#x1f31f; 什么是 MCP&#xff1f; 模型控制协议 (MCP) 是一种创新的协议&#xff0c;旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议&#xff0c;它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...

MVC 数据库

MVC 数据库 引言 在软件开发领域,Model-View-Controller(MVC)是一种流行的软件架构模式,它将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller)。这种模式有助于提高代码的可维护性和可扩展性。本文将深入探讨MVC架构与数据库之间的关系,以…...

oracle与MySQL数据库之间数据同步的技术要点

Oracle与MySQL数据库之间的数据同步是一个涉及多个技术要点的复杂任务。由于Oracle和MySQL的架构差异&#xff0c;它们的数据同步要求既要保持数据的准确性和一致性&#xff0c;又要处理好性能问题。以下是一些主要的技术要点&#xff1a; 数据结构差异 数据类型差异&#xff…...

Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)

引言&#xff1a;为什么 Eureka 依然是存量系统的核心&#xff1f; 尽管 Nacos 等新注册中心崛起&#xff0c;但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制&#xff0c;是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...

数据库分批入库

今天在工作中&#xff0c;遇到一个问题&#xff0c;就是分批查询的时候&#xff0c;由于批次过大导致出现了一些问题&#xff0c;一下是问题描述和解决方案&#xff1a; 示例&#xff1a; // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...

QT: `long long` 类型转换为 `QString` 2025.6.5

在 Qt 中&#xff0c;将 long long 类型转换为 QString 可以通过以下两种常用方法实现&#xff1a; 方法 1&#xff1a;使用 QString::number() 直接调用 QString 的静态方法 number()&#xff0c;将数值转换为字符串&#xff1a; long long value 1234567890123456789LL; …...