最近,托朋友用STM32F103评估板和迪文屏做了交互(@田),没写多少代码,就实现了一些简单常用的功能,还是很简单的!今天跟大家分享一下:

一、评估板使用说明
1.功能



图1:整体效果图


图2:MCU_KEY_LED


图3:MCU-STM32F103开发板


图4:按键及LED

注:可实现的功能:
a.通过屏上的图标来控制5路LED灯的状态(LED灯的开和关来表示状态),上电5路LED熄灭状态。
b. 通过评估板上的物理按键1,来控制亮屏和息屏,上电状态为亮屏状态。
c. 通过评估板上的物理按键2&3,来调节屏幕上的温度指数,上电初始值25度,以1为步长递增递减,最小0,最大255。
d. 通过评估板上的物理按键4,来控制音乐的播放和停止,上电音乐不播放。
e. 通过评估板上的物理按键5&6来调节音量的大小,上电音量值50,以10为步长递增递减,最小0,最大250。

2、需使用的工具
a.硬件:正点原子Mini STM32开发板(MCU为STM32F103RCT6,串口TTL电平)+面包板手工焊接5路LED和6路按键扩展。
b. 软件:STM32CubeMX+KEIL MDK5。
c.原理图:详见“硬件原理图”文件夹。
d.程序:工程文件在DGUS II工程文件夹中,下载DWIN_SET导入屏中即可。
STM32程序在“MCU_STM32F103RCT6程序”文件夹。(文件过大,感兴趣的可以给我留言)

二、硬件及软件介绍
1、硬件原理图:详见“硬件原理图”文件夹
(1)硬件接口定义:


(2)硬件原理图

图5:STM32F103原理图


图6:LED及KEY原理图

2.软件程序
界面工程文件在“DGUS_II工程”文件夹中。STM32程序在“MCU_STM32F103RCT6程序”文件夹中。
(1)界面工程
LED1图标:0X1000
LED1按键:0X1200
LED2图标:0X1001
LED2按键:0X1201
LED3图标:0X1002
LED3按键:0X1202
LED4图标:0X1003
LED4按键:0X1203
LED5图标:0X1004
LED5按键:0X1204
音量显示框地址:0X1210
温度显示框地址:0X1110

