找回密码
 立即注册

QQ登录

只需一步,快速开始

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

温度传感器实验

[复制链接]
跳转到指定楼层
楼主
ID:376535 发表于 2018-7-24 17:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. /**************************************************************************************
  2. *                              DS18B20温度传感器实验                                                                                                  *
  3. 实现现象:下载程序后,在温度传感器接口处,按照丝印方向插好温度传感器,数码管就会显示
  4.                         检测的温度值,
  5. 注意事项:                                                                                                                                                                  
  6. ***************************************************************************************/

  7. #include "reg52.h"                         //此文件中定义了单片机的一些特殊功能寄存器
  8. #include"temp.h"        

  9. typedef unsigned int u16;          //对数据类型进行声明定义
  10. typedef unsigned char u8;

  11. sbit LSA=P2^2;
  12. sbit LSB=P2^3;
  13. sbit LSC=P2^4;


  14. char num=0;
  15. u8 DisplayData[8];
  16. u8 code smgduan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};

  17. /*******************************************************************************
  18. * 函 数 名         : delay
  19. * 函数功能                   : 延时函数,i=1时,大约延时10us
  20. *******************************************************************************/
  21. void delay(u16 i)
  22. {
  23.         while(i--);        
  24. }


  25. /*******************************************************************************
  26. * 函 数 名         : datapros()
  27. * 函数功能                   : 温度读取处理转换函数
  28. * 输    入         : temp
  29. * 输    出         : 无
  30. *******************************************************************************/

  31. void datapros(int temp)         
  32. {
  33.            float tp;  
  34.         if(temp< 0)                                //当温度值为负数
  35.           {
  36.                 DisplayData[0] = 0x40;           //   -
  37.                 //因为读取的温度是实际温度的补码,所以减1,再取反求出原码
  38.                 temp=temp-1;
  39.                 temp=~temp;
  40.                 tp=temp;
  41.                 temp=tp*0.0625*100+0.5;        
  42.                 //留两个小数点就*100,+0.5是四舍五入,因为C语言浮点数转换为整型的时候把小数点
  43.                 //后面的数自动去掉,不管是否大于0.5,而+0.5之后大于0.5的就是进1了,小于0.5的就
  44.                 //算加上0.5,还是在小数点后面。

  45.           }
  46.          else
  47.           {                        
  48.                 DisplayData[0] = 0x00;
  49.                 tp=temp;//因为数据处理有小数点所以将温度赋给一个浮点型变量
  50.                 //如果温度是正的那么,那么正数的原码就是补码它本身
  51.                 temp=tp*0.0625*100+0.5;        
  52.                 //留两个小数点就*100,+0.5是四舍五入,因为C语言浮点数转换为整型的时候把小数点
  53.                 //后面的数自动去掉,不管是否大于0.5,而+0.5之后大于0.5的就是进1了,小于0.5的就
  54.                 //算加上0.5,还是在小数点后面。
  55.         }
  56.         DisplayData[1] = smgduan[temp / 10000];
  57.         DisplayData[2] = smgduan[temp % 10000 / 1000];
  58.         DisplayData[3] = smgduan[temp % 1000 / 100] | 0x80;
  59.         DisplayData[4] = smgduan[temp % 100 / 10];
  60.         DisplayData[5] = smgduan[temp % 10];
  61. }


  62. /*******************************************************************************
  63. * 函数名         :DigDisplay()
  64. * 函数功能                 :数码管显示函数
  65. * 输入           : 无
  66. * 输出                  : 无
  67. *******************************************************************************/
  68. void DigDisplay()
  69. {
  70.         u8 i;
  71.         for(i=0;i<6;i++)
  72.         {
  73.                 switch(i)         //位选,选择点亮的数码管,
  74.                 {
  75.                         case(0):
  76.                                 LSA=0;LSB=0;LSC=0; break;//显示第0位
  77.                         case(1):
  78.                                 LSA=1;LSB=0;LSC=0; break;//显示第1位
  79.                         case(2):
  80.                                 LSA=0;LSB=1;LSC=0; break;//显示第2位
  81.                         case(3):
  82.                                 LSA=1;LSB=1;LSC=0; break;//显示第3位
  83.                         case(4):
  84.                                 LSA=0;LSB=0;LSC=1; break;//显示第4位
  85.                         case(5):
  86.                                 LSA=1;LSB=0;LSC=1; break;//显示第5位        
  87.                 }
  88.                 P0=DisplayData[5-i];//发送数据
  89.                 delay(100); //间隔一段时间扫描        
  90.                 P0=0x00;//消隐
  91.         }               
  92. }

  93. /*******************************************************************************
  94. * 函 数 名       : main
  95. * 函数功能                 : 主函数
  96. * 输    入       : 无
  97. * 输    出             : 无
  98. *******************************************************************************/
  99. void main()
  100. {        
  101.         while(1)
  102.         {
  103.                 datapros(Ds18b20ReadTemp());         //数据处理函数
  104.                 DigDisplay();//数码管显示函数               
  105.         }               
  106. }


  107.                   #include"reg51.h"

  108. #include <intrins.h>
  109. sbit RX=P2^1;
  110. sbit TX=P2^0;
  111. unsigned int  time=0;
  112. unsigned int  timer=0;
  113. unsigned char posit=0;
  114. unsigned long S=0;
  115. bit      flag =0;
  116. //--定义使用的IO--//
  117. #define GPIO_DIG P0

  118. sbit LSA=P2^2;
  119. sbit LSB=P2^3;
  120. sbit LSC=P2^4;

  121. //--定义全局变量--//
  122. unsigned char code DIG_CODE[17]={
  123. 0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
  124. 0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
  125. //0、1、2、3、4、5、6、7、8、9、A、b、C、d、E、F的显示码
  126. unsigned char disbuff[4]           ={ 0,0,0,0,};
  127. /*******************************************************************************
  128. * 函 数 名         : DigDisplay
  129. * 函数功能                   : 使用数码管显示
  130. * 输    入         : 无
  131. * 输    出         : 无
  132. *******************************************************************************/
  133. void DigDisplay()
  134. {
  135.         unsigned char i;
  136.         unsigned int j;
  137.         for(i=0;i<8;i++)
  138.         {
  139.                 switch(i)         //位选,选择点亮的数码管,
  140.                 {
  141.                         case(0):
  142.                                 LSA=0;LSB=0;LSC=0; break;//显示第0位
  143.                         case(1):
  144.                                 LSA=1;LSB=0;LSC=0; break;//显示第1位
  145.                         case(2):
  146.                                 LSA=0;LSB=1;LSC=0; break;//显示第2位
  147.                         case(3):
  148.                                 LSA=1;LSB=1;LSC=0; break;//显示第3位
  149.                         case(4):
  150.                                 LSA=0;LSB=0;LSC=1; break;//显示第4位
  151.                         case(5):
  152.                                 LSA=1;LSB=0;LSC=1; break;//显示第5位
  153.                         case(6):
  154.                                 LSA=0;LSB=1;LSC=1; break;//显示第6位
  155.                         case(7):
  156.                                 LSA=1;LSB=1;LSC=1; break;//显示第7位        
  157.                 }
  158.                 GPIO_DIG=disbuff[i];//发送段码
  159.                 j=10;                                                 //扫描间隔时间设定
  160.                 while(j--);        
  161.                 GPIO_DIG=0x00;//消隐
  162.         }
  163. }
  164. /********************************************************/
  165.     void Conut(void)
  166.         {
  167.          time=TH0*256+TL0;
  168.          TH0=0;
  169.          TL0=0;
  170.         
  171.          S= (long)(time*0.17);     //算出来是CM
  172.          if((S>=4000)||flag==1) //超出测量范围显示“ERR0”
  173.          {         
  174.           flag=0;
  175.           disbuff[0]=0x3f;           //“-”
  176.           disbuff[1]=0x50;           //“-”
  177.           disbuff[2]=0x50;           //“-”
  178.           disbuff[3]=0x79;           //“-”
  179.          }
  180.          else
  181.          {
  182.           disbuff[3]=DIG_CODE[S%10000/1000];
  183.           disbuff[2]=DIG_CODE[S%1000/100];
  184.           disbuff[1]=DIG_CODE[S%100/10];
  185.           disbuff[0]=DIG_CODE[S%10/1];
  186.          }
  187.         }
  188. /********************************************************/
  189.      void zd0() interrupt 1                  //T0中断用来计数器溢出,超过测距范围
  190.   {
  191.     flag=1;                                                         //中断溢出标志
  192.   }
  193. /********************************************************/
  194.    void  zd3()  interrupt 3                  //T1中断用来扫描数码管和计800MS启动模块
  195.   {
  196.          TH1=0xf8;
  197.          TL1=0x30;
  198.          DigDisplay();
  199.          timer++;
  200.          if(timer>=100)
  201.          {
  202.           timer=0;
  203.           TX=1;                                        //800MS  启动一次模块
  204.           _nop_();
  205.           _nop_();
  206.           _nop_();
  207.           _nop_();
  208.           _nop_();
  209.           _nop_();
  210.           _nop_();
  211.           _nop_();
  212.           _nop_();
  213.           _nop_();
  214.           _nop_();
  215.           _nop_();
  216.           _nop_();
  217.           _nop_();
  218.           _nop_();
  219.           _nop_();
  220.           _nop_();
  221.           _nop_();
  222.           _nop_();
  223.           _nop_();
  224.           _nop_();
  225.           TX=0;
  226.          }
  227.   }
  228. /*********************************************************/

  229.         void  main(  void  )

  230.   {  
  231.     TMOD=0x11;                   //设T0为方式1,GATE=1;
  232.         TH0=0;
  233.         TL0=0;         
  234.         TH1=0xf8;                   //2MS定时
  235.         TL1=0x30;
  236.         ET0=1;             //允许T0中断
  237.         ET1=1;                           //允许T1中断
  238.         TR1=1;                           //开启定时器
  239.         EA=1;                           //开启总中断

  240.         while(1)
  241.         {
  242.          while(!RX);                //当RX为零时等待
  243.          TR0=1;                            //开启计数
  244.          while(RX);                        //当RX为1计数并等待
  245.          TR0=0;                                //关闭计数
  246.      Conut();                        //计算
  247.         }

  248.   }
复制代码
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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