找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机温度报警器与时钟显示C程序和原理图

  [复制链接]
跳转到指定楼层
楼主
       文章附图中的是单片机温度报警器+时钟显示板的实物照片,附件中有C程序和原理图,需要的可以自己下载。这款单片机温度报警器+时钟显示板,采用8只数码管来显示时间,小时、分钟、秒种之间用“-”进行分隔,看上去比较美观。这款单片机温度报警器+时钟显示板,使用的单片机为AT89C51,DS18B20的数据端接单片机的P3^3脚,测试测量保留一位小数,测量范围-55~125度,板上设有两按键,用来调整时间温度定值。



         源代码及其电路图下载(protel格式的原理图): 温度报警器 时钟显示C程序和原理图.rar (52.96 KB, 下载次数: 208)
  1. #include <reg51.h>
  2. #include "intrins.h"
  3. #define uint unsigned int //宏定义
  4. #define uchar unsigned char //宏定义
  5. uchar i=0,j=0,k=0, s=1,f=1,m=0,a[9]; //定义变量
  6. sbit K4=P1^3; //位定义
  7. sbit K5 =P1^4; //位定义
  8. sbit fmq =P3^6; //位定义
  9. sbit     DQ=P3^3;                               //温度输入口
  10. sbit     DIN=P0^7;
  11. uint     h;
  12. uint     temp;
  13. uint     num;
  14. uint     numc;
  15. //uchar code sz[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf} ; //数字编码表
  16. //uchar code xw[]={ 0xff,0xfe,0xfd,0xfb,0xf7, //选位编码表
  17. //0xef,0xdf,0xbf,0x7f
  18. //};
  19. //**************温度小数部分用查表法***********//
  20. uchar code ditab[16]=
  21. {0x00,0x01,0x01,0x02,0x03,0x03,0x04,0x04,0x05,0x06,0x06,0x07,0x08,0x08,0x09,0x09};
  22. //
  23. uchar code dis_7[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xff,0xbf};
  24. //共阳LED段码表        "0"  "1"  "2"  "3"  "4"  "5"  "6"  "7"  "8"  "9" "不亮" "-"              
  25. uchar code scan_con[8]={0xf7,0xfb,0xfd,0xfe,0xef,0xdf,0xbf,0x7f};    //列扫描控制字
  26. uchar data temp_data[2]={0x00,0x00};             //读出温度暂放
  27. uchar data display[10]={0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00};     //显示单元数据,共4个数据和一个运算暂用
  28. //uchar data display1[5]={};
  29. //
  30. //
  31. //
  32. void pf() //区分出个位和十位
  33. {
  34. a[1]=s/10;
  35. a[2]=s%10;
  36. a[3]=11;
  37. a[4]=f/10;
  38. a[5]=f%10;
  39. a[6]=11;
  40. a[7]=m/10;
  41. a[8]=m%10;
  42. }

  43. /*****************11us延时函数*************************/
  44. //
  45. void delay(uint t)
  46. {
  47.   for (;t>0;t--);
  48. }
  49. /*****************延时函数***********************/
  50. void ys ( int d )
  51. {
  52. int b ,c ;
  53. for (b = d;b>0;b--)
  54. for (c=110;c>0;c--) ;
  55. }
  56. //****************1ms基准延时程序
  57. void delay1ms(uint i)
  58. {

  59. uchar j;
  60. while(i--)
  61. {
  62. for(j=0;j<115;j++)          
  63. {
  64.   ;
  65. }


  66. }
  67.   
  68. }
  69. /************500us基准延时程序         ******************/
  70. void delay500us()
  71. {

  72. unsigned char j;

  73. for(j=0;j<57;j++)         
  74. {
  75.   ;
  76. }
  77. }
  78. /****************显示扫描函数***************************/
  79. void scan()
  80. {
  81.   uchar k;
  82.   display[4]=num/1000;
  83. display[5]=num/100-display[4]*100;
  84. display[6]=num/10-display[5]*10;
  85. display[7]=num-display[5]*100-display[6]*10;
  86. numc=display[2]*100+display[1]*10+display[0];
  87.      for(k=0;k<8;k++)                     //4位LED扫描控制
  88. {
  89.   P0=dis_7[display[k]];          //数据显示
  90.   if ((k==1)||(6==k))
  91.   {DIN=0;}                   //小数点显示
  92.   P2=scan_con[k];                 //位选
  93.   delay(100);
  94. }
  95. }

  96. void xs(uint k)
  97. {        uint i;
  98.         for(i=0;i<k;i++)
  99.         {
  100.         scan();
  101.        
  102.         }
  103. }
  104. /***********产生1KHZ频率声音的函数 /****************/
  105. void beep()       
  106. {       
  107.         fmq=0;
  108.         delay500us();
  109.         fmq=1;
  110.        
  111.        
  112. }

  113. /****************DS18B20复位函数************************/
  114. void ow_reset(void)
  115. {
  116. char presence=1;
  117. while(presence)
  118. {
  119.   while(presence)
  120.    {
  121.     DQ=1;_nop_();_nop_();//从高拉倒低
  122.         DQ=0;                                       
  123.         delay(50);           //550 us
  124.         DQ=1;                                       
  125.         delay(6);            //66 us
  126.         presence=DQ;         //presence=0 复位成功,继续下一步
  127.    }
  128.    delay(45);            //延时500 us
  129.    presence=~DQ;         
  130. }
  131. DQ=1;                   //拉高电平
  132. }
  133. //
  134. //
  135. /****************DS18B20写命令函数************************/
  136. //向1-WIRE 总线上写1个字节
  137. void write_byte(uchar val)
  138. {
  139.   uchar i;
  140.   for(i=8;i>0;i--)
  141.   {
  142.    DQ=1;_nop_();_nop_();                  //从高拉倒低
  143.    DQ=0;_nop_();_nop_();_nop_();_nop_();  //5 us
  144.    DQ=val&0x01;                           //最低位移出
  145.    delay(6);                              //66 us
  146.    val=val/2;                             //右移1位
  147.    }
  148.    DQ=1;
  149.    delay(1);
  150. }
  151. //
  152. /****************DS18B20读1字节函数************************/
  153. //从总线上取1个字节
  154. uchar read_byte(void)
  155. {
  156. uchar i;
  157. uchar value=0;
  158. for(i=8;i>0;i--)
  159. {
  160.   DQ=1;_nop_();_nop_();
  161.   value>>=1;
  162.   DQ=0;_nop_();_nop_();_nop_();_nop_();         //4 us
  163.   DQ=1;_nop_();_nop_();_nop_();_nop_();         //4 us
  164.   if(DQ)value|=0x80;
  165.   delay(6);                                     //66 us
  166. }
  167. DQ=1;
  168. return(value);
  169. }
  170. //
  171. /****************读出温度函数************************/
  172. //
  173. read_temp()
  174. {
  175.   ow_reset();                  //总线复位
  176.   delay(200);
  177.   write_byte(0xcc);            //发命令
  178.   write_byte(0x44);            //发转换命令
  179.   ow_reset();
  180.   delay(1);
  181.   write_byte(0xcc);            //发命令
  182.   write_byte(0xbe);
  183.   temp_data[0]=read_byte();    //读温度值的第字节
  184.   temp_data[1]=read_byte();    //读温度值的高字节
  185.   temp=temp_data[1];
  186.   temp<<=8;                                               
  187.   temp=temp|temp_data[0];      // 两字节合成一个整型变量。
  188.   return temp;                 //返回温度值
  189. }
  190. //
  191. /****************温度数据处理函数************************/

  192. //二进制高字节的低半字节和低字节的高半字节组成一字节,这个
  193. //字节的二进制转换为十进制后,就是温度值的百、十、个位值,而剩
  194. //下的低字节的低半字节转化成十进制后,就是温度值的小数部分

  195. /********************************************************/
  196. void work_temp(uint tem)
  197. {
  198. uchar n=0;
  199. if(tem>6348)                        // 温度值正负判断
  200.      {tem=65536-tem;n=1;}            // 负温度求补码,标志位置1
  201.       display[4]=tem&0x0f;           // 取小数部分的值
  202.   display[0]=ditab[display[4]];  // 存入小数部分显示值
  203.       display[4]=tem>>4;             // 取中间八位,即整数部分的值
  204.   display[3]=display[4]/100;     // 取百位数据暂存
  205.   display[1]=display[4]%100;     // 取后两位数据暂存
  206.   display[2]=display[1]/10;      // 取十位数据暂存
  207.   display[1]=display[1]%10;  
  208. /******************符号位显示判断**************************/
  209.   if(!display[3])
  210.   {
  211.     display[3]=0x0a;           //最高位为0时不显示
  212.     if(!display[2])
  213. {
  214.    display[2]=0x0a;        //次高位为0时不显示
  215. }
  216.   }
  217.   if(n){display[3]=0x0b;}      //负温度时最高位显示"-"
  218. }
  219. /*************显视函数*************/
  220. void szxs()
  221. { uint jj;
  222. pf() ;
  223. for (k=1;k<=8;k++)
  224. {
  225. if(k<5)
  226. {jj=4-k;}
  227. else
  228. jj=k-1;
  229. P2=scan_con[jj];
  230. P0=dis_7[a[k]];
  231. ys(3);
  232. }


  233. }
  234. void dczd() interrupt 1 //定时中断
  235. {
  236. TH0=(65535-50000)/256;
  237. TL0=(65535-50000)%256;
  238. i++;

  239. if (i==20)
  240. {
  241. i=0;

  242. m++;
  243. if (m==60)
  244. {
  245. m=0;
  246. f++;
  247. if (f==60)
  248. {
  249. f=0;
  250. s++;
  251. if (s==24)
  252. s=0;
  253. }
  254. }
  255. }
  256. }
  257. void cs() //初始函数
  258. {
  259. TMOD=0x01; //设置为定时工作方式
  260. TH0=(65535-50000)/256; //定时器装初值
  261. TL0=(65535-50000)%256; //定时器装初值
  262. EA=1; //打开总中断
  263. ET0=1; //打开定时中断
  264. TR0=1; //起用定时器
  265. //P3=0X00;
  266. }
  267. void szxs1(uint t)
  268. {
  269. uint a;
  270. for(a=0;a<t;a++)
  271. {szxs();
  272. }
  273. }
  274. void shizhong()
  275. {

  276. szxs1(1);


  277. if(( K4==0)&&(0!=K5))
  278. {
  279. szxs1(2);
  280. if( ( K4==0)&&(0!=K5))
  281. {
  282. szxs1(10);
  283. s++;
  284. s%=24;
  285. }
  286. }
  287. if(( K5==0)&&(0!=K4))
  288. {
  289. szxs1(2);
  290. if(( K5==0)&&(0!=K4))
  291. {
  292. szxs1(10);
  293. f++;
  294. f%=60;
  295. }
  296. }


  297. }
  298. void cw()
  299. {

  300. work_temp(read_temp());     //处理温度数据
  301. scan();

  302. if(( K5==0)&&(0!=K4))                                        //上限+
  303.         {
  304.         //delay1ms(15);
  305.         xs(3);                                          //用显示程序延时,下同
  306.         if(( K5==0)&&(0!=K4))
  307.                 {
  308.        
  309.             num=num+1;
  310.          
  311.                 }
  312.          //while(!K5);
  313.          xs(14);
  314.          }
  315. if(( K4==0)&&(0!=K5))                                  //上限-
  316.         {
  317.         //delay1ms(15);
  318.         xs(3);
  319.         if(( K4==0)&&(0!=K5))
  320.                 {
  321.        
  322.             num=num-1;
  323.          
  324.                 }
  325.          //while(!K4);
  326.          xs(14);
  327.          }

  328.           
  329.          if(numc>num)
  330.          {
  331.          beep();
  332.          }                  //显示温度值
  333.   
  334. }
  335. void main ()
  336. {
  337. uint b=0;
  338. cs();
  339. num=300;
  340.   P0=0xff;                 //初始化端口
  341.   P2=0xff;
  342.   for(h=0;h<4;h++)              //开机显示"0000"
  343.       {display[h]=0;}
  344.   ow_reset();                   //开机先转换一次
  345.   write_byte(0xcc);             //Skip ROM
  346.   write_byte(0x44);             //发转换命令
  347.   xs(20);            //开机显示"00000300"
  348.   while(1)
  349.   {
  350.   for(b=0;b<200;b++)
  351.   shizhong();
  352.    for(b=0;b<200;b++)
  353.    cw();


  354.   }



  355. }
