当前位置:   article > 正文

STM32学习笔记(江协科技)-----实现串口通信_江协科技stm32

江协科技stm32

STM32的USART外设:

自带波特率发生器,最高可达4.5Mbits/s

可配置数据位长度(8/9),停止位长度(0.5/1/1.5/2)

可选校验位(无校验/奇校验/偶校验)

STM32F103C8T6的USART资源:USART1(APB2总线),USAR2(APB1总线),USART3(APB1总线)。

硬件部分:

f5fc2595a84a4a22919902f6f880778a.png

执行过程:

22da6bc3e60549f0af98d0f63453fbc1.png

波特率发生器产生约定的通信速率,产生的时钟通向发送控制器和接收控制器,用来控制发送移位和接收移位。之后由发送数据寄存器和发送移位寄存器配合,移出数据(右移,低位先行),通过GPIO复用输出,输出到TX引脚。RX引脚通过GPIO复用输入,移动到接收寄存器(右移,低位先行),然后转移到RDR,同时置一个RXNE标志位(既可检查是否收到,也可申请中断)。

数据采样:

f7eb6b12764d4351ab0f020a52755fe9.png

以波特率的16倍频率采样,在某个位置,突然采集到0,说明出现了下降沿,然后进行连续16位采样,在下降沿的第3,5,7次进行一批采样,8,9,10次进行一批采样,这两批,,每3位里都要有至少2个0。若有一个1,会置一个NE,即噪声标志位。若通过检测,之后每次都在8,9,10位进行采样(正好在正中心采样)。

波特率发生器(寄存器):

波特率由波特率寄存器BRR里的DIV来确定。

29a1cce24e2047f183d0d29746c8fa21.png

波特率 =eq?%5C%3B1%7D(一般为72M) /(16*DIV)

举例:若要配置波特率为9600,9600 = 72M/(16*DIV) 即 DIV = 72M/9600/16=468.75,然后转换成二进制,468.75 =   11101 0100.11 

所以写入BRR寄存器,DIV15~0:0000 11101 0100 1100 (整数部分前面补0,小数部分后面补0)   

串口发送+接收:              

接线:

USB转串口模块:VCC和3V3用跳线帽接在一起,TXD接PA10,RXD接PA9。、

(因为USART1_TX是PA9,USART1_RX是PA10,所以TX接RX,RX接TX,交叉连接)

串口发送:e23efac553214d6794cde005588ed46b.png

f6f7c98d6c1a4fd79b698a1ca87c0b68.png

 

e8f9d35d131e49c698f19018d3f68d15.png1027cf3169604f30be81365f4887d9fd.png

2a0f05d837124f00a8d22b2ce7fa1b24.png

ce7abf8777764afdb5d5b451fe833a4f.png



一些SendByte的拓展函数:

74150c2021cb4602bd72326196e35522.png

63523d4906884f5599b0229377440327.png

8cf0312a8366459f827649ee24da6048.png

