标题: [课程设计]基于51单片机及DS18B20温度传感器的数字温度计设计 [打印本页]

作者: hushao    时间: 2016-1-4 01:50
标题: [课程设计]基于51单片机及DS18B20温度传感器的数字温度计设计
基于51单片机及DS18B20温度传感器的数字温度计设计,是知创学院Jason大学时做的课程设计,虽说比较简单,但对初学者还是有一些借鉴意义。好多朋友也在微信中留言询问有没有相关资料。特借此机会公布一下下载地址,希望能为需要的朋友提供一点帮助。感谢大家关注知创学院
1、下面是做好的实物效果图

2、资料包含的主要内容:程序、仿真、原理图、参考文档

3、仿真效果图(仿真软件使用proteus 7.7 sp2)

4、文档目录

元件清单:
单片机:STC89C52             1   
传感器:DS18B20              1   
晶振:  11.0592MHz            1   
电容:  33pf                   2
       22uf电解电容           1
电阻:  10k                    1
       4.7k                    1
        1k                    1
排阻:  4.7k  9             1
PNP三极管:9012或者8550或者5401   1
蜂鸣器:                        1
轻触按钮:5
四位一体共阴极数码管:1
红色发光二极管:      1
万用板:              1
导线:                若干

使用说明:
K1是用来进入上下限调节模式的,当按一下K1进入上限调节模式,再按一下进入下限调节模式,再按一下退出调节模式。在调节上下限温度模式下,K2是实现加1功能,K1是实现减1功能,K3是用来设定上下限温度正负的。
在正常模式下,按一下K2进入查看上限温度模式,显示1s左右自动退出;按一下K3进入查看下限温度模式,显示1s左右自动退出。
K4正常模式下用来设置和取消按键音。
上下限设置模式下是用来设置温度的正负。


部分程序预览:
ds18b20.c
  1. /********************************************************************
  2. * 程序名;  基于DS18B20的测温系统
  3. * 功  能: 实时测量温度,超过上下限报警,报警温度可手动调整。K1是用来
  4. * 进入上下限调节模式的,当按一下K1进入上限调节模式,再按一下进入下限
  5. * 调节模式。在正常模式下,按一下K2进入查看上限温度模式,显示1s左右自动
  6. * 退出;按一下K3进入查看下限温度模式,显示1s左右自动退出;按一下K4消除
  7. * 按键音,再按一下启动按键音。在调节上下限温度模式下,K2是实现加1功能,
  8. * K1是实现减1功能,K3是用来设定上下限温度正负的。         
  9. * 编程时间:                  
  10. *********************************************************************/
  11. #include<AT89X52.h>                                   //将AT89X52.h头文件包含到主程序
  12. #include<intrins.h>                                   //将intrins.h头文件包含到主程序(调用其中的_nop_()空操作函数延时)
  13. #define uint unsigned int                      //变量类型宏定义,用uint表示无符号整形(16位)
  14. #define uchar unsigned char                   //变量类型宏定义,用uchar表示无符号字符型(8位)

  15. uchar max=0x00,min=0x00;                   //max是上限报警温度,min是下限报警温度

  16. bit   s=0;                                                   //s是调整上下限温度时温度闪烁的标志位,s=0不显示200ms,s=1显示1s左右
  17. bit   s1=0;                                                   //s1标志位用于上下限查看时的显示
  18. void display1(uint z);                            //声明display1()函数(display.h头文件中的函数,ds18b20.h要用应先声明)
  19. #include"ds18b20.h"                                   //将ds18b20.h头文件包含到主程序
  20. #include"keyscan.h"                                   //将keyscan.h头文件包含到主程序
  21. #include"display.h"                                   //将display.h头文件包含到主程序

  22. /***********************主函数************************/
  23. void main()
  24. {
  25.          beer=1;                                           //关闭蜂鸣器
  26.          led=1;                                                   //关闭LED灯
  27.          timer1_init(0);                           //初始化定时器1(未启动定时器1)
  28.          get_temperature(1);                    //首次启动DS18B20获取温度(DS18B20上点后自动将EEPROM中的上下限温度复制到TH和TL寄存器)
  29.          while(1)                                           //主循环
  30.          {         
  31.                  keyscan();                                   //按键扫面函数
  32.                  get_temperature(0);           //获取温度函数
  33.                  keyscan();                                   //按键扫面函数
  34.                  display(temp,temp_d*0.625);//显示函数
  35.                  alarm();                                           //报警函数
  36.                  keyscan();                                     //按键扫面函数
  37.          }
  38. }   




