找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5203|回复: 1
收起左侧

DS18B20仿真+实际制作

[复制链接]
ID:241586 发表于 2017-12-21 18:37 | 显示全部楼层 |阅读模式
DS18B20.jpg QQ图片20171221183210.png t01e38a1a940fdda20f.jpg

单片机源程序如下:
  1. #include <reg52.h>
  2. #include <intrins.h>
  3. #define uint unsigned int
  4. #define uchar unsigned char
  5. bit I2C_Busy, NO_Ack,Bus_Fault,point;

  6. uchar bdata a;
  7. sbit LSB = a^0;
  8. sbit MSB = a^7;
  9. sbit SDA = P3^3;
  10. sbit SCL = P3^2;
  11. uchar Array[] = {'0','1','2','3','4','5','6','7','8','9'};
  12. uchar command_data[]=
  13. {
  14.          0xac,0x00,0xee,0xa1,0x00,0x00,0xa2,0x00,0x00,0xaa
  15. };
  16. uchar Prompt[]="Waiting for a while...\r";
  17. uchar i;
  18. void DelayMS(uint ms)
  19. {
  20.          uchar i;
  21.         while(ms--)
  22.         {
  23.                  for(i=0;i<120;i++);
  24.         }
  25. }

  26. void SendStop()
  27. {
  28.          SDA = 0;
  29.         SCL = 1;
  30.         _nop_();
  31.         SDA = 1;
  32.         I2C_Busy = 0;
  33. }

  34. void SendByte(uchar wd)
  35. {
  36.          uchar i;
  37.         a = wd;
  38.         for(i=0;i<8;i++)
  39.         {
  40.                  SCL = 0;
  41.                 _nop_();
  42.                 _nop_();
  43.                 SDA = MSB;
  44.                 a <<= 1;
  45.                 _nop_();
  46.                 _nop_();
  47.                 SCL = 1;
  48.                 _nop_();
  49.                 _nop_();
  50.                 SCL = 0;
  51.         }
  52.         SDA = 1;
  53.         SCL = 1;
  54.         _nop_();
  55.         _nop_();

  56.         if(!SDA)
  57.         {
  58.                  SCL = 0;
  59.                 _nop_();
  60.                 _nop_();
  61.         }
  62.         else
  63.         {
  64.                  NO_Ack = 1;
  65.                 SCL = 0;
  66.                 _nop_();
  67.                 _nop_();
  68.         }
  69. }

  70. void Master(uchar slave_addr)
  71. {

  72.          I2C_Busy = 1;
  73.         NO_Ack = 0;
  74.         Bus_Fault = 0;
  75.         if(!SCL || !SDA)
  76.                 Bus_Fault = 1;
  77.         else
  78.         {
  79.                  SDA = 0;
  80.                 _nop_();
  81.                 _nop_();
  82.                 SCL = 0;
  83.                 _nop_();
  84.                 _nop_();
  85.                 SendByte(slave_addr);
  86.         }
  87. }

  88. uchar RecvByte(uchar cnt)
  89. {
  90.         uchar i,rcv_data;
  91.         for(i=0;i<8;i++)
  92.         {
  93.                  SDA = 1;
  94.                 SCL = 1;
  95.                 _nop_();
  96.                 LSB = SDA;
  97.                 if(i<7)
  98.                         a <<= 1;
  99.                 _nop_();
  100.                 SCL = 0;
  101.                 _nop_();
  102.         }
  103.         
  104.         if(cnt == 1)
  105.                 SDA = 1;
  106.         else
  107.                 SDA = 0;
  108.         SCL = 1;
  109.         _nop_();
  110.         SCL = 0;
  111.         SDA = 1;
  112.         _nop_();
  113.         rcv_data = a;
  114.         return rcv_data;        
  115. }

  116. void SendData(uchar slave_address,uchar start,uchar end)
  117. {
  118.          Master(slave_address);
  119.         for(i=start;i<=end;i++)
  120.                 SendByte(command_data[i]);        
  121.         SendStop();
  122. }

  123. void InitialiseSerialPort()
  124. {
  125.          TMOD = 0x20;
  126.         TH1  = 0xfd;
  127.         SCON = 0x50;
  128.         TR1  = 1;
  129. }

  130. void SendCharToSerialPort(uchar ch)
  131. {
  132.          SBUF = ch;
  133.         while(!TI);
  134.         TI = 0;
  135. }

  136. void SendTemperatureToSerialPort(uchar val)
  137. {
  138.          if(val>200)
  139.         {
  140.                  val = 255-val;
  141.                 SendCharToSerialPort('-');
  142.                 if(!point)
  143.                         val+=1;
  144.         }
  145.         SendCharToSerialPort(Array[(val/10)/10]);
  146.         SendCharToSerialPort(Array[(val/10)%10]);
  147.         SendCharToSerialPort(Array[val%10]);
  148.         SendCharToSerialPort('.');
  149.         if(point)
  150.                 SendCharToSerialPort('5');
  151.         else
  152.                 SendCharToSerialPort('0');
  153.         SendCharToSerialPort(' ');
  154.         SendCharToSerialPort('C');
  155.         SendCharToSerialPort('\r');        
  156. }

  157. void SetTemperatureLimit(uchar HI,uchar LO)
  158. {
  159.         command_data[4] = HI;
  160.         command_data[5]        = 0;
  161.         command_data[7] = LO;
  162.         command_data[8] = 0;
  163.         SendData(0x90,3,5);
  164.         DelayMS(10);
  165.         SendData(0x90,6,8);        
  166. }

  167. void StartConversion()
  168. {
  169.          SendData(0x90,2,2);
  170.         DelayMS(750);
  171. }

  172. uchar ReadTemp()
  173. {
  174.          uchar d;
  175.         SendData(0x90,9,9);
  176.         Master(0x91);
  177.         d = RecvByte(0);
  178.         point = RecvByte(1)>>7;
  179.         SendStop();
  180.         return d;
  181. }

  182. void WriteConfig(uchar c)
  183. {
  184.          command_data[1] = c;
  185.         SendData(0x90,0,1);               
  186. }

  187. void main()
  188. {
  189.          uchar i;
  190.            InitialiseSerialPort();
  191.         while(Prompt[i]!='\0')
  192.                 SendCharToSerialPort(Prompt[i++]);
  193.         WriteConfig(0x02);
  194.         StartConversion();
  195.         SetTemperatureLimit(40,35);
  196.         while(1)
  197.         {
  198.                  DelayMS(50);
  199.                 SendTemperatureToSerialPort(ReadTemp());
  200.         }        
  201. }
复制代码

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

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:742468 发表于 2020-6-2 11:45 | 显示全部楼层
好东西 谢谢分享
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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