串口接收+发送:

  1. #include "Device/Include/stm32f10x.h" // Device header
  2. #include <stdio.h>
  3. #include <stdarg.h>
  4. uint8_t Serial_RxData;
  5. uint8_t Serial_RxFlag;
  6. void Serial_Init(void)
  7. {
  8. USART_InitTypeDef USART_InitStructure;
  9. GPIO_InitTypeDef GPIO_InitStructure;
  10. NVIC_InitTypeDef NVIC_InitStructure;
  11. RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
  12. //RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);
  13. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
  14. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
  15. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  16. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  17. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  18. GPIO_Init(GPIOA,&GPIO_InitStructure);
  19. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  20. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;//上拉输入
  21. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  22. GPIO_Init(GPIOA,&GPIO_InitStructure);
  23. USART_InitStructure.USART_BaudRate = 9600;
  24. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  25. USART_InitStructure.USART_Mode = USART_Mode_Tx|USART_Mode_Rx;//发送+接收
  26. USART_InitStructure.USART_Parity = USART_Parity_No;
  27. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  28. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  29. USART_Init(USART1,&USART_InitStructure);
  30. USART_ITConfig(USART1, USART_IT_RXNE,ENABLE);
  31. //使能或者失能指定的 USART 中断,USART_IT_TXE:发送中断
  32. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  33. //该参数设置优先级分组位长度
  34. //NVIC_PriorityGroup_2:先占优先级 2 位,从优先级 2
  35. NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  36. //该参数用以使能或者失能指定的 IRQ 通道
  37. //USART1_IRQChannel USART1 全局中断
  38. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  39. //该参数指定了在成员 NVIC_IRQChannel 中定义的 IRQ 通道被使能还是失能。
  40. //这个参数取值为 ENABLE 或者 DISABLE。
  41. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
  42. //该参数设置了成员 NVIC_IRQChannel 中的先占优先级
  43. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  44. //该参数设置了成员 NVIC_IRQChannel 中的从优先级
  45. NVIC_Init(&NVIC_InitStructure);
  46. USART_Cmd(USART1,ENABLE);
  47. //使能或者失能 USART 外设
  48. }
  49. void Serial_SendByte(uint8_t Byte)
  50. {
  51. USART_SendData(USART1,Byte);
  52. while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET);
  53. }
  54. void Serial_SendArray(uint8_t *Array,uint16_t Length)//串口1发送数组,(首地址,长度)
  55. {
  56. uint16_t i;
  57. for(i=0;i<Length;i++)
  58. {
  59. Serial_SendByte(Array[i]);
  60. }
  61. }
  62. void Serial_SendString(char *String)//串口1发送字符串(地址)
  63. {
  64. uint8_t i;
  65. for(i=0;String[i] !='\0';i++)
  66. {
  67. Serial_SendByte(String[i]);
  68. }
  69. }
  70. uint32_t Serial_Pow(uint32_t x,uint32_t y)//转化次方 (x的y次方)
  71. {
  72. uint32_t Result = 1;
  73. while(y--)
  74. {
  75. Result *= x;
  76. }
  77. return Result;
  78. }
  79. void Serial_SendNumber(uint32_t Number,uint8_t Length)//串口1发送数字(数字,长度)
  80. {
  81. uint8_t i;
  82. for(i=0;i<Length;i++)
  83. {
  84. Serial_SendByte(Number / Serial_Pow(10,Length - i - 1) %10 + 0x30);
  85. }
  86. }
  87. int fputc(int ch,FILE *f)
  88. {
  89. Serial_SendByte(ch);
  90. return ch;
  91. }
  92. void Serial_Printf(char *format,...)
  93. {
  94. char String[100];
  95. va_list arg;
  96. va_start(arg,format);
  97. vsprintf(String,format,arg);
  98. va_end(arg);
  99. Serial_SendString(String);
  100. }
  101. uint8_t Serial_GetRxFlag(void)//清除引出标志位
  102. {
  103. if(Serial_RxFlag == 1)
  104. {
  105. Serial_RxFlag = 0;
  106. return 1;
  107. }
  108. return 0;
  109. }
  110. uint8_t Serial_GetRxData(void)//引出收到的数据
  111. {
  112. return Serial_RxData;
  113. }
  114. void USART1_IRQHandler(void)
  115. {
  116. if(USART_GetFlagStatus(USART1,USART_IT_RXNE) == SET)//判断RXNE标志位是否置1
  117. {
  118. Serial_RxData = USART_ReceiveData(USART1);
  119. //引出收到的数据
  120. Serial_RxFlag = 1;
  121. //引出完成标志位
  122. USART_ClearITPendingBit(USART1,USART_IT_RXNE);
  123. //清除RXNE标志位
  124. }
  125. }
  1. #include "stm32f10x.h"
  2. #include "Delay.h"
  3. #include "OLED.h"
  4. #include "Serial.h"
  5. uint8_t RxData;
  6. int main(void)
  7. {
  8. OLED_Init(); //OLED初始化
  9. OLED_ShowString(1,1,"RxData:");
  10. Serial_Init();//串口初始化
  11. while(1)
  12. {
  13. if(Serial_GetRxFlag() == 1)
  14. {
  15. RxData = Serial_GetRxData();
  16. Serial_SendByte(RxData);
  17. OLED_ShowHexNum(1,8,RxData,2);
  18. }
  19. }
  20. }

串口收发数据包:

HEX数据包:551f5594689d44e897489b8cb362e3f9.png

        如果载荷容易与包头包尾重复,尽量选择固定包长。如果载荷不会和包头包尾重复,可选择可变包长。(包头包尾都是可以人为规定的)

文本数据包:

3870ac67b18445ce9c1ccfab3e13364f.png

文本数据包存在大量字符可以作为包头包尾,有效避免载荷与包头包尾重复。

发送数据包:

很简单,可参考“串口发送”,直接调用封装的函数即可。

接收数据包:

09106e9249154ff390342c34905b8ef4.png

添加一个状态机。定义三个状态,状态变量为S,三个状态分别为S=0,S=1,S=2。(类似于置标志位)

文本数据包的接收也是使用状态机:

       f19112a1c1804ec1b48b9ff2703a98e1.png

