微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > MCU和单片机设计讨论 > 帮我快速的看一下哪里有什么错误,关于双机的问题

帮我快速的看一下哪里有什么错误,关于双机的问题

时间:10-02 整理:3721RD 点击:
我弄出来的数码管显示的是乱码,我用的是89C51的单片机
主机:

#include<reg51.h>


#include"temp.h"



void LcdDisplay(int);


void UsartConfiguration();


void Delay10ms(unsigned int c);   //延时10ms



void main()


{


       UsartConfiguration();


       while(1)


       {


              LcdDisplay(Ds18b20ReadTemp());


       }


}



     





void LcdDisplay(int temp)     //lcd显示


{



      unsigned int datas[]={0,0,0,0,0}; //定义数组


        datas[0]=temp>>8;



          datas[1]=temp&0xff;



       SBUF= datas[0];        //将接收到的数据放入到发送寄存器


       while(!TI);                      //等待发送数据完成


       TI= 0;


      


       SBUF= datas[1];        //将接收到的数据放入到发送寄存器


       while(!TI);                      //等待发送数据完成


       TI= 0;



        Delay10ms(100);


        


}


/*******************************************************************************


* 函数 名         :UsartConfiguration()


* 函数功能              : 设置串口


* 输    入         : 无


* 输    出         : 无


*******************************************************************************/


voidDelay10ms(unsigned int c)   //误差 0us


{


   unsigned char a, b;



       //--c已经在传递过来的时候已经赋值了,所以在for语句第一句就不用赋值了--//


   for (;c>0;c--)


       {


              for(b=38;b>0;b--)


              {


                     for(a=130;a>0;a--);


              }


         


       }      


}



void UsartConfiguration()


{


       SCON=0X50;               //设置为工作方式1


       TMOD=0X20;              //设置计数器工作方式2


       PCON=0X80;               //波特率加倍


       TH1=0XF3;                         //计数器初始值设置,注意波特率是4800的


       TL1=0XF3;


//     ES=1;                                        //打开接收中断


       EA=1;                                        //打开总中断


       TR1=1;                               //打开计数器


}

从机:

#include<reg51.h>
#define GPIO_DIG P0
sbit LSA=P2^2;
sbit LSB=P2^3;
sbit LSC=P2^4;

unsigned char code DIG_CODE[17]={
0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
//0、1、2、3、4、5、6、7、8、9、A、b、C、d、E、F的显示码
unsigned char DisplayData[8];   int temp;
//用来存放要显示的8位数的值
unsigned int buffer[5];//定义接收缓冲区
//--声明全局函数--//
void DigDisplay();//动态显示函数
void UsartConfiguration();
void main()
{
   float tp;
UsartConfiguration();
while(1)
{  
    if(RI == 1) //查看是否接收到数据
{
buffer[0] = SBUF; //读取数据
RI = 0; //清除标志位
  }
if(RI == 1) //查看是否接收到数据
{
buffer[1] = SBUF; //读取数据
RI = 0; //清除标志位
  }
temp=buffer[0]<<8| buffer[1];
    if(temp< 0) //当温度值为负数
   {
DisplayData[0] = 0x40;
//因为读取的温度是实际温度的补码,所以减1,再取反求出原码
temp=temp-1;
temp=~temp;
tp=temp;
temp=tp*0.0625*100+0.5;
//留两个小数点就*100,+0.5是四舍五入,因为C语言浮点数转换为整型的时候把小数点
//后面的数自动去掉,不管是否大于0.5,而+0.5之后大于0.5的就是进1了,小于0.5的就
//算由?.5,还是在小数点后面。

   }
  else
   {
DisplayData[0] = 0x00;
tp=temp;//因为数据处理有小数点所以将温度赋给一个浮点型变量
//如果温度是正的那么,那么正数的原码就是补码它本身
temp=tp*0.0625*100+0.5;
//留两个小数点就*100,+0.5是四舍五入,因为C语言浮点数转换为整型的时候把小数点
//后面的数自动去掉,不管是否大于0.5,而+0.5之后大于0.5的就是进1了,小于0.5的就
//算加上0.5,还是在小数点后面。
}
DisplayData[1] = DIG_CODE[temp / 10000];
DisplayData[2] = DIG_CODE[temp % 10000 / 1000];
DisplayData[3] = DIG_CODE[temp % 1000 / 100] | 0x80;
DisplayData[4] = DIG_CODE[temp % 100 / 10];
DisplayData[5] = DIG_CODE[temp % 10];
  DigDisplay();    //扫描显示
  
}
}
void UsartConfiguration()
{
SCON=0X50; //设置为工作方式1
TMOD=0X20; //设置计数器工作方式2
PCON=0X80; //波特率加倍
TH1=0XF3; //计数器初始值设置,注意波特率是4800的
TL1=0XF3;
TR1=1; //打开计数器
}
void DigDisplay()
{
unsigned char i;
unsigned int j;
for(i=0;i<8;i++)
{
switch(i) //位选,选择点亮的数码管,
{
    case(0):
LSA=0;LSB=0;LSC=0; break;//显示第0位
case(1):
LSA=1;LSB=0;LSC=0; break;//显示第1位
case(2):
LSA=0;LSB=1;LSC=0; break;//显示第2位
    case(3):
      LSA=1;LSB=1;LSC=0; break;//显示第3位
case(4):
LSA=0;LSB=0;LSC=1; break;//显示第4位
case(5):
    LSA=1;LSB=0;LSC=1; break;//显示第5位
case(6):
LSA=0;LSB=1;LSC=1; break;//显示第6位
case(7):
LSA=1;LSB=1;LSC=1; break;//显示第7位
}
GPIO_DIG=DisplayData;//发送段码
j=10; //扫描间隔时间设定
while(j--);
GPIO_DIG=0x00;//消隐
}
}  



这个不是只和软件有关系,你的从机器有几个,要是多余两个的话要加三极管驱动的,还有两个从机的话主机是不能读取数据的

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top