51串口通讯中断方式接收数据

51 串口通讯,通过电脑通讯发送字符串测试。

并用tft3.5 液晶屏显示:

#include<reg52.h> //包含头文件,一般情况不需要改动,头文件包含特殊功能寄存器的定义                        
#include<tft.h>
unsigned int pos_x=0;
unsigned int pos_y=0;
/*------------------------------------------------
                   函数声明
------------------------------------------------*/
void SendStr(unsigned char *s);

/*------------------------------------------------
                    串口初始化
------------------------------------------------*/
void InitUART  (void)
{

    SCON  = 0x50;		        // SCON: 模式 1, 8-bit UART, 使能接收  
    TMOD |= 0x20;               // TMOD: timer 1, mode 2, 8-bit 重装
    TH1   = 0xF3;               //  0xFD (TH1:  重装值 9600 波特率 晶振 11.0592MHz ) 0xF3 12M 2400
    TR1   = 1;                  // TR1:  timer 1 打开                         
    EA    = 1;                  //打开总中断
   // ES    = 1;                  //打开串口中断
}                            
/*------------------------------------------------
                    主函数
------------------------------------------------*/
void main (void)
{
TFT_Initial();//初始化
ClearScreen(0x00);
InitUART();

SendStr("发送消息至电脑端串口");

ES    = 1;                  //打开串口中断
while (1)                       
    {
    
    }
}

/*------------------------------------------------
                    发送一个字节
------------------------------------------------*/
void SendByte(unsigned char dat)
{
 SBUF = dat;
 while(!TI);
      TI = 0;
}
/*------------------------------------------------
                    发送一个字符串
------------------------------------------------*/
void SendStr(unsigned char *s)
{
 while(*s!='\0')// \0 表示字符串结束标志,通过检测是否字符串末尾
  {
  SendByte(*s);
  s++;
  }
}
/*------------------------------------------------
                     串口中断程序
------------------------------------------------*/
void UART_SER (void) interrupt 4 //串行中断服务程序
{
   unsigned char Temp;          //定义临时变量 
   pos_x = pos_x+8;
   if( pos_x > 320){
   		pos_y = pos_y + 20;
		pos_x = 8;
   }
   if(RI)                        //判断是接收中断产生
     {
	  RI=0;                      //标志位清零
	  Temp=SBUF;                 //读入缓冲区的值
	  P1=Temp;                   //把值输出到P1口,用于观察
      SBUF=Temp;                 //把接收到的值再发回电脑端
	  //LCD_Write_Data
	  LCD_PutChar8x16(pos_x , pos_y, Temp, 0x0000,0xffff);
	  
	 }
   if(TI)                        //如果是发送标志位,清零
     TI=0;
}

51接收多个字符串数据接收不全的问题,

接收时用一个缓冲数组保存接收数据

如:

unsigned int count; 
unsigned char inbuf1[20]; 

void UART_SER (void) interrupt 4 //串行中断服务程序
{
   unsigned char Temp;          //定义临时变量 


   if(RI)                        //判断是接收中断产生
     {
 RI=0;                      //标志位清零
 Temp=SBUF;                 //读入缓冲区的值
 P1=Temp;                   //把值输出到P1口,用于观察
      SBUF=Temp;                 //把接收到的值再发回电脑端
 inbuf1[count] = Temp;
 count ++;
 if (count > 30){
  count = 0;
 }


}
   if(TI)                        //如果是发送标志位,清零
     TI=0;

}

转载于:https://my.oschina.net/ffs/blog/170162

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值