找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5656|回复: 2
收起左侧

基于DS18B20的温控系统仿真和单片机程序源码

[复制链接]
ID:351886 发表于 2018-6-14 15:12 | 显示全部楼层 |阅读模式
基于DS18B20的温控系统仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
0.png 0.png

单片机源程序如下:
  1.                      //安装目录下的EXE文件打开后可在电脑上显示当前温度值
  2. #include <reg52.h>
  3. #define uchar unsigned char
  4. #define uint unsigned int

  5. sbit DS=P2^7;          //温度传感器信号线
  6. sbit dula=P2^0;                   //数码管段选线
  7. sbit wela=P2^1;                   //数码管位选线

  8. uint temp;             //定义整型的温度数据
  9. float f_temp;
  10. sbit beep=P3^7;        //蜂鸣器
  11. sbit led0=P1^0;        //模拟开启制热设备,伴随着led0发光二极管闪烁,蜂鸣器慢”滴”声报警
  12. sbit led1=P1^1;        //模拟加大制热设备功率,伴随着led0,led1发光二极管一起闪烁,蜂鸣器快”滴”声报警
  13. sbit led2=P1^2;        //模拟开启制冷设备,伴随着led2发光二极管闪烁,蜂鸣器慢”滴”声报警
  14. sbit led3=P1^3;        //模拟加大制冷设备功率,伴随着led2,led3发光二极管一起闪烁,蜂鸣器快”滴”声报警
  15. uint warn_11=270;      //定义温度下限值  是温度值乘以10以后的结果
  16. uint warn_12=250;      //定义温度下限值
  17. uint warn_h1=300;      //定义温度上限值
  18. uint warn_h2=320;      //定义温度上限值

  19. unsigned char code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,
  20.                         0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};//带小数点的0-9编码
  21. unsigned char code table1[]={0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd,
  22.                         0x87,0xff,0xef};//不带小数点的0-9编码


  23. void delay(uint count)      //delay函数
  24. {
  25.         uint i;
  26.         while(count)
  27.         {
  28.                 i=200;
  29.                 while(i>0)
  30.                 i--;
  31.                 count--;
  32.         }
  33. }

  34. void dsreset(void)       //DS18B20复位,初始化函数
  35. {
  36.         uint i;
  37.         DS=0;
  38.         i=103;
  39.         while(i>0)i--;
  40.         DS=1;
  41.         i=4;
  42.         while(i>0)i--;
  43. }

  44. bit tempreadbit(void)      //读1位数据函数
  45. {
  46.         uint i;
  47.         bit dat;
  48.         DS=0;i++;          //i++ 起延时作用
  49.         DS=1;i++;i++;
  50.         dat=DS;
  51.         i=8;while(i>0)i--;
  52.         return (dat);
  53. }

  54. uchar tempread(void)   //读1字节数据函数
  55. {
  56.         uchar i,j,dat;
  57.         dat=0;
  58.         for(i=1;i<=8;i++)
  59.         {
  60.                 j=tempreadbit();
  61.                 dat=(j<<7)|(dat>>1);   //读出的数据最低位在最前面,这样刚好一个字节在DAT里
  62.         }
  63.         return(dat);
  64. }

  65. void tempwritebyte(uchar dat)   //向ds18b20写一个字节数据函数
  66. {
  67.         uint i;
  68.         uchar j;
  69.         bit testb;
  70.         for(j=1;j<=8;j++)
  71.         {
  72.                 testb=dat&0x01;
  73.                 dat=dat>>1;
  74.                 if(testb)     //写1
  75.                 {
  76.                         DS=0;
  77.                         i++;i++;
  78.                         DS=1;
  79.                         i=8;while(i>0)i--;
  80.                 }
  81.                 else
  82.                 {
  83.                         DS=0;       //写0
  84.                         i=8;while(i>0)i--;
  85.                         DS=1;
  86.                         i++;i++;
  87.                 }       
  88.         }
  89. }

  90. void tempchange(void)  //DS18B20开始获取温度并转换
  91. {
  92.         dsreset();
  93.         delay(1);
  94.         tempwritebyte(0xcc);  // 写跳过读ROM指令
  95.         tempwritebyte(0x44);  // 写温度转换指令
  96. }

  97. uint get_temp()             //读取寄存器中存储的温度数据
  98. {
  99.   
  100.         uchar a,b;
  101.         dsreset();
  102.         delay(1);
  103.         tempwritebyte(0xcc);
  104.         tempwritebyte(0xbe);
  105.         a=tempread();                        //读低8位
  106.         b=tempread();                        //读高8位
  107.         temp=b;
  108.         temp<<=8;             //两个字节组合为1个字节
  109.         temp=temp|a;
  110.         f_temp=temp*0.0625;                //温度在寄存器中为12位,分辨*0.0625
  111.         temp=f_temp*10+0.5;                //temp是整型
  112.         return temp;
  113. }


  114. void display(uint temp)                        //数据显示程序
  115. {                                                               
  116.         uchar A1,A2,A3;

  117.         A1=temp/100;
  118.         A2=temp%100/10;
  119.         A3=temp%10;

  120.         wela=1;
  121.         P0=0x7e;
  122.         wela=0;

  123.         dula=1;
  124.         P0=table[A1];                //显示百位
  125.         dula=0;       
  126.         delay(1);
  127.        
  128.         wela=1;
  129.         P0=0x7d;
  130.         wela=0;

  131.         dula=1;
  132.         P0=table1[A2];                //显示十位
  133.         dula=0;
  134.         delay(1);
  135.        
  136.         wela=1;
  137.         P0=0x7b;
  138.         wela=0;
  139.        
  140.         dula=1;
  141.         P0=table[A3];                //显示个位
  142.         dula=0;       
  143.         delay(1);
  144. }


  145. void warn(uint s, uchar led)  //报警显示
  146. {
  147.         uchar i;i=s;
  148.         beep=0;
  149.         P1=~(led);
  150.         while(i--)
  151.         {
  152.                 display(get_temp());
  153.         }
  154.         beep=1;
  155.         P1=0xff;
  156.         i=s;
  157.         while(i--)
  158.         {
  159.                 display(get_temp());
  160.         }
  161. }

  162. void deal(uint t)  //温度处理函数
  163. {
  164.         uchar i;
  165.         if((t>warn_12)&&(t<=warn_11))
  166.         {
  167.                 warn(40,0x01);
  168.         }
  169.         else if(t<=warn_12)
  170.         {
  171.                 warn(10,0x03);
  172.         }
  173.         else if((t<warn_h2)&&(t>=warn_h1))
  174.         {
  175.                 warn(40,0x04);
  176.         }
  177.         else if(t>=warn_h2)
  178.         {
  179.                 warn(10,0x0c);
  180.         }
  181.         else
  182.         {
  183.                 i=40;
  184.                 while(i--)
  185.                 {
  186.                         display(get_temp());
  187.                 }
  188.         }
  189. }



  190. void main()
  191. {

  192.         uchar a;

  193.         while(1)
  194.         {
  195.                 tempchange();
  196.                 get_temp();
  197.                 deal(temp);
  198.                
  199.                 for(a=10;a>0;a--)
  200.                 {   
  201.                         display(get_temp());
  202.                 }
  203.         }               

  204. }
复制代码

所有资料51hei提供下载:
DS18B20.zip (67.9 KB, 下载次数: 89)


回复

使用道具 举报

ID:418389 发表于 2018-10-31 10:48 | 显示全部楼层
代码写得很整齐,水平高
回复

使用道具 举报

ID:493382 发表于 2019-4-12 13:25 | 显示全部楼层
安装目录下的EXE文件在哪里的,没有懂起
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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