找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机+DS1621温度串口显示程序 Proteus仿真

[复制链接]
跳转到指定楼层
楼主
DS1621温度串口显示温度    不同于DS18B20
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)



单片机源程序如下:
  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. ……………………

  180. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei附件下载:
DS1621温度传感器实验.7z (36.84 KB, 下载次数: 34)


评分

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

查看全部评分

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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