完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
我弄出来的数码管显示的是乱码,我用的是89C51的单片机
主机: #include #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 #define GPIO_DIG P0 ***it LSA=P2^2; ***it LSB=P2^3; ***it 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;//消隐 } } |
|
相关推荐
1个回答
|
|
|
这个不是只和软件有关系,你的从机器有几个,要是多余两个的话要加三极管驱动的,还有两个从机的话主机是不能读取数据的
|
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
470 浏览 0 评论
532 浏览 0 评论
660 浏览 0 评论
822 浏览 0 评论
RT-Thread与英飞凌(infineon)合作得板子PSOC 6 板子学习
758 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
17034 浏览 31 评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-13 18:04 , Processed in 1.176191 second(s), Total 72, Slave 55 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
7370