STM32f4日記4之HMI智能串口屏與單片機串口通信實驗(能通過按下串口屏圖片來控制單片機上LED燈閃滅)
板子:stm32f407zgt6正點原子迷你版
串口屏:淘晶馳HMI電容觸摸屏3.5寸
//
如果你覺得對你有幫助,請點贊同,這對我很重要,謝謝,
//
一、器材介紹
HMI智能串口屏


串口屏的圖形化編輯是開發利器,引數如上
串口屏可以通過***簡單的編輯***達到非常理想的效果
二、硬體連接
串口屏一共4個口:RX、TX、5V、GND
1.單片機初始化USART1,對應正點原子板子上PA9、PA10,
2.因為兩個IO口都是用跳線帽接好的,我們將跳線帽拔掉,將RX接PA9,將TX接PA10(接線非常重要,PA10為單片機RX口,PA9為單片機TX口)
3.記得設定單片機跟串口屏的波特率相同,我將他們兩個都設定為9600(推薦串口屏使用SD卡下載,2秒就能下好,而串口下載需要2分鐘)
三、程序講解
1.想要兩個電子產品之間產生互動一定要有以下程序:發送資料,資料分析,代碼執行
2.關于發送資料串口屏可通過printh發送(此代碼發送的是hex資料也就是16進制資料)
3.根據正點原子的串口通信協議,為保證接受資料的真實有效撰寫了一個通信協議
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
{
Res =USART_ReceiveData(USART1);//(USART1->DR);
if((USART_RX_STA&0x8000)==0)
{
if(USART_RX_STA&0x4000)
{
if(Res!=0x0a)USART_RX_STA=0;
else USART_RX_STA|=0x8000;
}
else
{
if(Res==0x0d)USART_RX_STA|=0x4000;
else
{
USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;
USART_RX_STA++;
if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;
}
}
}
}
定義了一個變數USART_RX_STA來進行串口通信標志的分析,定義USART_RX_BUF(陣列)來存盤收到資料
如有不懂可以觀看視頻點擊此處
這個視頻會具體講解這段代碼
這段代碼說明只有收到的資料為0x0d 0x0a結尾才是有效資料
四、代碼示例
usart.c里面代碼
#include "sys.h"
#include "usart.h"
#include"delay.h"
//
#if SYSTEM_SUPPORT_OS
#include "includes.h"
#endif
#if 1
#pragma import(__use_no_semihosting)
struct __FILE
{
int handle;
};
FILE __stdout;
void _sys_exit(int x)
{
x = x;
}
int fputc(int ch, FILE *f)
{
while((USART1->SR&0X40)==0);//?-?··¢?í,?±μ?·¢?ííê±?
USART1->DR = (u8) ch;
return ch;
}
#endif
#if EN_USART1_RX
u8 USART_RX_BUF[USART_REC_LEN];
u16 USART_RX_STA=0;
void uart_init(u32 bound){
GPIO_InitTypeDef GPIO_InitStructure;
USART_InitTypeDef USART_InitStructure;
NVIC_InitTypeDef NVIC_InitStructure;
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_USART1);
GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_USART1);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9 | GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
GPIO_Init(GPIOA,&GPIO_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;
USART_Init(USART1, &USART_InitStructure);
USART_Cmd(USART1, ENABLE);
#if EN_USART1_RX
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;//′??ú1?D??í¨μà
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3;
NVIC_InitStructure.NVIC_IRQChannelSubPriority =3;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
#endif
}
void USART1_IRQHandler(void)
{
u8 Res;
#if SYSTEM_SUPPORT_OS
OSIntEnter();
#endif
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
{
Res =USART_ReceiveData(USART1);//(USART1->DR);
if((USART_RX_STA&0x8000)==0)
{
if(USART_RX_STA&0x4000)//?óê?μ?á?0x0d
{
if(Res!=0x0a)USART_RX_STA=0;
else USART_RX_STA|=0x8000;
}
else
{
if(Res==0x0d)USART_RX_STA|=0x4000;
else
{
USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;
USART_RX_STA++;
if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;
}
}
}
}
#if SYSTEM_SUPPORT_OS
OSIntExit();
#endif
}
#endif
最重要的是void USART1_IRQHandler(void) 這個函式用來寫usart1的中斷,中斷里面就是通行協議
usart.h里面
#define USART_REC_LEN 200
#define EN_USART1_RX 1
extern u8 USART_RX_BUF[USART_REC_LEN];
extern u16 USART_RX_STA;
void uart_init(u32 bound);
#endif
主函式里面代碼
#include "sys.h"
#include "delay.h"
#include "usart.h"
#include "led.h"
#include "beep.h"
#include "key.h"
int main(void)
{
u8 t;
u8 len;
u16 times=0;
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
delay_init(168);
uart_init(9600);
LED_Init();
while(1)
{
if(USART_RX_STA&0x8000)
{
len=USART_RX_STA&0x3fff;
USART_RX_STA=0;
if(!(strcmp(USART_RX_BUF,"1")))
{
LED0=0;
}
if(!(strcmp(USART_RX_BUF,"2")))
{
LED0=1;
}
delay_ms(10);
}
}
}
下面給出串口屏代碼撰寫


這兩個圖片匯入串口屏工程中
一個作為開燈一個作為關燈
設定一個***雙態按鈕***來實作
按下事件里面寫
if(bt0.val==1)
{
bt0.pic=1
printh 31
printh 0d
printh 0a
}else
{
bt0.pic=0
printh 32
printh 0d
printh 0a
}
記得在program.s里面加入
bauds=9600
bkcmd=3
dims=100
來確保波特率為9600
下面是除錯視頻我放在網盤里面了(被百度網盤處理過,可能不怎么清晰,見諒)
鏈接:https://pan.baidu.com/s/1_7tiJ2xq_gpxV_PdpD2CmQ
提取碼:clz6
復制這段內容后打開百度網盤手機App,操作更方便哦
之后就可以進行串口通信了+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
五、實驗效果
按下串口屏圖片,燈亮,再按,燈滅
六、思考拓展
雖然這個實驗看起來很簡單,但卻是簡單化處理矩陣鍵盤的基礎,可以自行設計各種圖片按鍵,達到非常理想的效果,需要讀者自己的探索,
作者:shawn
可咨詢QQ:965798711
2021.1.22
14:55
All rights reserved
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/252032.html
標籤:其他