代码实现(HEX数据包):

Serial.c:

  1. #include "Device/Include/stm32f10x.h" // Device header
  2. #include <stdio.h>
  3. #include <stdarg.h>
  4. uint8_t Serial_TxPacket[4];//发送的数据载荷(4个字节)
  5. uint8_t Serial_RxPacket[4];//接收的数据载荷(4个字节)
  6. uint8_t Serial_RxFlag;//如果收到一个数据包,就置RxFlag标志位
  7. void Serial_Init(void)
  8. {
  9. USART_InitTypeDef USART_InitStructure;
  10. GPIO_InitTypeDef GPIO_InitStructure;
  11. NVIC_InitTypeDef NVIC_InitStructure;
  12. RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
  13. //RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);
  14. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
  15. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
  16. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  17. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  18. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  19. GPIO_Init(GPIOA,&GPIO_InitStructure);
  20. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  21. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;
  22. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  23. GPIO_Init(GPIOA,&GPIO_InitStructure);
  24. USART_InitStructure.USART_BaudRate = 9600;
  25. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  26. USART_InitStructure.USART_Mode = USART_Mode_Tx|USART_Mode_Rx;
  27. USART_InitStructure.USART_Parity = USART_Parity_No;
  28. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  29. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  30. USART_Init(USART1,&USART_InitStructure);
  31. USART_ITConfig(USART1, USART_IT_RXNE,ENABLE);
  32. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  33. NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  34. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  35. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
  36. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  37. NVIC_Init(&NVIC_InitStructure);
  38. USART_Cmd(USART1,ENABLE);
  39. }
  40. void Serial_SendByte(uint8_t Byte)
  41. {
  42. USART_SendData(USART1,Byte);
  43. while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET);
  44. }
  45. void Serial_SendArray(uint8_t *Array,uint16_t Length)//串口1发送数组,(首地址,长度)
  46. {
  47. uint16_t i;
  48. for(i=0;i<Length;i++)
  49. {
  50. Serial_SendByte(Array[i]);
  51. }
  52. }
  53. void Serial_SendString(char *String)//串口1发送字符串(地址)
  54. {
  55. uint8_t i;
  56. for(i=0;String[i] !='\0';i++)
  57. {
  58. Serial_SendByte(String[i]);
  59. }
  60. }
  61. uint32_t Serial_Pow(uint32_t x,uint32_t y)//转化次方 (x的y次方)
  62. {
  63. uint32_t Result = 1;
  64. while(y--)
  65. {
  66. Result *= x;
  67. }
  68. return Result;
  69. }
  70. void Serial_SendNumber(uint32_t Number,uint8_t Length)//串口1发送数字(数字,长度)
  71. {
  72. uint8_t i;
  73. for(i=0;i<Length;i++)
  74. {
  75. Serial_SendByte(Number / Serial_Pow(10,Length - i - 1) %10 + 0x30);
  76. }
  77. }
  78. int fputc(int ch,FILE *f)
  79. {
  80. Serial_SendByte(ch);
  81. return ch;
  82. }
  83. void Serial_Printf(char *format,...)
  84. {
  85. char String[100];
  86. va_list arg;
  87. va_start(arg,format);
  88. vsprintf(String,format,arg);
  89. va_end(arg);
  90. Serial_SendString(String);
  91. }
  92. void Serial_SendPacket(void)//发送数据包
  93. {
  94. Serial_SendByte(0xff);
  95. Serial_SendArray(Serial_TxPacket,4);
  96. Serial_SendByte(0xfe);
  97. }
  98. uint8_t Serial_GetRxFlag(void)
  99. {
  100. if(Serial_RxFlag == 1)
  101. {
  102. Serial_RxFlag = 0;
  103. return 1;
  104. }
  105. return 0;
  106. }
  107. void USART1_IRQHandler(void)
  108. {
  109. static uint8_t RxState = 0;//状态机变量(S)
  110. static uint8_t pRxPacket = 0;
  111. if(USART_GetFlagStatus(USART1,USART_IT_RXNE) == SET)
  112. {
  113. uint8_t RxData = USART_ReceiveData(USART1);
  114. if(RxState == 0)
  115. {
  116. if(RxData == 0xff)//等待包头
  117. {
  118. RxState = 1;
  119. pRxPacket = 0;
  120. }
  121. else
  122. {
  123. RxState = 0;
  124. }
  125. }
  126. else if(RxState == 1)//等待接收数据
  127. {
  128. Serial_RxPacket[pRxPacket] =RxData;
  129. pRxPacket ++;
  130. if(pRxPacket >= 4)
  131. {
  132. RxState = 2;
  133. }
  134. }
  135. else if(RxState == 2)//等待包尾
  136. {
  137. if(RxData == 0xfe)
  138. {
  139. RxState = 0;
  140. Serial_RxFlag = 1;
  141. }
  142. else;
  143. }
  144. }
  145. }