复制代码

ds18b20.h文件:
  1. /********************************************************************
  2. * 程序名;  __ds18b20_h__
  3. * 功  能: DS18B20的c51编程头文件
  4. * 说  明:用到的全局变量是:无符号字符型变量temp(测得的温度整数部分),temp_d
  5. * (测得的温度小数部分),标志位f(测量温度的标志位‘0’表示“正温度”‘1’表
  6. * 示“负温度”),标志位f_max(上限温度的标志位‘0’表示“正温度”、‘1’表
  7. * 示“负温度”),标志位f_min(下限温度的标志位‘0’表示“正温度”、‘1’表
  8. * 示“负温度”),标志位w(报警标志位‘1’启动报警‘0’关闭报警)。                  
  9. *********************************************************************/
  10. #ifndef __ds18b20_h__                                  //定义头文件
  11. #define __ds18b20_h__

  12. #define uint unsigned int                             //变量类型宏定义,用uint表示无符号整形(16位)
  13. #define uchar unsigned char                           //变量类型宏定义,用uchar表示无符号字符型(8位)

  14. sbit    DQ= P2^3;                                          //可位寻址变量定义,用DQ表示P2.3口
  15. sbit    beer=P1^0;                                           //用beer表示P1.0
  16. sbit    led=P1^1;                                          //用led表示P1.1
  17. uchar   temp=0;                                   //测量温度的整数部分
  18. uchar   temp_d=0;                               //测量温度的小数部
  19. bit     f=0;                                                  //测量温度的标志位,0’表示“正温度”‘1’表示“负温度”)
  20. bit     f_max=0;                                          //上限温度的标志位‘0’表示“正温度”‘1’表示“负温度”)
  21. bit     f_min=0;                                          //下限温度的标志位‘0’表示“正温度”、‘1’表示“负温度”)
  22. bit     w=0;                                                  //报警标志位‘1’启动报警‘0’关闭报警)
  23. /*****************************延时子函数******************************/
  24. void ds18b20_delayus(uint t)          //延时几μs
  25. {
  26.    while(t--);
  27. }

  28. void ds18b20_delayms(uint t)                  //延时1ms左右
  29. {
  30.         uint i,j;
  31.         for(i=t;i>0;i--)
  32.             for(j=120;j>0;j--);
  33. }
  34. /**************************ds18b20初始化函数*************************/
  35. void ds18b20_init()                                         // DS18B20初始化
  36. {
  37.         DQ=1;                                                         //拉高数据线
  38.         DQ=0;                                                     //控制器向DS18B20发低电平脉冲
  39.         ds18b20_delayus(30);                     //延时480μs左右
  40.         DQ=1;                                                         //控制器拉高总线,
  41.         while(DQ);                                                    //等待DS18B20拉低总线
  42.         ds18b20_delayus(20);                         //延时,等待上拉电阻拉高总线
  43.         DQ=1;                                                         //拉高数据线,准备数据传输;
  44. }

  45. /***************************ds18b20字节读函数************************/
  46. uchar ds18b20_read()                                 //DS18B20 字节读取
  47. {
  48.         uchar i;                                                 //定义一个局部变量i(局部变量只在本函数中有效)
  49.         uchar d = 0;                                         //定义一个局部变量d
  50.         DQ = 1;                                                         //准备读;
  51.         for(i=8;i>0;i--)                                 //一位一位的读,循环8次
  52.         {       
  53.             d >>= 1;                     //d左移一位,低位先发;
  54.                 DQ = 0;                                                                       
  55.                 _nop_();
  56.                 _nop_();
  57.                 _nop_();                               
  58.                 DQ = 1;                                                 //必须写1,否则读出来的将是不预期的数据;
  59.                 if(DQ)                                                 //在12us处读取数据,送给d的最高位
  60.                         d |= 0x80;
  61.                 ds18b20_delayus(10);               
  62.                 }
  63.         return d;                                                 //返回读取的值
  64. }

  65. /*************************ds18b20字节写函数**************************/
  66. void ds18b20_write(uchar d)                         // ds18b20字节写
  67. {
  68.      uchar  i;
  69.      for(i=8;i>0;i--)                                 //一位一位的写
  70.      {        
  71.                   DQ=0;
  72.                   _nop_();
  73.                   _nop_();
  74.                   _nop_();
  75.                   DQ=d&0x01;                                //写数据
  76.                   ds18b20_delayus(5);
  77.                   DQ=1;       
  78.                   d >>= 1;         
  79.      }
  80. }

  81. /***************************获取温度函数****************************/
  82. void get_temperature(bit flag)               
  83. {
  84.         uchar a=0,b=0,c=0,d=0;
  85.     uint i;       
  86.         ds18b20_init();                                    //DS18B20初始化
  87.         ds18b20_write(0xcc);                        //向DS18B20发跳过读ROM命令
  88.         ds18b20_write(0x44);                        //写启动DS18B20进行温度转换命令,转换结果存入内部RAM
  89.         if(flag==1)
  90.         {                                                                //首次启动DS18B20进行温度转换需要500ms,若转换时间不够就出错,读出的是85度的错误值。
  91.           display1(1);                                        //用开机动画耗时
  92.         }

  93.         else
  94.         ds18b20_delayms(1);                               
  95.         ds18b20_init();                                //DS18B20初始化
  96.         ds18b20_write(0xcc);                         //向DS18B20发跳过读ROM命令
  97.         ds18b20_write(0xbe);                        //写读内部RAM中9字节的内容命令
  98.         a=ds18b20_read();                                //读内部RAM (LSB)
  99.         b=ds18b20_read();                                //读内部RAM (MSB)
  100.         if(flag==1)                                                //局部位变量f=1时读上下线报警温度
  101.         {
  102.             max=ds18b20_read();                    //读内部RAM (TH)
  103.             min=ds18b20_read();                    //读内部RAM (Tl)
  104.                
  105.         }
  106.         if((max&0x80)==0x80)                    //若读取的上限温度的最高位(符号位)为‘1’表明是负温度
  107.         {f_max=1;max=(max-0x80);}       //将上限温度符号标志位置‘1’表示负温度,将上限温度装换成无符号数。
  108.          if((min&0x80)==0x80)                     //若读取的下限温度的最高位(符号位)为‘1’表明是负温度
  109.         {f_min=1;min=(min-0x80);}       //将下限温度符号标志位置‘1’表示负温度,将下限温度装换成无符号数。
  110.                 
  111.         i=b;
  112.         i>>=4;
  113.         if (i==0)
  114.                 {
  115.         f=0;                                            //i为0,表示读取的温度是正温度,设立正温度标记
  116.         temp=((a>>4)|(b<<4));                //整数部分
  117.                a=(a&0x0f);
  118.                temp_d=a;                                        //小数部分
  119.                 }
  120.         else
  121.                 {
  122.                f=1;                                            //i为1,表示读取的温度是负温度,设立负温度标记
  123.                a=~a+1;                                                //负数的小数部分取反加1
  124.                b=~b;                                                //负数的整数部分取反
  125.                temp=((a>>4)|(b<<4));                //整数部分
  126.                a=(a&0x0f);                                        //小数部分
  127.                temp_d=a;
  128.             }
  129. }
  130. /*************************存储极限温度函数***************************/
  131. void store_t()
  132. {
  133.         if(f_max==1)                                         //若上限温度为负,将上限温度转换成有符号数(最高位为1是负,为0是正)
  134.         max=max+0x80;
  135.         if(f_min==1)                                         //若下限温度为负,将上限温度转换成有符号数
  136.         min=min+0x80;

  137.         ds18b20_init();                                 //DS18B20初始化
  138.         ds18b20_write(0xcc);                          //向DS18B20发跳过读ROM命令
  139.         ds18b20_write(0x4e);                         //向DS18B20发写字节至暂存器2和3(TH和TL)命令
  140.         ds18b20_write(max);                             //向暂存器TH(上限温度暂存器)写温度
  141.         ds18b20_write(min);                             //向暂存器TL(下限温度暂存器)写温度
  142.         ds18b20_write(0xff);                         //向配置寄存器写命令,进行温度值分辨率设置
  143.         ds18b20_init();                                 //DS18B20初始化
  144.         ds18b20_write(0xcc);                          //向DS18B20发跳过读ROM命令
  145.         ds18b20_write(0x48);                         //向DS18B20发将RAM中2、3字节的内容写入EEPROM
  146. }                                                                         //DS18B20上电后会自动将EEPROM中的上下限温度拷贝到TH、TL暂存器


  147. /**************************温度超限报警函数*************************/
  148. void alarm()
  149. {                                                                         //若上限值是正值
  150.           if(f_max==0)
  151.           {
  152.              if(f_min==0)                                 //若下限值是正值
  153.                  {
  154.                          if(f==0)                                 //若测量值是正值
  155.                          {
  156.                                  if((temp+temp_d*0.0625)<=min||(temp+temp_d*0.0625)>=max)
  157.                                  {w=1;TR1=1;}                 //当测量值小于最小值或大于最大值时报警
  158.                                  if((temp+temp_d*0.0625)<max&&(temp+temp_d*0.0625)>min)
  159.                                  {w=0;}                                 //当测量值大于最小值且小于最大值时不报警
  160.                          }
  161.                          if(f==1){w=1;TR1=1;}         //若测量值是负值时报警
  162.                  }
  163.              if(f_min==1)                                 //若下限值是负值
  164.                  {
  165.                           if(f==0)                                 //若测量值是正值
  166.                          {
  167.                                  if((temp+temp_d*0.0625)>=max)//当测量值大于最大值时报警
  168.                                  {w=1;TR1=1;}
  169.                                  if((temp+temp_d*0.0625)<max )//当测量值小于最大值时不报警
  170.                                  {w=0;}
  171.                          }
  172.                          if(f==1)                                 //若测量值是负值
  173.                          {
  174.                                  if((temp+temp_d*0.0625)>=min)//当测量值大于最小值时报警
  175.                                  {w=1;TR1=1;}
  176.                                  if((temp+temp_d*0.0625)<min)//当测量值小于最小值时不报警
  177.                                  {w=0;}
  178.                          }
  179.                  }
  180.           }

  181.           if(f_max==1)                                         //若下限值是负值
  182.           {
  183.              if(f_min==1)                                 //若下限值是负值
  184.                  {
  185.                          if(f==1)                                 //若测量值是负值
  186.                          {
  187.                                  if((temp+temp_d*0.0625)<=max||(temp+temp_d*0.0625)>=min)
  188.                                  {w=1;TR1=1;}                 //当测量值小于最大值或大于最小值时报警
  189.                                  if((temp+temp_d*0.0625)<min&&(temp+temp_d*0.0625)>max)
  190.                                  {w=0;}                                 //当测量值小于最小值且大于最大值时不报警
  191.                          }
  192.                          if(f==0){w=1;TR1=1;}         //若测量值是正值时报警
  193.                  }

  194.           }          
  195. }

  196. #endif
