当前位置:   article > 正文

STM32与陶晶驰串口屏交互_陶晶驰串口屏链接stm32

陶晶驰串口屏链接stm32

1、串口屏界面设计

1.新建工程

保存位置自定义,作为一个合格的嵌入式工程师要有路径下没有中文的情况并命名。

选择自己串口屏对应的芯片,一般屏幕背面会有,也可以查看资料。

 选择显示方向,自行选择。按照自己的爱好

右边可对当前页面重命名。

再进行一些基础代码修改。一般情况下修改波特率与单片机串口一致即可。

 Program.s

  1. //以下代码只在上电时运行一次,一般用于全局变量定义和上电初始化数据
  2. int sys0=0,sys1=0,sys2=0 //全局变量定义目前仅支持4字节有符号整形(int),不支持其他类型的全局变量声明,如需使用字符串类型可以在页面中使用变量控件
  3. bauds=115200 //配置波特率为115200
  4. dim=100 //配置亮度100
  5. bkcmd=0
  6. printh 00 00 00 ff ff ff 88 ff ff ff//输出上电信息到串口
  7. page 0 //上电刷新第0

然后从工具箱添加组件

右下角可进行属性设置。

然后在按钮组件添加弹起事件,0 1 2 3类似,依次添加。

串口屏界面设计完毕,下载到串口屏。

接下来进行单片机程序编写,本实验使用串口1与串口屏通讯。

程序与串口驱动无异

