找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1852|回复: 2
打印 上一主题 下一主题
收起左侧

51单片机+18B20实现温度检测并用数码管显示

[复制链接]
跳转到指定楼层
楼主
ID:556720 发表于 2019-6-13 20:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
一个简单的18B20温度计
  1. #include <reg52.h>
  2. #include "temp.h"
  3. #define u8 unsigned char
  4. #define u16 unsigned int
  5.         
  6. /*……按键接线……*/
  7. sbit key1=P1^0;   //开始
  8. sbit key2=P1^1;                //停止
  9. sbit key3=P1^2;                //小数点转换
  10. sbit key4=P1^3;                //显示平均值及转换


  11. /*……三八译码器接线……*/
  12. sbit LSA=P2^2;
  13. sbit LSB=P2^3;
  14. sbit LSC=P2^4;

  15. uchar count,second,occuar,temp;

  16. uchar temp_av[3];

  17. uchar dat[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
  18.                                         0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};

  19. /*……定时器初始化……*/
  20. void InitTimer1(void)
  21. {
  22.     TMOD = 0x10;
  23.     TH1 = 0x0EC;
  24.     TL1 = 0x78;
  25.     EA = 1;
  26.     ET1 = 1;
  27.     TR1 = 1;
  28. }

  29. void delay(u16 i)
  30. {
  31.         while(i--);        
  32. }

  33. void shumaguan_stop()
  34. {
  35.         u8 i;
  36.         for(i=0;i<8;i++)
  37.         {
  38.                 switch(i)         //位选,选择点亮的数码管,
  39.                 {
  40.                         case(0):
  41.                                 LSA=0;LSB=0;LSC=0; break;//显示第0位
  42.                         case(1):
  43.                                 LSA=1;LSB=0;LSC=0; break;//显示第1位
  44.                         case(2):
  45.                                 LSA=0;LSB=1;LSC=0; break;//显示第2位
  46.                         case(3):
  47.                                 LSA=1;LSB=1;LSC=0; break;//显示第3位
  48.                         case(4):
  49.                                 LSA=0;LSB=0;LSC=1; break;//显示第4位
  50.                         case(5):
  51.                                 LSA=1;LSB=0;LSC=1; break;//显示第5位
  52.                         case(6):
  53.                                 LSA=0;LSB=1;LSC=1; break;//显示第6位
  54.                         case(7):
  55.                                 LSA=1;LSB=1;LSC=1; break;//显示第7位        
  56.                 }
  57.                 P0=0x00;//发送段码
  58.                 delay(100); //间隔一段时间扫描        
  59.                 P0=0x00;//消隐
  60.         }
  61. }


  62. /*……数码管显示温度值……*/

  63. void shumaguan(uchar Data)
  64. {
  65.         uchar i,j;
  66.         for(i=0;i>8;i++)
  67.         {
  68.                 j=(Data*100)|0xff;
  69.                 Data=Data >> 16;
  70.                 switch(i)         //位选,选择点亮的数码管,
  71.                 {
  72.                         case(7):
  73.                                 LSA=0;LSB=0;LSC=0; break;//显示第0位
  74.                         case(6):
  75.                                 LSA=1;LSB=0;LSC=0; break;//显示第1位
  76.                         case(5):
  77.                                 LSA=0;LSB=1;LSC=0; break;//显示第2位
  78.                         case(4):
  79.                                 LSA=1;LSB=1;LSC=0; break;//显示第3位
  80.                         case(3):
  81.                                 LSA=0;LSB=0;LSC=1; break;//显示第4位
  82.                         case(2):
  83.                                 LSA=1;LSB=0;LSC=1; break;//显示第5位
  84.                         case(1):
  85.                                 LSA=0;LSB=1;LSC=1; break;//显示第6位
  86.                         case(0):
  87.                                 LSA=1;LSB=1;LSC=1; break;//显示第7位        
  88.                 }
  89.                 if(i==5)                //是否小数点位
  90.                 {
  91.                         P0=dat[j]&0x01;
  92.                         delay(100); //间隔一段时间扫描        
  93.                         P0=0x00;                //消隐
  94.                 }
  95.                 else
  96.                 {
  97.                         if(i==7)                        //是否第七位
  98.                         {
  99.                                 if(!key3)
  100.                                 {
  101.                                         P0=dat[0];
  102.                                         delay(100); //间隔一段时间扫描        
  103.                                         P0=0x00;                //消隐
  104.                                 }
  105.                                 else
  106.                                 {
  107.                                         P0=dat[j];        //显示温当前度值
  108.                                         delay(100); //间隔一段时间扫描        
  109.                                         P0=0x00;                //消隐
  110.                                 }
  111.                         }
  112.                         else
  113.                         {
  114.                                         P0=dat[j];        //显示温当前度值
  115.                                         delay(100); //间隔一段时间扫描        
  116.                                         P0=0x00;                //消隐
  117.                         }
  118.                 }
  119.         }
  120. }


  121. /*……主函数……*/
  122. void main()
  123. {        
  124.         uchar j;
  125.         InitTimer1();                //定时器初始化
  126.         while(1)
  127.         {
  128.                 if(!key1) //按键开始
  129.                 {
  130.                         found1:
  131.                            shumaguan(temp);
  132.                         if(!key4) goto found2;
  133.                 }
  134.                 if(!key2)   //按键停止
  135.                 {
  136.                         shumaguan_stop();
  137.                 }
  138.                 found2:
  139.                         for(j=0;j<5;)
  140.                         {
  141.                                 if(!key4)
  142.                                 {        
  143.                                         if(j==4) goto found1;
  144.                                         else shumaguan(temp_av[j]);
  145.                                         while(!key4)
  146.                                         j++;
  147.                                 }
  148.                         }
  149.                   
  150.         }
  151. }
  152. /*……定时器中断……*/
  153. void Timer1Interrupt(void) interrupt 3
  154. {
  155.     TH1 = 0x0EC;
  156.     TL1 = 0x78;
  157.           count++;
  158.           count=count%1000;
  159.           if(count==0)
  160.                 {
  161.                         temp=Ds18b20ReadTemp();
  162.                         occuar+=temp;
  163.                         second++;
  164.                         second=second%20;
  165.                         if(second==5)
  166.                         {
  167.                                 temp_av[0]=occuar/5;
  168.                         }
  169.                         if(second==10)
  170.                         {
  171.                                 temp_av[1]=occuar/10;
  172.                         }
  173.                         if(second==0)
  174.                         {
  175.                                 temp_av[2]=occuar/20;
  176.                                 occuar=0;
  177.                         }
  178.                 }               
  179. }

复制代码

ds18b20.rar

35.85 KB, 下载次数: 19, 下载积分: 黑币 -5

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:360174 发表于 2019-11-1 16:15 来自手机 | 只看该作者
楼主,有原理图吗?
回复

使用道具 举报

板凳
ID:690838 发表于 2020-2-7 15:54 | 只看该作者
有proteus仿真图吗?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表