Serial.h:

  1. #ifndef __SERIAL_H
  2. #define __SERIAL_H
  3. #include <stdio.h>
  4. extern uint8_t Serial_TxPacket[];//发送缓存区数组
  5. extern uint8_t Serial_RxPacket[];//接收缓存区数数组
  6. void Serial_Init(void);
  7. void Serial_SendByte(uint8_t Byte);
  8. void Serial_SendArray(uint8_t *Array,uint16_t Length);
  9. void Serial_SendString(char *String);
  10. void Serial_SendNumber(uint32_t Number,uint8_t Length);
  11. void Serial_Printf(char *format,...);
  12. uint8_t Serial_GetRxFlag(void);
  13. void USART1_IRQHandler(void);
  14. void Serial_SendPacket(void);
  15. #endif

main.c:

  1. #include "stm32f10x.h"
  2. #include "Delay.h"
  3. #include "OLED.h"
  4. #include "Serial.h"
  5. #include "KEY.h"
  6. uint8_t KeyNum;
  7. int main(void)
  8. {
  9. OLED_Init(); //OLED初始化
  10. Key1_Init();
  11. Serial_Init();//串口初始化
  12. OLED_ShowString(1,1,"TxPacket:");
  13. OLED_ShowString(3,1,"RxPacket:");
  14. Serial_TxPacket[0] = 0x01;
  15. Serial_TxPacket[1] = 0x02;
  16. Serial_TxPacket[2] = 0x03;
  17. Serial_TxPacket[3] = 0x04;
  18. while(1)
  19. {
  20. if (Serial_GetRxFlag() == 1)
  21. {
  22. OLED_ShowHexNum(1,1,Serial_RxPacket[0],2);
  23. OLED_ShowHexNum(1,4,Serial_RxPacket[1],2);
  24. OLED_ShowHexNum(1,7,Serial_RxPacket[2],2);
  25. OLED_ShowHexNum(1,10,Serial_RxPacket[3],2);
  26. }
  27. }
  28. }

代码实现(文本数据包):