(2)MCU程序
1).main():硬件初始化,触摸屏初始化,按键扫描,接收触摸屏数据处理 int main(void) { uint8_t i; HAL_Init();
SystemClock_Config(); MX_GPIO_Init(); MX_USART1_UART_Init();while (1) {
HAL_UART_Receive_IT(&huart1,&usart1_data,1); if(UP_POWER_FLAG == 0)//上电初始化触摸屏 {
UP_POWER_FLAG =1; HMI_SEND_BUF[0] = TEMP; PLC_Data_Wr2HMI(0X1110,0,1); delay_ms(
100); HMI_SEND_BUF[0] = VOLUME; PLC_Data_Wr2HMI(0X1210,0,1);//ÒôÁ¿ÏÔʾ delay_ms(
100); WRITE_HMI(0X00A1,VOLUME,0x00,0,0,2);//ĬÈÏÒôÁ¿50 delay_ms(100); for(i=0;i<
5;i++) { HMI_SEND_BUF[i] = 0; } for(i=0;i<20;i++) { usart1_rxBuf[i] = 0x00; }
HMI_HANDLEFLAG =0; } if(PLAY ==1)//监测是否播放完音乐 { READ_HMI(0x00a1,1); delay_ms(100
);if(HMI_HANDLEFLAG) { if(usart1_rxBuf[8] == 0) { PLAY = 0; for(i=0;i<50;i++) {
usart1_rxBuf[i] =0x00; } usart1_counter = 0; } } } SCAN_KEY(0);//按键扫描 if
(HMI_HANDLEFLAG)//接收触摸屏数据处理 { HMI_HANDLEFLAG = 0; CLOSE_OPEN_IO(0x01);
CLOSE_OPEN_IO(0x02); CLOSE_OPEN_IO(0x03); CLOSE_OPEN_IO(0x04); CLOSE_OPEN_IO(
0x05); for(i=0;i<50;i++) { usart1_rxBuf[i] = 0x00; } usart1_counter = 0; } } 2
). PLC_Data_Wr2HMI ():数据写入触摸屏变量寄存器void PLC_Data_Wr2HMI(uint16_t
HMI_start_addr,uint16_t PLC_return_data_start_addr,uint8_t len) { uint8_t i;
usart1_txBuf[0]=0x5a; usart1_txBuf[1]=0xa5; usart1_txBuf[2]=len*2+3;
usart1_txBuf[3]=0x82; usart1_txBuf[4]=((uint8_t)(HMI_start_addr>>8))&0XFF;
usart1_txBuf[5]=(uint8_t)(HMI_start_addr&0XFF); for(i=0;i<len;i++) {
usart1_txBuf[i*2+6]=((HMI_SEND_BUF[i+PLC_return_data_start_addr] >>8)&0xff);
usart1_txBuf[i*2+7]=(HMI_SEND_BUF[i+PLC_return_data_start_addr] &0xff); }
HAL_UART_Transmit(&huart1, usart1_txBuf, len*2+6, 10);//串口发送 } 3). WRITE_HMI
():数据写入触摸屏寄存器void WRITE_HMI(uint16_t addr,uint8_t data1,uint8_t data2,uint8_t
data3,uint8_t data4,uint8_t len) { usart1_txBuf[0]=0x5a; usart1_txBuf[1]=0xa5;
usart1_txBuf[2]=len*2+3; usart1_txBuf[3]=0x82; usart1_txBuf[4]=(uint8_t)((addr>>
8)&0xff); usart1_txBuf[5]=(uint8_t)(addr&0xff); usart1_txBuf[6]=data1;
usart1_txBuf[7]=data2; usart1_txBuf[8]=data3; usart1_txBuf[9]=data4;
HAL_UART_Transmit(&huart1, usart1_txBuf, len*2+6 , 20); } 4). READ_HMI
():读触摸屏寄存器数据void READ_HMI(uint16_t addr,uint8_t num) { usart1_txBuf[0]=0x5a;
usart1_txBuf[1]=0xa5; usart1_txBuf[2]=0x04; usart1_txBuf[3]=0x83; usart1_txBuf[4
]=(uint8_t)((addr>>8)&0xff); usart1_txBuf[5]=(uint8_t)(addr&0xff); usart1_txBuf[
6]=num; HAL_UART_Transmit(&huart1, usart1_txBuf, 7 , 20); } 5). CLOSE_OPEN_IO
():开关LEDvoid CLOSE_OPEN_IO(uint8_t hmi_key_value) { uint8_t i; if(usart1_rxBuf[7
] ==0x00&&usart1_rxBuf[8] == hmi_key_value)//LED1 { if(LED_FLAG[hmi_key_value-1
] ==0) { if(hmi_key_value == 0x01) { HAL_GPIO_WritePin(GPIOC, GPIO_PIN_10,
GPIO_PIN_RESET);//开LED1 } if(hmi_key_value == 0x02) { HAL_GPIO_WritePin(GPIOC,
GPIO_PIN_3, GPIO_PIN_RESET);//开LED2 } if(hmi_key_value == 0x03) {
HAL_GPIO_WritePin(GPIOC, GPIO_PIN_2, GPIO_PIN_RESET);//开LED3 } if(hmi_key_value
==0x04) { HAL_GPIO_WritePin(GPIOC, GPIO_PIN_0, GPIO_PIN_RESET); //开LED4 } if
(hmi_key_value ==0x05) { HAL_GPIO_WritePin(GPIOC, GPIO_PIN_13, GPIO_PIN_RESET);
//开LED5 } LED_FLAG[hmi_key_value-1] = 1; } else if(LED_FLAG[hmi_key_value-1] ==
1) { if(hmi_key_value == 0x01) { HAL_GPIO_WritePin(GPIOC, GPIO_PIN_10,
GPIO_PIN_SET);//关LED1 } if(hmi_key_value == 0x02) { HAL_GPIO_WritePin(GPIOC,
GPIO_PIN_3, GPIO_PIN_SET);//关LED2 } if(hmi_key_value == 0x03) {
HAL_GPIO_WritePin(GPIOC, GPIO_PIN_2, GPIO_PIN_SET);//关LED3 } if(hmi_key_value ==
0x04) { HAL_GPIO_WritePin(GPIOC, GPIO_PIN_0, GPIO_PIN_SET); //关LED4 } if
(hmi_key_value ==0x05) { HAL_GPIO_WritePin(GPIOC, GPIO_PIN_13, GPIO_PIN_SET);
//关LED5 } LED_FLAG[hmi_key_value-1] = 0; } for(i=0;i<9;i++) { usart1_rxBuf[i] =
0xff; } for(i=0;i<5;i++) { HMI_SEND_BUF[i] = LED_FLAG[i]; } PLC_Data_Wr2HMI(
0X1000,0,5);//发送LED状态到触摸屏,改变LED显示图标; delay_ms(50); } } 6). CLOSE_OPEN_IO
():开关LEDvoid SCAN_KEY(uint8_t io_key_value) { uint8_t i; if
(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_10)==GPIO_PIN_RESET)//KEY1按下 { delay_ms(150);
//去抖 if(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_10)==GPIO_PIN_RESET) { if(HMI_FLAG[0] ==
0) { WRITE_HMI(0X82,0x00,0x00,0,0,1);//熄灭屏幕 HMI_FLAG[0] = 1; }else if(HMI_FLAG[0
] ==1) { WRITE_HMI(0X82,0X64,0x00,0,0,1);//点亮屏幕 HMI_FLAG[0] = 0; } } for(i=0;i<
50;i++) { usart1_rxBuf[i] = 0x00; } usart1_counter = 0; } if
(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_11)==GPIO_PIN_RESET)//KEY2按下 { delay_ms(150);
//去抖 if(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_11)==GPIO_PIN_RESET) { TEMP += 1;
HMI_SEND_BUF[0] = TEMP; PLC_Data_Wr2HMI(0X1110,0,1);//温度+ } for(i=0;i<50;i++) {
usart1_rxBuf[i] =0x00; } usart1_counter = 0; } if
(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_12)==GPIO_PIN_RESET)//KEY3按下 { delay_ms(150);
//去抖 if(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_12)==GPIO_PIN_RESET) { TEMP -= 1;
HMI_SEND_BUF[0] = TEMP; PLC_Data_Wr2HMI(0X1110,0,1);//温度- } for(i=0;i<50;i++) {
usart1_rxBuf[i] =0x00; } usart1_counter = 0; } if
(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_13)==GPIO_PIN_RESET)//KEY4按下 { delay_ms(150);
//去抖 if(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_13)==GPIO_PIN_RESET) { if(PLAY == 0) {
WRITE_HMI(0X00A0,0X00,0x0E,0,0,1); PLAY =1;//播放 }else if(PLAY == 1) { WRITE_HMI(
0X00A0,0X00,0x00,0,0,1); PLAY =0;//停止 } } for(i=0;i<50;i++) { usart1_rxBuf[i] =
0x00; } usart1_counter = 0; } if
(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_14)==GPIO_PIN_RESET)//KEY5按 { delay_ms(150);
//去抖 if(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_14)==GPIO_PIN_RESET) { if(VOLUME<250) {
VOLUME +=10; WRITE_HMI(0X00A1,VOLUME,0x00,0,0,2);//音量+ delay_ms(50);
HMI_SEND_BUF[0] = VOLUME; PLC_Data_Wr2HMI(0X1210,0,1);//写当前音量到触摸屏 delay_ms(50);
} }for(i=0;i<50;i++) { usart1_rxBuf[i] = 0x00; } usart1_counter = 0; } if
(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_15)==GPIO_PIN_RESET)//KEY6按下 { delay_ms(150);
//去抖 if(HAL_GPIO_ReadPin(GPIOB,GPIO_PIN_15)==GPIO_PIN_RESET) { if(VOLUME >= 10)
{ VOLUME -=10; WRITE_HMI(0X00A1,VOLUME,0x00,0,0,2);//音量- delay_ms(50);
HMI_SEND_BUF[0] = VOLUME; PLC_Data_Wr2HMI(0X1210,0,1);//写当前音量到触摸屏 delay_ms(50);
} }for(i=0;i<50;i++) { usart1_rxBuf[i] = 0x00; } usart1_counter = 0; } } 7).
delay_ms ():延时函数,不精确慎用void delay_ms(uint16_t nms) { uint16_t i,j; for(i=0
;i<nms;i++) {for(j=0;j<10000;j++) { ; } } } 8). USART1_IRQHandler ():数据接收中断 void
USART1_IRQHandler(void) { HAL_UART_IRQHandler(&huart1); if(usart1_rxBuf[0] ==
0x5a&&usart1_rxBuf[1] == 0xa5&&usart1_rxBuf[2]) { if(usart1_counter >= 3
&&usart1_counter<(usart1_rxBuf[2]+3)) { usart1_rxBuf[usart1_counter] =
usart1_data; usart1_counter++; }if(usart1_counter >= 3
&&usart1_counter>=(usart1_rxBuf[2]+3)) { HMI_HANDLEFLAG = 1;//接收完成标志 } } if
(usart1_counter <3) { usart1_rxBuf[usart1_counter] = usart1_data;
usart1_counter++; }if(HMI_HANDLEFLAG) { usart1_counter = 0; }
HAL_UART_Receive_IT(&huart1,&usart1_data,1);//开接收中断 }
更多内容:界面工程文件、MCU_STM32F103RCT6 程序、演示视频、硬件结构图
及原理图、使用说明以及相关介绍
更多内容点击这里 <https://pan.baidu.com/s/19ZArydIGQOAVitdx5WgIRw>

友情链接
KaDraw流程图
API参考文档
OK工具箱
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:637538335
关注微信