复制代码

键盘扫描文件:
  1. /**********************************************************************
  2. * 程序名;   ds18b20键盘头文件
  3. * 功  能:  通过键盘设定设定上下限报警温度
  4. * 编程者:  ZPZ
  5. * 编程时间:2009/10/2   
  6. **********************************************************************/
  7. #ifndef __keyscan_H__                                //定义头文件
  8. #define __keyscan_H__
  9.                
  10. sbit key1=P2^2;                                              //可位寻址变量定义,用key1表示P2.2口
  11. sbit key2=P2^1;                                                 //用key2表示P2.1口
  12. sbit key3=P2^0;                                                //用key3表示P2.0口
  13. sbit key4=P3^3;                                                //用key4表示P3.3口

  14. uchar i=0;                                                        //定义全局变量i用于不同功能模式的选择,‘0’正常模式,‘1’上限调节模式,‘2’下限调节模式
  15. uchar a=0;                                                    //定义全局变量a用于不同模式下数码管显示的选择
  16. bit          k4=0;                                                        //K4按键双功能选择位,k4=0时K4按键选择消按键音的功能,k4=1时K4按键选择正负温度设定功能
  17. bit   v=0;                                                        //K2、K3按键双功能选择位,v=0时选择上下限查看功能,v=1时选择上下限温度加减功能
  18. bit   v1=0;                                                        //v1=1时定时1250ms时间到自动关闭报警上下限查看功能
  19. bit   v2=0;                                        //消按键音功能调整位,为‘0’时开按键音,为‘1’时关按键音

  20. /***************************读键盘延时子函数**************************/
  21. void keyscan_delay(uint z)                        //延时1ms左右
  22. {
  23.   uint i,j;
  24.   for(i=z;i>0;i--)
  25.         for(j=120;j>0;j--);
  26. }

  27. /****************************温度调节函数******************************/
  28. int temp_change(int count,bit f)        //上下限温度调整
  29. {
  30.     if(key2==0)                                                //判断K2是否按下
  31.         {                                                               
  32.             if(v2==0)beer=0;                        //v2=0开按键音,否则消按键音
  33.                 keyscan_delay(10);                        //延时10ms
  34.                 if(key2==0)                                        //再次判断K2是否按下(实现按按键时消抖)
  35.                 {                  
  36.                    beer=1;                                        //K2按下关按键音
  37.                    if(f==0)                                        //若温度为正
  38.                    {  
  39.                       count++;                                //每按一下K2温度上调1
  40.                       if(a==1){if(count>125) count=125;}//当温度值大于125时不上调
  41.                           if(a==2){if(count>125) count=125;}
  42.                    }
  43.                    if(f!=0)                                        //若温度为负
  44.                    {                     
  45.                           count++;                                //每按一下K2温度下调1
  46.                           if(a==1){if(count>55) count=55;}//当温度值小于-55时不再下调
  47.                           if(a==2){if(count>55) count=55;}
  48.                    }
  49.                 }
  50.                 while(key2==0);                                //K2松开按键时消抖
  51.                 keyscan_delay(10);
  52.        
  53.         }
  54.         if(key3==0)
  55.         {
  56.             if(v2==0)beer=0;
  57.                 keyscan_delay(10);
  58.                 if(key3==0)                                    //K3按按键时消抖
  59.                 {
  60.                     beer=1;
  61.                            count--;                                //每按一下K3温度为正时下调1,为负时上调1
  62.                         if(a==1){if(count<0) count=0;}//当温度值达到0时不再调
  63.                         if(a==2){if(count<0) count=0;}       
  64.                 }
  65.                 while(key3==0);
  66.                 keyscan_delay(10);                        //K3松开按键时消抖
  67.        
  68.         }
  69.         return count;
  70. }
  71. /*****************************读键盘函数******************************/
  72. void keyscan()
  73. {
  74.          
  75.         if(key1==0)
  76.         {
  77.             if(v2==0)beer=0;
  78.                 keyscan_delay(10);
  79.                 if(key1==0)                                        //K1按按键时消抖
  80.                 {
  81.                    beer=1;
  82.                    TR1=1;                                           //开定时器1,通过s标志位的变化,实现在上下限温度调整时温度显示时闪烁的功能                  
  83.                    k4=1;                                        //在上下温度调节功能模式下选择K4的调整上下限温度正负的功能
  84.                    v=1;                                                //在上下温度调节功能模式下选择K2、K3的温度加减功能
  85.                    i++;                                                   //K1按一下i加1,i=‘0’进入正常模式,i=‘1’进入调上限模式,i=‘2’进入调下限模式
  86.                    if(i>2)                                        //K1按下三次后退出调节模式
  87.                    {
  88.                        i=0;                                        //进入正常模式
  89.                            TR1=0;                                //关定时器1
  90.                            k4=0;                                //在正常模式下选择K4的消按键音功能
  91.                            v=0;                                        //在正常模式下选择K2、K3的查看上下限报警温度功能
  92.                            store_t();                        //存储调整后的上下限报警温度
  93.                    }                  
  94.                    switch(i)                                //显示选择
  95.                    {
  96.                        case 0:a=0;break;        //a=0选择显示测得的温度
  97.                            case 1:a=1;break;    //a=1选择显示上限温度
  98.                            case 2:a=2;break;    //a=2选择显示下限温度
  99.                           
  100.                            default:break;
  101.                    }
  102.                           
  103.                 }
  104.                 while(key1==0);                                //K1松按键时消抖
  105.                 keyscan_delay(10);
  106.                
  107.         }
  108.         if(a==1&&v==1)                                        //a=1选择显示上限温度且v=1时选择上下限温度加功能
  109.         {led=0;max=temp_change(max,f_max);}//显示上限温度
  110.         else if(a==2&&v==1)                                //a=2选择显示下限温度且v=1时选择上下限温度减功能
  111.         {led=1;min=temp_change(min,f_min);}
  112.         else;
  113.         if(k4==1)                                                //k4=1时K4按键选择正负温度设定功能
  114.         {
  115.                 if(key4==0)
  116.                 {
  117.                     if(v2==0)beer=0;
  118.                         keyscan_delay(5);
  119.                         if(key4==0)
  120.                         {
  121.                            beer=1;
  122.                            if(a==1)
  123.                            {if(max>55) f_max=0;else f_max=~f_max;}//当温度大于55度时,只能设定为正温度
  124.                            if(a==2)
  125.                            {if(min>55) f_max=0;else f_min=~f_min;}//当温度大于55度时,只能设定为正温度                                  
  126.                         }
  127.                         while(key4==0);
  128.                         keyscan_delay(10);
  129.                 }
  130.         }
  131.        
  132.         if(v==0)                                                 //v=0时选择上下限查看功能
  133.         {
  134.                 if(key2==0)
  135.                 {
  136.                     if(v2==0)beer=0;
  137.                         keyscan_delay(10);
  138.                         if(key2==0)
  139.                         {
  140.                            beer=1;
  141.                            a=1;                                        //选择上限显示
  142.                            TR1=1;                                //开定时器1开始定时一分钟左右
  143.                            s1=1;                                   //上限显示不闪烁,显示一分钟左右自动退出
  144.                         }
  145.                         while(key2==0);
  146.                         keyscan_delay(10);
  147.                        
  148.                 }
  149.                 if(key3==0)
  150.                 {
  151.                     if(v2==0)beer=0;
  152.                         keyscan_delay(10);
  153.                         if(key3==0)
  154.                         {
  155.                            beer=1;
  156.                            a=2;                                        //选择下限显示
  157.                            TR1=1;                                //开定时器1开始定时1s
  158.                            s1=1;                                   //下限显示不闪烁,显示1s自动退出                          
  159.                         }
  160.                         while(key3==0);
  161.                         keyscan_delay(10);
  162.                        
  163.                 }
  164.                 if(v1==1)                                   //v1=1时定时1s时间到自动关闭报警上下限查看功能
  165.                 {a=0;v1=0;TR1=0;}                   //a=0显示实测温度,v1清零,关定时器1
  166.                 if(k4==0)                                   //k4=0时K4按键选择消按键音的功能
  167.                 {                                                  
  168.                         if(key4==0)
  169.                         {
  170.                                 if(v2==0)beer=0;
  171.                                 keyscan_delay(10);
  172.                                 if(key4==0)
  173.                                 {
  174.                                    beer=1;
  175.                                    v2=~v2;                        //为‘0’时开按键音,为‘1’时关按键音                                     
  176.                                 }
  177.                                 while(key4==0);
  178.                                 keyscan_delay(10);
  179.                     }               
  180.                 }
  181.         }        
  182. }

  183. #endif