复制代码




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

使用道具 举报

沙发
ID:76671 发表于 2015-4-16 17:23 | 只看该作者
有没电路图?
回复

使用道具 举报

板凳
ID:76671 发表于 2015-4-16 17:26 | 只看该作者
装个看图软件都两三G
回复

使用道具 举报

地板
ID:44267 发表于 2015-9-25 08:12 | 只看该作者
强强强强强强强强强强强强强强强强强强强强强
回复

使用道具 举报

5#
ID:44267 发表于 2015-9-25 10:36 | 只看该作者
正好做一个太强了,赚点币
回复

使用道具 举报

6#
ID:106483 发表于 2016-2-27 00:50 来自手机 | 只看该作者
怎麼下載?
回复

使用道具 举报

7#
ID:122826 发表于 2016-5-24 12:03 | 只看该作者
希望可以帮到我
回复

使用道具 举报

8#
ID:136460 发表于 2017-1-13 14:54 | 只看该作者
收藏了,谢谢分享!
回复

使用道具 举报

9#
ID:159575 发表于 2017-1-16 11:44 来自手机 | 只看该作者
做一个试试
回复

使用道具 举报

10#
ID:89286 发表于 2017-1-16 22:07 | 只看该作者
thanks for sharing
回复

使用道具 举报

