单片机利用串口通信却接收不了数据

有没有大佬帮忙看看问题出在哪了

#include "fccgq.h"
#include "sys.h"
#include "led.h" 
#include "beep.h" 
#include "oled.h" 
#include "exti.h" 
#include "usart.h" 
u16 fccgqsj[9];
int Receive_sum=0;
int Receive_Flag=0;
int integer=-100;//整数的数据//储存上一次整数的数据
int decimal=-100;//小数的数据//储存上一次小数的数据
int x=1,y=1;//x储存这一次整数的数据,y储存这一次小数的数据
int c;
void fccgq_init(void){
   //GPIO端口设置
  GPIO_InitTypeDef GPIO_InitStructure;
    USART_InitTypeDef USART_InitStructure;
    NVIC_InitTypeDef NVIC_InitStructure;
    
    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); //使能GPIOA时钟
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);//使能USART2时钟
 
    //串口2对应引脚复用映射
    GPIO_PinAFConfig(GPIOA,GPIO_PinSource3,GPIO_AF_USART2); //GPIOA3复用为USART2
    //GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_USART1); //GPIOA10复用为USART1
    
    //USART1端口配置
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3; //GPIOA3
    GPIO_InitStructure.GPIO_Mode =  GPIO_Mode_IN;//输入功能//浮空输入
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;    //速度50MHz
//    GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; //推挽复用输出
    GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL; //不上拉
    GPIO_Init(GPIOA,&GPIO_InitStructure); //初始化PA3

   //USART2 初始化设置
    USART_InitStructure.USART_BaudRate = 9600;//波特率设置
    USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式
    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_Init(USART2, &USART_InitStructure); //初始化串口2
    
  USART_Cmd(USART2, ENABLE);  //使能串口2
    
  USART_ITConfig(USART2, USART_IT_RXNE, ENABLE);//开启相关中断,接收到数据中断
                                                  // RXNE(读数据寄存器非空):置1表示已经有数据被接收到并且可以读出来了,通过读USART_DR可以将该位清零,也可以向该位写0,直接清除

  OLED_ShowString(5,5,"1",16,1); 
    //Usart2 NVIC 配置
  NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;//串口2中断通道
    NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=1;//抢占优先级3
    NVIC_InitStructure.NVIC_IRQChannelSubPriority =1;        //子优先级3
    NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;            //IRQ通道使能
    NVIC_Init(&NVIC_InitStructure);    //根据指定的参数初始化NVIC寄存器

  OLED_ShowString(10,10,"2:",16,1); 

}
void USART2_IRQHandler(void)                    //串口2中断服务程序//在串口中接收数据
{
 // EXTI_ClearITPendingBit(EXTI_Line3);//清除LINE3上的中断标志位

    Receive_Flag = 0;//重新开始接收数据
    OLED_ShowString(0,48,"ASCII:",16,1);  
 // c=USART_ReceiveData(USART2);
    //if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET) //获取中断状态标志位//不等于0,也就是接收到了数据           
    //接收中断//这是判断读数据寄存器是否空,因为接受到了字符才会产生中断,所以不是空的,这个判断成立
        if(USART_ReceiveData(USART2))
      {                                                      //USART_IT_RXNE是接收数据寄存器的非空标志位
            OLED_ShowString(50,48,"CODE:",16,1);
            if(Receive_sum > 7)                                                    //数组能存放8个字节的数据                
            {
            //    USART_ReceiveString[49] = '\0';                                        //数据字节超过50位时,将最后一位设置为\0    
            //    Receive_Flag = 1;                                                    //接收标志位置1,停止接收数据
                Receive_sum = 0;                                                    //数组下标置0
            }
        //记录接收到的数据
            if(Receive_Flag == 0)                                                    //接收标志位等于0,开始接收数据
                {
                    fccgqsj[Receive_sum] = USART_ReceiveData(USART2);        //通过USART1串口接收字符
                    Receive_sum++;                                                        //数组下标++
                     OLED_ShowNum(10,10,fccgqsj[Receive_sum],3,16,1);
                } 
            
            if(Receive_sum == 3)                                                    //位置3为整数部分
            {
                 if(integer==-100){
                      integer=fccgqsj[Receive_sum];
                 }//如果是第一个数据则直接传过去
                 x=fccgqsj[Receive_sum];
                 if(x>integer)  { //如果整数比之前的大则led0亮
                         GPIO_ResetBits(GPIOF,GPIO_Pin_9); // DS0 拉低,亮 等同 LED0=0;             
                 }
                 else if(x<integer){  //如果整数比之前小则led1亮
                      GPIO_ResetBits(GPIOF,GPIO_Pin_10); // DS1 拉低,亮 等同 LED1=0;    
                 }
                 else if(x==integer){ //如果一样则蜂鸣器响
                    //  GPIO_SetBits(GPIOF,GPIO_Pin_8); //BEEP 引脚拉高, 等同 BEEP=1;
                      OLED_ShowNum(50,30,x,3,16,1);
                 }
                 integer=x;//覆盖之前的数据

            }       
      if(Receive_sum == 4)                                                    //位置4为小数部分
            {
                 if(decimal==-100){
                      decimal=fccgqsj[Receive_sum];
                 }//如果是第一个数据则直接传过去
                 y=fccgqsj[Receive_sum];
                 if(y>decimal){//如果小数比之前的大则led0亮
                         GPIO_ResetBits(GPIOF,GPIO_Pin_9); // DS0 拉低,亮 等同 LED0=0;
                 }
                 else if(y<decimal){ //如果小数比之前小则led1亮
                      GPIO_ResetBits(GPIOF,GPIO_Pin_10); // DS1 拉低,亮 等同 LED1=0;    
                 }
                 else if(y==decimal){ //如果一样则蜂鸣器响
                //         GPIO_SetBits(GPIOF,GPIO_Pin_8); //BEEP 引脚拉高, 等同 BEEP=1;
             OLED_ShowNum(103,48,y,3,16,1);             
                 }
                 decimal=y;//覆盖之前的数据

            }                        
  } 
        
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值