找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3452|回復: 1
收起左側(cè)

單片機多點溫度測量程序及仿真使用1602液晶顯示

[復制鏈接]
ID:137190 發(fā)表于 2016-8-20 22:17 | 顯示全部樓層 |閱讀模式
51單片機多點溫度測量的仿真原理圖:
0.png
多點溫度測量程序:
  1. //頭文件包含
  2. #include <AT89X51.H>
  3. #include <Intrins.h>
  4. #include "DS18B20.H"

  5. //引腳定義
  6. sbit                                                         DQ = P2^7;                                                        //數(shù)據(jù)線端口

  7. //DS18B20序列號,通過調(diào)用GetROMSequence()函數(shù)在P1口讀出(讀8次)
  8. const unsigned char code ROMData1[8] = {0x28, 0x33, 0xC5, 0xB8, 0x00, 0x00, 0x00, 0xD7};        //U1
  9. const unsigned char code ROMData2[8] = {0x28, 0x30, 0xC5, 0xB8, 0x00, 0x00, 0x00, 0x8E};        //U2
  10. const unsigned char code ROMData3[8] = {0x28, 0x31, 0xC5, 0xB8, 0x00, 0x00, 0x00, 0xB9};        //U3
  11. const unsigned char code ROMData4[8] = {0x28, 0x32, 0xC5, 0xB8, 0x00, 0x00, 0x00, 0xE0};        //U4
  12. const unsigned char code ROMData5[8] = {0x28, 0x34, 0xC5, 0xB8, 0x00, 0x00, 0x00, 0x52};        //U5
  13. const unsigned char code ROMData6[8] = {0x28, 0x35, 0xC5, 0xB8, 0x00, 0x00, 0x00, 0x65};        //U6
  14. const unsigned char code ROMData7[8] = {0x28, 0x36, 0xC5, 0xB8, 0x00, 0x00, 0x00, 0x3C};        //U7
  15. const unsigned char code ROMData8[8] = {0x28, 0x37, 0xC5, 0xB8, 0x00, 0x00, 0x00, 0x0B};        //U8

  16. //延時16us子函數(shù)
  17. void Delay16us()
  18. {
  19.         unsigned char a;

  20.         for (a = 0; a < 4; a++);
  21. }

  22. //延時60us子函數(shù)
  23. void Delay60us()
  24. {
  25.         unsigned char a;

  26.         for (a = 0; a < 18; a++);
  27. }

  28. //延時480us子函數(shù)
  29. void Delay480us()
  30. {
  31.         unsigned char a;

  32.         for (a = 0; a < 158; a++);
  33. }

  34. //延時240us子函數(shù)
  35. void Delay240us()
  36. {
  37.         unsigned char a;

  38.         for (a = 0; a < 78; a++);
  39. }

  40. //延時500ms子函數(shù)
  41. void Delay500ms()
  42. {
  43.         unsigned char a, b, c;

  44.         for (a = 0; a < 250; a++)
  45.         for (b = 0; b < 3; b++)
  46.         for (c = 0; c < 220; c++);
  47. }

  48. //芯片初始化
  49. void Initialization()
  50. {
  51.         while(1)
  52.         {
  53.                 DQ = 0;
  54.                 Delay480us();                         //延時480us
  55.                 DQ = 1;
  56.                 Delay60us();                        //延時60us
  57.                 if(!DQ)                                  //收到ds18b20的應答信號
  58.                 {       
  59.                         DQ = 1;
  60.                         Delay240us();                //延時240us
  61.                         break;               
  62.                 }
  63.         }
  64. }

  65. //寫一個字節(jié)(從低位開始寫)
  66. void WriteByte(unsigned char btData)
  67. {
  68.         unsigned char i, btBuffer;

  69.         for (i = 0; i < 8; i++)
  70.         {
  71.                 btBuffer = btData >> i;
  72.                 if (btBuffer & 1)
  73.                 {
  74.                         DQ = 0;
  75.                         _nop_();
  76.                         _nop_();
  77.                         DQ = 1;
  78.                         Delay60us();
  79.                 }
  80.                 else
  81.                 {
  82.                         DQ = 0;
  83.                         Delay60us();
  84.                         DQ = 1;                       
  85.                 }
  86.         }
  87. }

  88. //讀一個字節(jié)(從低位開始讀)
  89. unsigned char ReadByte()
  90. {
  91.         unsigned char i, btDest;

  92.         for (i = 0; i < 8; i++)
  93.         {
  94.                 btDest >>= 1;
  95.                 DQ = 0;
  96.                 _nop_();
  97.                 _nop_();
  98.                 DQ = 1;
  99.                 Delay16us();
  100.                 if (DQ) btDest |= 0x80;
  101.                 Delay60us();
  102.         }

  103.         return btDest;
  104. }

  105. //序列號匹配
  106. void MatchROM(const unsigned char *pMatchData)
  107. {
  108.         unsigned char i;

  109.         Initialization();
  110.         WriteByte(MATCH_ROM);
  111.         for (i = 0; i < 8; i++) WriteByte(*(pMatchData + i));       
  112. }

  113. //得到64位ROM序列(在P1口顯示,必須與Proteus聯(lián)調(diào)且在單步調(diào)試下才能得到)
  114. /*void GetROMSequence()
  115. {
  116.         unsigned char i;

  117.         Initialization();
  118.         WriteByte(READ_ROM);
  119.         for (i = 0; i < 8; i++)
  120.         P1 = ReadByte();       
  121. }*/

  122. //讀取溫度值
  123. TEMPDATA ReadTemperature()
  124. {
  125.         TEMPDATA TempData;
  126.         unsigned int iTempDataH;
  127.         unsigned char btDot, iTempDataL;
  128.         static unsigned char i = 0;

  129.         TempData.btNegative = 0;                                                //為0溫度為正
  130.         i++;
  131.         if (i == 9) i = 1;
  132.         Initialization();
  133.         WriteByte(SKIP_ROM);                                                        //跳過ROM匹配
  134.         WriteByte(TEMP_SWITCH);                                                        //啟動轉(zhuǎn)換
  135.         Delay500ms();                                                                          //調(diào)用一次就行       
  136.         Delay500ms();                         
  137.         Initialization();

  138.         //多個芯片的時候用MatchROM(ROMData)換掉WriteByte(SKIP_ROM)
  139.         switch (i)
  140.         {
  141.                 case 1 : MatchROM(ROMData1); break;                        //匹配1
  142.                 case 2 : MatchROM(ROMData2); break;                        //匹配2
  143.                 case 3 : MatchROM(ROMData3); break;                        //匹配3
  144.                 case 4 : MatchROM(ROMData4); break;                        //匹配4       
  145.                 case 5 : MatchROM(ROMData5); break;                        //匹配5
  146.                 case 6 : MatchROM(ROMData6); break;                        //匹配6
  147.                 case 7 : MatchROM(ROMData7); break;                        //匹配7
  148.                 case 8 : MatchROM(ROMData8); break;                        //匹配8
  149.         }
  150.         //WriteByte(SKIP_ROM);                                                        //跳過ROM匹配(單個芯片時用這句換掉上面的switch)
  151.         WriteByte(READ_MEMORY);                                                        //讀數(shù)據(jù)
  152.         iTempDataL = ReadByte();
  153.         iTempDataH = ReadByte();       
  154.         iTempDataH <<= 8;
  155.         iTempDataH |= iTempDataL;

  156.         if (iTempDataH & 0x8000)
  157.         {
  158.                 TempData.btNegative = 1;
  159.                 iTempDataH = ~iTempDataH + 1;                                //負數(shù)求補
  160.         }

  161.         //為了省去浮點運算帶來的開銷,而采用整數(shù)和小數(shù)部分分開處理的方法(沒有四舍五入)
  162.         btDot = (unsigned char)(iTempDataH & 0x000F);        //得到小數(shù)部分
  163.         iTempDataH >>= 4;                                                                //得到整數(shù)部分
  164.         btDot *= 5;                                                                         //btDot*10/16得到轉(zhuǎn)換后的小數(shù)數(shù)據(jù)
  165.         btDot >>= 3;

  166.         //數(shù)據(jù)處理
  167.         TempData.btThird   = (unsigned char)iTempDataH / 100;
  168.         TempData.btSecond  = (unsigned char)iTempDataH % 100 / 10;
  169.         TempData.btFirst   = (unsigned char)iTempDataH % 10;
  170.         TempData.btDecimal = btDot;       

  171.         return TempData;
  172. }
復制代碼



0.png


多點溫度測量.rar

76.02 KB, 下載次數(shù): 36, 下載積分: 黑幣 -5

相關(guān)帖子

回復

使用道具 舉報

ID:127977 發(fā)表于 2016-8-21 15:45 | 顯示全部樓層
樓主厲害啊,感謝分享
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表