复制代码



全部资料51黑下载地址: 基于51单片机及DS18B20温度传感器的数字温度计设计.rar (704.05 KB, 下载次数: 1050)




作者: mnbvcxzlkjhgfds    时间: 2016-3-19 23:23
失败........
作者: mnbvcxzlkjhgfds    时间: 2016-3-19 23:25
失败是成功之母
作者: pengrubin    时间: 2016-8-6 21:37
失败是成功之母
作者: pengrubin    时间: 2016-8-14 11:22
很好,可以实际使用了。
作者: zryZRY    时间: 2016-12-16 12:35
顶!顶!顶!顶!顶!顶!
作者: lv123456    时间: 2017-3-13 22:00
顶!顶!顶!顶!失败了!
作者: yeeze    时间: 2017-3-14 12:02
失败是成功之母
作者: hshang333    时间: 2017-4-4 08:49
很好,值得学习,虽然自己弄总是有点小差错
作者: fxad    时间: 2017-4-18 18:28
这个对我很有帮助
作者: 9998钰    时间: 2017-5-22 15:23
那个h文件是直接添加在c文件里面的吗
作者: 9998钰    时间: 2017-5-22 15:25
下载一个串口驱动行不行啊,一定要那个USB串口下载吗
作者: 123411    时间: 2017-6-17 12:55
很不错
作者: 884888488848    时间: 2017-9-19 11:08
很好用,有借鉴意义
作者: hanh    时间: 2017-10-10 09:52
很好用,有借鉴意义
作者: piapink    时间: 2017-12-6 20:48
好棒 可惜积分不够怎么办呢
作者: 可疑的南瓜    时间: 2018-1-5 16:41
很好,可以实际使用了
作者: October__    时间: 2018-1-5 16:59
不错不错
作者: kgz945643524    时间: 2018-1-5 20:13
厉害了大腿啊
作者: kgz945643524    时间: 2018-1-5 20:14
有重要学习意义啊啊啊
作者: kgz945643524    时间: 2018-1-5 20:18
大腿呀,多谢分享
作者: zyt@0121    时间: 2018-1-6 12:50
很赞 ,我写的一个显示不了,正好可以借鉴一下。
作者: o876291531    时间: 2018-1-8 16:09
很厉害很厉害啊!!
作者: h2o1    时间: 2018-1-27 14:59
#在这里 谢谢分享!~~~~~~~~~下个收藏快速回复#
作者: minlingshuai    时间: 2018-4-17 17:46
这个给力,点赞
作者: haojie950113    时间: 2018-4-17 19:23
厉害,受教了
作者: Live电子    时间: 2018-5-15 09:35
谢谢,分享
作者: fcdls    时间: 2018-5-28 14:26
十分有用谢谢大神
作者: 拒绝燃烧的煤    时间: 2018-5-29 20:33
所有的都是自己diy的吗,厉害了
作者: wyx15100087    时间: 2018-5-31 22:37
点赞,真厉害