11#
ID:158248 发表于 2017-1-18 14:03 | 只看该作者
很好的的东西,学习了
回复

使用道具 举报

12#
ID:108622 发表于 2017-11-2 02:51 | 只看该作者
能不能把数码管分开显
回复

使用道具 举报

13#
ID:270880 发表于 2018-1-3 17:00 | 只看该作者
请问楼主,有电路图吗?
回复

使用道具 举报

14#
ID:270880 发表于 2018-1-3 17:00 | 只看该作者
zeng_fanlong 发表于 2017-1-18 14:03
很好的的东西,学习了

你好,请问一下有电路原理图吗
回复

使用道具 举报

15#
ID:270880 发表于 2018-1-3 17:01 | 只看该作者
28674500 发表于 2015-4-16 17:26
装个看图软件都两三G

请问一下有电路原理图吗
回复

使用道具 举报

16#
ID:73957 发表于 2018-1-27 10:41 | 只看该作者
电路放出来给大家



回复

使用道具 举报

17#
ID:314979 发表于 2018-4-24 14:40 | 只看该作者
做一个试试学习学习
回复

使用道具 举报

18#
ID:314732 发表于 2018-5-4 16:38 | 只看该作者
强,我也弄一个
回复

使用道具 举报

19#
ID:567207 发表于 2019-6-20 09:50 来自手机 | 只看该作者
希望可以帮到我
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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