tjc_usart_hmi.h

  1. #ifndef __TJCUSARTHMI_H_
  2. #define __TJCUSARTHMI_H_
  3. #include "stm32f10x.h"
  4. /**
  5. 打印到屏幕串口
  6. */
  7. void TJCPrintf (const char *str, ...);
  8. void initRingBuff(void);
  9. void writeRingBuff(uint8_t data);
  10. void deleteRingBuff(uint16_t size);
  11. uint16_t getRingBuffLenght(void);
  12. uint8_t read1BFromRingBuff(uint16_t position);
  13. void USART1_Init(uint32_t bound);
  14. void USART1_printf(char* fmt,...); //串口1的专用printf函数
  15. #define RINGBUFF_LEN (500) //定义最大接收字节数 500
  16. #define usize getRingBuffLenght()
  17. #define code_c() initRingBuff()
  18. #define udelete(x) deleteRingBuff(x)
  19. #define u(x) read1BFromRingBuff(x)
  20. extern uint8_t RxBuff[1];
  21. #endif

 tjc_usart_hmi.c

  1. #include <stdint.h>
  2. #include <stdio.h>
  3. #include <string.h>
  4. #include <stdarg.h>
  5. #include "tjc_usart_hmi.h"
  6. #include <stddef.h>
  7. #include <stm32f10x_usart.h>
  8. #define STR_LENGTH 100
  9. typedef struct
  10. {
  11. uint16_t Head;
  12. uint16_t Tail;
  13. uint16_t Lenght;
  14. uint8_t Ring_data[RINGBUFF_LEN];
  15. }RingBuff_t;
  16. RingBuff_t ringBuff; //创建一个ringBuff的缓冲区
  17. uint8_t RxBuff[1];
  18. void TJCPrintf (const char *str, ...){
  19. char buffer[STR_LENGTH+1]; // 数据长度
  20. u8 i = 0;
  21. va_list arg_ptr;
  22. va_start(arg_ptr, str);
  23. vsnprintf(buffer, STR_LENGTH+1, str, arg_ptr);
  24. va_end(arg_ptr);
  25. while ((i < STR_LENGTH) && (i < strlen(buffer)))
  26. {
  27. USART_SendData(USART1, (u8) buffer[i++]);
  28. while (USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
  29. }
  30. USART_SendData(USART1,(uint8_t)0xff); //这个函数改为你的单片机的串口发送单字节函数
  31. while (USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
  32. USART_SendData(USART1,(uint8_t)0xff); //这个函数改为你的单片机的串口发送单字节函数
  33. while (USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
  34. USART_SendData(USART1,(uint8_t)0xff); //这个函数改为你的单片机的串口发送单字节函数
  35. while (USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);
  36. }
  37. /********************************************************
  38. 函数名: USART1_IRQHandler
  39. 作者:
  40. 日期: 2022.10.08
  41. 功能: 串口接收中断,将接收到的数据写入环形缓冲区
  42. 输入参数:
  43. 返回值: void
  44. 修改记录:
  45. **********************************************************/
  46. void USART1_IRQHandler(void)
  47. {
  48. if (USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
  49. {
  50. USART_ClearITPendingBit(USART1, USART_IT_RXNE);
  51. RxBuff[0] = USART_ReceiveData(USART1);
  52. writeRingBuff(RxBuff[0]);
  53. }
  54. }
  55. /********************************************************
  56. 函数名: initRingBuff
  57. 作者:
  58. 日期: 2022.10.08
  59. 功能: 初始化环形缓冲区
  60. 输入参数:
  61. 返回值: void
  62. 修改记录:
  63. **********************************************************/
  64. void initRingBuff(void)
  65. {
  66. //初始化相关信息
  67. ringBuff.Head = 0;
  68. ringBuff.Tail = 0;
  69. ringBuff.Lenght = 0;
  70. }
  71. /********************************************************
  72. 函数名: writeRingBuff
  73. 作者:
  74. 日期: 2022.10.08
  75. 功能: 往环形缓冲区写入数据
  76. 输入参数:
  77. 返回值: void
  78. 修改记录:
  79. **********************************************************/
  80. void writeRingBuff(uint8_t data)
  81. {
  82. if(ringBuff.Lenght >= RINGBUFF_LEN) //判断缓冲区是否已满
  83. {
  84. return ;
  85. }
  86. ringBuff.Ring_data[ringBuff.Tail]=data;
  87. ringBuff.Tail = (ringBuff.Tail+1)%RINGBUFF_LEN;//防止越界非法访问
  88. ringBuff.Lenght++;
  89. }
  90. /********************************************************
  91. 函数名: deleteRingBuff
  92. 作者:
  93. 日期: 2022.10.08
  94. 功能: 删除串口缓冲区中相应长度的数据
  95. 输入参数: 要删除的长度
  96. 返回值: void
  97. 修改记录:
  98. **********************************************************/
  99. void deleteRingBuff(uint16_t size)
  100. {
  101. if(size >= ringBuff.Lenght)
  102. {
  103. initRingBuff();
  104. return;
  105. }
  106. for(int i = 0; i < size; i++)
  107. {
  108. if(ringBuff.Lenght == 0)//判断非空
  109. {
  110. initRingBuff();
  111. return;
  112. }
  113. ringBuff.Head = (ringBuff.Head+1)%RINGBUFF_LEN;//防止越界非法访问
  114. ringBuff.Lenght--;
  115. }
  116. }
  117. /********************************************************
  118. 函数名: read1BFromRingBuff
  119. 作者:
  120. 日期: 2022.10.08
  121. 功能: 从串口缓冲区读取1字节数据
  122. 输入参数: position:读取的位置
  123. 返回值: 所在位置的数据(1字节)
  124. 修改记录:
  125. **********************************************************/
  126. uint8_t read1BFromRingBuff(uint16_t position)
  127. {
  128. uint16_t realPosition = (ringBuff.Head + position) % RINGBUFF_LEN;
  129. return ringBuff.Ring_data[realPosition];
  130. }
  131. /********************************************************
  132. 函数名: getRingBuffLenght
  133. 作者:
  134. 日期: 2022.10.08
  135. 功能: 获取串口缓冲区的数据数量
  136. 输入参数:
  137. 返回值: 串口缓冲区的数据数量
  138. 修改记录:
  139. **********************************************************/
  140. uint16_t getRingBuffLenght()
  141. {
  142. return ringBuff.Lenght;
  143. }
  144. /********************************************************
  145. 函数名: isRingBuffOverflow
  146. 作者:
  147. 日期: 2022.10.08
  148. 功能: 判断环形缓冲区是否已满
  149. 输入参数:
  150. 返回值: 1:环形缓冲区已满 , 2:环形缓冲区未满
  151. 修改记录:
  152. **********************************************************/
  153. uint8_t isRingBuffOverflow()
  154. {
  155. return ringBuff.Lenght == RINGBUFF_LEN;
  156. }
  157. //初始化IO 串口1
  158. //bound:波特率
  159. void USART1_Init(uint32_t bound){
  160. //串口1初始化并启动
  161. //GPIO端口设置
  162. GPIO_InitTypeDef GPIO_InitStructure;
  163. USART_InitTypeDef USART_InitStructure;
  164. NVIC_InitTypeDef NVIC_InitStructure;
  165. RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1|RCC_APB2Periph_GPIOA, ENABLE); //使能USART1,GPIOA时钟
  166. //USART1_TX PA.9
  167. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; //PA.9
  168. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  169. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽输出
  170. GPIO_Init(GPIOA, &GPIO_InitStructure);
  171. //USART1_RX PA.10
  172. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  173. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空输入
  174. GPIO_Init(GPIOA, &GPIO_InitStructure);
  175. //Usart1 NVIC 配置
  176. NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  177. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ;//抢占优先级3
  178. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3; //子优先级3
  179. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道使能
  180. NVIC_Init(&NVIC_InitStructure); //根据指定的参数初始化VIC寄存器
  181. //USART 初始化设置
  182. USART_InitStructure.USART_BaudRate = bound;//一般设置为9600;
  183. USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式
  184. USART_InitStructure.USART_StopBits = USART_StopBits_1;//一个停止位
  185. USART_InitStructure.USART_Parity = USART_Parity_No;//无奇偶校验位
  186. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制
  187. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; //收发模式
  188. USART_Init(USART1, &USART_InitStructure); //初始化串口
  189. USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//开启ENABLE/关闭DISABLE中断
  190. USART_Cmd(USART1, ENABLE); //使能串口
  191. }

main.c

  1. #include "stm32f10x.h"
  2. #include "tjc_usart_hmi.h"
  3. #include "stm32f10x_rcc.h"
  4. #define FRAMELENGTH 6
  5. void NVIC_Configuration(void);
  6. void RCC_Configuration(void);
  7. int main(void)
  8. {
  9. RCC_Configuration();
  10. NVIC_Configuration();
  11. USART1_Init(115200); //串口初始化为115200
  12. TJCPrintf("\x00"); //为确保串口HMI正常通信
  13. while(1)
  14. {
  15. //stm32f103的GND接串口屏或串口工具的GND,共地
  16. //stm32f103的TX1(PA9)接串口屏或串口工具的RX
  17. //stm32f103的RX1(PA10)接串口屏或串口工具的TX
  18. //stm32f1035V接串口屏的5V,如果是串口工具,不用接5V也可以
  19. //串口数据格式:
  20. //串口数据帧长度:6字节
  21. //帧头 led编号 LED状态 帧尾
  22. //0x55 1字节 1字节 0xffffff
  23. //例子1:上位机代码 printh 55 01 00 ff ff ff 含义:1号led关闭
  24. //例子2:上位机代码 printh 55 04 01 ff ff ff 含义:4号led打开
  25. //例子3:上位机代码 printh 55 00 01 ff ff ff 含义:0号led打开
  26. //例子4:上位机代码 printh 55 04 00 ff ff ff 含义:4号led关闭
  27. while(usize >= FRAMELENGTH)
  28. {
  29. //校验帧头帧尾是否匹配
  30. if(u(0) != 0x55 || u(3) != 0xff || u(4) != 0xff || u(5) != 0xff)
  31. {
  32. //不匹配删除1字节
  33. udelete(1);
  34. }else
  35. {
  36. //匹配,跳出循环
  37. break;
  38. }
  39. }
  40. //进行解析
  41. if(usize >= FRAMELENGTH && u(0) == 0x55 && u(3) == 0xff && u(4) == 0xff && u(5) == 0xff)
  42. {
  43. TJCPrintf("msg.txt=\"led %d is %s\"", u(1), u(2) ? "on" : "off");
  44. udelete(FRAMELENGTH);
  45. }
  46. //delay_ms(1000);
  47. }
  48. }
  49. void NVIC_Configuration(void)
  50. {
  51. NVIC_InitTypeDef NVIC_InitStructure;
  52. /* 嵌套向量中断控制器组选择 */
  53. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  54. /* 配置USART为中断源 */
  55. NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  56. /* 抢断优先级*/
  57. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
  58. /* 子优先级 */
  59. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  60. /* 使能中断 */
  61. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  62. /* 初始化配置NVIC */
  63. NVIC_Init(&NVIC_InitStructure);
  64. }
  65. void RCC_Configuration(void){ //RCC时钟的设置
  66. ErrorStatus HSEStartUpStatus;
  67. RCC_DeInit(); /* RCC system reset(for debug purpose) RCC寄存器恢复初始化值*/
  68. RCC_HSEConfig(RCC_HSE_ON); /* Enable HSE 使能外部高速晶振*/
  69. HSEStartUpStatus = RCC_WaitForHSEStartUp(); /* Wait till HSE is ready 等待外部高速晶振使能完成*/
  70. if(HSEStartUpStatus == SUCCESS){
  71. /*设置PLL时钟源及倍频系数*/
  72. RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); //RCC_PLLMul_x(枚举2~16)是倍频值。当HSE=8MHZ,RCC_PLLMul_9时PLLCLK=72MHZ
  73. /*设置AHB时钟(HCLK)*/
  74. RCC_HCLKConfig(RCC_SYSCLK_Div1); //RCC_SYSCLK_Div1——AHB时钟 = 系统时钟(SYSCLK) = 72MHZ(外部晶振8HMZ)
  75. /*注意此处的设置,如果使用SYSTICK做延时程序,此时SYSTICK(Cortex System timer)=HCLK/8=9MHZ*/
  76. RCC_PCLK1Config(RCC_HCLK_Div2); //设置低速AHB时钟(PCLK1),RCC_HCLK_Div2——APB1时钟 = HCLK/2 = 36MHZ(外部晶振8HMZ)
  77. RCC_PCLK2Config(RCC_HCLK_Div1); //设置高速AHB时钟(PCLK2),RCC_HCLK_Div1——APB2时钟 = HCLK = 72MHZ(外部晶振8HMZ)
  78. /*注:AHB主要负责外部存储器时钟。APB2负责AD,I/O,高级TIM,串口1。APB1负责DA,USB,SPI,I2C,CAN,串口2345,普通TIM */
  79. FLASH_SetLatency(FLASH_Latency_2); //设置FLASH存储器延时时钟周期数
  80. /*FLASH时序延迟几个周期,等待总线同步操作。
  81. 推荐按照单片机系统运行频率:
  82. 024MHz时,取Latency_0
  83. 2448MHz时,取Latency_1
  84. 48~72MHz时,取Latency_2*/
  85. FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //选择FLASH预取指缓存的模式,预取指缓存使能
  86. RCC_PLLCmd(ENABLE); //使能PLL
  87. while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET); //等待PLL输出稳定
  88. RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //选择SYSCLK时钟源为PLL
  89. while(RCC_GetSYSCLKSource() != 0x08); //等待PLL成为SYSCLK时钟源
  90. }

代码很好理解,查看注释可知,可根据自己情况添加控制外设以及显示温湿度等函数

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号