作者: SADong    时间: 2018-6-2 10:54
为什么下载文件被组阻止了
作者: lemon611    时间: 2018-6-5 12:46
因为这个注册的
作者: a1357787200    时间: 2018-6-8 11:11
优秀优秀
作者: 李浩_Haoy    时间: 2018-6-19 11:51
现在我也在做这个 很有参考价值!谢谢!
作者: BOBNIE    时间: 2018-6-23 23:04
厉害,很赞

作者: 0123.    时间: 2018-9-9 09:49
感觉很不错,但是为什么,
设计报告中的单片机是at89s52,
仿真和原理图都是at89c51,
然后,器件列表是STC89C52
作者: 天天天天凡    时间: 2018-10-30 15:58
非常有用的资料
作者: 灭雷决88    时间: 2018-10-31 15:00
很垃圾太复杂
作者: 123w123    时间: 2018-11-2 20:31
很棒 很实用
作者: Easonqp    时间: 2018-12-6 12:43
太棒啦

作者: Easonqp    时间: 2018-12-6 12:50
感觉很厉害 可惜我没有币去下载
作者: 公寓3    时间: 2018-12-20 17:24
BOBNIE 发表于 2018-6-23 23:04
厉害,很赞

非常厉害,很棒
作者: 公寓3    时间: 2018-12-21 10:03
非常棒
作者: xiaozhiTZM    时间: 2018-12-21 14:04
好东西  谢谢分享
作者: xiaozhiTZM    时间: 2018-12-21 19:27
好东西  一起学习交流
作者: 陈鹏飞15    时间: 2019-1-15 23:23
写的很详细,研究一下
作者: wmw336    时间: 2019-1-16 01:19
很给力
作者: 无奇    时间: 2019-4-24 18:10
赞赞赞
作者: 44tt    时间: 2019-4-25 17:20
优秀实用
作者: xxxxxoooooo    时间: 2019-4-27 11:08
nice!!
作者: zhao1999250    时间: 2019-4-27 14:08
优秀!支持!
作者: 王成昊    时间: 2019-5-24 20:28
非常有帮助的一个资料 正在做这个
作者: 小道不道    时间: 2019-5-29 09:35
谢谢,对我太有帮助了!
作者: xiaojingang    时间: 2019-5-29 15:32
棒棒哒
作者: bubu..    时间: 2019-11-28 13:15
很有帮助,谢谢
作者: Auorora    时间: 2019-12-4 16:51
真棒,顶一个
作者: 888--    时间: 2019-12-7 23:22
我自己也设计了一个,失败了。来参考下楼主的
作者: lufanghuai    时间: 2019-12-24 13:36
emmmm。。。可惜积分不够
作者: 2228048982    时间: 2019-12-26 12:00
设计很全面,很详细,厉害厉害厉害
作者: liqingyundmtech    时间: 2020-1-7 20:05
现在我也在做这个 很有参考价值
作者: 刘锦辉    时间: 2020-3-17 22:05
里面那些头文件的资料
作者: XUWENQIANG    时间: 2020-3-25 04:26
刘锦辉 发表于 2020-3-17 22:05
里面那些头文件的资料