Serial.c:

  1. #include "Device/Include/stm32f10x.h" // Device header
  2. #include <stdio.h>
  3. #include <stdarg.h>
  4. char Serial_RxPacket[100];
  5. uint8_t Serial_RxFlag;
  6. void Serial_Init(void)
  7. {
  8. USART_InitTypeDef USART_InitStructure;
  9. GPIO_InitTypeDef GPIO_InitStructure;
  10. NVIC_InitTypeDef NVIC_InitStructure;
  11. RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
  12. //RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);
  13. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
  14. RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
  15. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  16. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
  17. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  18. GPIO_Init(GPIOA,&GPIO_InitStructure);
  19. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  20. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;
  21. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  22. GPIO_Init(GPIOA,&GPIO_InitStructure);
  23. USART_InitStructure.USART_BaudRate = 9600;
  24. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  25. USART_InitStructure.USART_Mode = USART_Mode_Tx|USART_Mode_Rx;
  26. USART_InitStructure.USART_Parity = USART_Parity_No;
  27. USART_InitStructure.USART_StopBits = USART_StopBits_1;
  28. USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  29. USART_Init(USART1,&USART_InitStructure);
  30. USART_ITConfig(USART1, USART_IT_RXNE,ENABLE);
  31. NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  32. NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  33. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  34. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
  35. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
  36. NVIC_Init(&NVIC_InitStructure);
  37. USART_Cmd(USART1,ENABLE);
  38. }
  39. void Serial_SendByte(uint8_t Byte)
  40. {
  41. USART_SendData(USART1,Byte);
  42. while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) == RESET);
  43. }
  44. void Serial_SendArray(uint8_t *Array,uint16_t Length)//串口1发送数组,(首地址,长度)
  45. {
  46. uint16_t i;
  47. for(i=0;i<Length;i++)
  48. {
  49. Serial_SendByte(Array[i]);
  50. }
  51. }
  52. void Serial_SendString(char *String)//串口1发送字符串(地址)
  53. {
  54. uint8_t i;
  55. for(i=0;String[i] !='\0';i++)
  56. {
  57. Serial_SendByte(String[i]);
  58. }
  59. }
  60. uint32_t Serial_Pow(uint32_t x,uint32_t y)//转化次方 (x的y次方)
  61. {
  62. uint32_t Result = 1;
  63. while(y--)
  64. {
  65. Result *= x;
  66. }
  67. return Result;
  68. }
  69. void Serial_SendNumber(uint32_t Number,uint8_t Length)//串口1发送数字(数字,长度)
  70. {
  71. uint8_t i;
  72. for(i=0;i<Length;i++)
  73. {
  74. Serial_SendByte(Number / Serial_Pow(10,Length - i - 1) %10 + 0x30);
  75. }
  76. }
  77. int fputc(int ch,FILE *f)
  78. {
  79. Serial_SendByte(ch);
  80. return ch;
  81. }
  82. void Serial_Printf(char *format,...)
  83. {
  84. char String[100];
  85. va_list arg;
  86. va_start(arg,format);
  87. vsprintf(String,format,arg);
  88. va_end(arg);
  89. Serial_SendString(String);
  90. }
  91. void USART1_IRQHandler(void)
  92. {
  93. static uint8_t RxState = 0;
  94. static uint8_t pRxPacket = 0;
  95. if(USART_GetFlagStatus(USART1,USART_IT_RXNE) == SET)
  96. {
  97. uint8_t RxData = USART_ReceiveData(USART1);
  98. if(RxState == 0)
  99. {
  100. if(RxData == '@' && Serial_RxFlag == 0)
  101. {
  102. RxState = 1;
  103. pRxPacket = 0;
  104. }
  105. else
  106. {
  107. RxState = 0;
  108. }
  109. }
  110. else if(RxState == 1)
  111. {
  112. if(RxData == '\r')
  113. {
  114. RxState = 2;
  115. }
  116. else
  117. {
  118. Serial_RxPacket[pRxPacket] =RxData;
  119. pRxPacket ++;
  120. }
  121. }
  122. else if(RxState == 2)
  123. {
  124. if(RxData == '\n')
  125. {
  126. RxState = 0;
  127. Serial_RxPacket[pRxPacket] = '\0';
  128. Serial_RxFlag = 1;
  129. }
  130. else;
  131. }
  132. }
  133. }

Serial.h:

  1. #ifndef __SERIAL_H
  2. #define __SERIAL_H
  3. #include <stdio.h>
  4. extern char Serial_RxPacket[];
  5. extern uint8_t Serial_RxFlag;
  6. void Serial_Init(void);
  7. void Serial_SendByte(uint8_t Byte);
  8. void Serial_SendArray(uint8_t *Array,uint16_t Length);
  9. void Serial_SendString(char *String);
  10. void Serial_SendNumber(uint32_t Number,uint8_t Length);
  11. void Serial_Printf(char *format,...);
  12. void USART1_IRQHandler(void);
  13. #endif

main.c:

  1. #include "stm32f10x.h"
  2. #include "Delay.h"
  3. #include "OLED.h"
  4. #include "Serial.h"
  5. #include "LED.h"
  6. #include <string.h>
  7. int main(void)
  8. {
  9. OLED_Init(); //OLED初始化
  10. LED_Init();
  11. Serial_Init();//串口初始化
  12. OLED_ShowString(1,1,"TxPacket:");
  13. OLED_ShowString(3,1,"RxPacket:");
  14. while(1)
  15. {
  16. if(Serial_RxFlag == 1)
  17. {
  18. OLED_ShowString(4,1," ");
  19. OLED_ShowString(4,1,Serial_RxPacket);
  20. if(strcmp(Serial_RxPacket,"led_on") == 0)
  21. {
  22. LED_G_ON();
  23. Serial_SendString("led_on_ok\r\n");
  24. OLED_ShowString(2,1," ");
  25. OLED_ShowString(2,1,"led_on_ok");
  26. }
  27. else if(strcmp(Serial_RxPacket,"led_off") == 0)
  28. {
  29. LED_G_OFF();
  30. Serial_SendString("led_off_ok\r\n");
  31. OLED_ShowString(2,1," ");
  32. OLED_ShowString(2,1,"led_off_ok");
  33. }
  34. else
  35. {
  36. Serial_SendString("ERROR_COMMAND\r\n");
  37. OLED_ShowString(2,1," ");
  38. OLED_ShowString(2,1,"ERROR_COMMAND");
  39. }
  40. Serial_RxFlag = 0;
  41. }
  42. }
  43. }

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/在线问答5/article/detail/935833
推荐阅读
相关标签
  

闽ICP备14008679号