我也发现这个问题了,希望作者能上传一下
作者: lianghao567    时间: 2020-5-27 15:01
怎么搞的啊,搞不透。
作者: Zhang511    时间: 2020-6-1 10:00
厉害呀

作者: dhz0105    时间: 2020-6-5 15:56
厉害,感谢分享,学习一下
作者: gqzjl    时间: 2020-6-6 08:03
失败是成功之母
作者: user_Qian    时间: 2020-6-9 15:17
666厉害了
作者: xin16    时间: 2020-6-10 19:48
真的给;力,太全了,感谢感谢
作者: 守夜灬    时间: 2020-6-11 10:03
非常感谢 很棒 很实用 就是可惜原文件中没有proteus仿真
作者: 断丿凯Wild    时间: 2020-6-12 23:27
哇! 很有借鉴学习的意义 去试着学习 根据这个去研究学习真的有帮助
作者: 罗伦斯    时间: 2020-6-13 10:46
给力,对我帮助很大
作者: 子尧木易    时间: 2020-6-19 07:56
感谢分享。
作者: rayin    时间: 2020-11-15 17:19
不错,值得学习。51hei有你更精彩!!
作者: cwz666    时间: 2021-6-25 07:44
建议把温度显示在LED1602上面,然后加一个初始化LED1602初始化和把蜂鸣器报警换成LED闪烁报警会更好。
作者: jiangxinhong    时间: 2021-12-20 20:04
咱就是说
可以显示负数嘛

作者: xiuquan523    时间: 2021-12-28 17:38

失败是成功之母
作者: dhbt2021    时间: 2022-2-5 21:05
优秀。厉害,很有借鉴意义!!!!!!!!!
作者: wrlyhh    时间: 2022-3-22 13:56
试试吧 但愿好用
作者: 红花无常    时间: 2022-5-3 13:58
辛苦了,又重温了一遍,这个比我以前看的学习资料多了一个阀值报警功能。ds18b20的代码比较常见,如果是PT100和表面热电偶的测温方案就好了。
作者: joe_2019    时间: 2022-12-28 10:43
非常的棒,来学习一下




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1