找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4762|回复: 4
收起左侧

火灾报警系统_单片机proteus仿真及源码

[复制链接]
ID:196562 发表于 2017-5-4 16:26 | 显示全部楼层 |阅读模式
基于51单片机的火灾报警系统, 用adc0809来采集模拟数据。包含源程序,下面是proteus仿真原理图
0.png
0.png

0.png

单片机源程序:
  1. #include<REG51.H>
  2. #define uint unsigned int
  3. #define uchar unsigned char
  4. uchar code a[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};        //段码组合,共阴极
  5. uchar code b[6]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf}; //位码组合         低有效
  6. uchar code c[9]={201,202,203,204,205,206,207,208,0};
  7. uchar y[8]={0,0,0,0,0,0,0,0};
  8. //*************************************************************************************
  9. sbit ST=P3^1;
  10. sbit OE=P3^0;
  11. sbit Add=P3^4;
  12. sbit Bdd=P3^5;
  13. sbit Cdd=P3^6;

  14. uint t=0,h=0x9f;
  15. uchar p[8];
  16. uchar k,m,n,q,g,r,d,i,cnt=0,v=0;
  17. void delay(uchar s);

  18. void inrupt(void)
  19. {
  20.         TMOD=0x01;
  21.         TH0=0x3c;
  22.         TL0=0xb0;
  23.         
  24.         EX0=1;
  25.         IT0=1;
  26.          EX1=1;
  27.         IT1=1;
  28.         EA=1;
  29. }

  30. void lxy(void)
  31. {
  32.         switch(d)
  33.                                 {        
  34.                                         case 0:Add=0,Bdd=0,Cdd=0;ST=0,ST=1,ST=0;break;
  35.                                     case 1:Add=1,Bdd=0,Cdd=0;ST=0,ST=1,ST=0;break;
  36.                                         case 2:Add=0,Bdd=1,Cdd=0;ST=0,ST=1,ST=0;break;
  37.                                         case 3:Add=1,Bdd=1,Cdd=0;ST=0,ST=1,ST=0;break;
  38.                                         case 4:Add=0,Bdd=0,Cdd=1;ST=0,ST=1,ST=0;break;
  39.                                         case 5:Add=1,Bdd=0,Cdd=1;ST=0,ST=1,ST=0;break;
  40.                                         case 6:Add=0,Bdd=1,Cdd=1;ST=0,ST=1,ST=0;break;
  41.                                         case 7:Add=1,Bdd=1,Cdd=1;ST=0,ST=1,ST=0;break;
  42.                                 
  43.                                 }
  44. }   
  45.    
  46.   
  47.   

  48. void time0(void) interrupt 2
  49. {
  50.         OE=1;
  51.         t=P1;
  52.         OE=0;

  53.         if(t>=h)
  54.           {
  55.                                           y[d]=t;
  56.                                         p[i]=d;
  57.                                         i++;
  58.                                                                         
  59.                                 
  60.       }
  61.          d++;
  62.          lxy();
  63.          r--;
  64.                            
  65. }
  66. void time1(void) interrupt 1
  67. {
  68.         TH0=0x3c;
  69.         TL0=0xb0;
  70.         cnt++;        
  71.         if(cnt>=20)
  72.         {
  73.          v--;
  74.          cnt=0;
  75.          if(v==0)
  76.            {        
  77.                      g=1;
  78.                   ET0=0;
  79.               TR0=0;        
  80.            }
  81.           else g=0;
  82.         }

  83.         
  84. }

  85. void time2(void) interrupt 0
  86. {
  87.         g=1;
  88.         i++;
  89.         if(p[i]==8)
  90.           {        i=0;
  91.             g=1;
  92.           }
  93.         delay(20);
  94. }
  95. void delay(uchar s) //延时0.1*n毫秒 0
  96. {
  97.   uchar j;
  98.   do
  99.    {
  100.      for(j=0;j<23;j++)
  101.      ;;;
  102.    } while(s--);
  103. }

  104. void display(void)
  105.         {                for(;;)
  106.                           {
  107.                            P2=b[0],P0=a[k];
  108.                                 delay(20);

  109.                                 P2=b[1],P0=a[m];
  110.                                 delay(20);
  111.                
  112.                                 P2=b[2],P0=a[n];
  113.                                 delay(20);

  114.                                 P2=b[3],P0=a[q];
  115.                                 delay(20);

  116.                                 P2=b[4],P0=a[v/10];
  117.                                 delay(20);

  118.                                 P2=b[5],P0=a[v%10];
  119.                                 delay(20);
  120.                                 if(g==1)
  121.                                   {
  122.                                 
  123.                                         break;
  124.                                   }
  125.                           }
  126.         }
  127. void main(void)
  128. {
  129.         inrupt();


  130.                         for(;;)
  131.                           {
  132.                             P2=0x3e,P0=a[0];
  133.                                 delay(20);

  134.                                 P2=0x3d,P0=a[0];
  135.                                 delay(20);
  136.                
  137.                                 P2=0x3b,P0=a[0];
  138.                                 delay(20);

  139.                                 P2=0x37,P0=a[0];
  140.                         
  141.                                 for(i=0;i<8;i++)
  142.                                   {
  143.                                           p[i]=8;
  144.                                   }
  145.                                 i=0;
  146.                                 t=0;
  147.                                 d=0;
  148.                                 r=8;
  149.                     Add=0,Bdd=0,Cdd=0;
  150.                         
  151.                                 ST=0;
  152.                                 ST=1;
  153.                                 ST=0;
  154.                                 while(r);
  155.                                 i=0;
  156.                                 if(y[p[i]]>=h)
  157.                                 {
  158.                                        
  159.                                         v=20;
  160.                                         ET0=1;
  161.                         TR0=1;
  162.                                  while(v)
  163.                                     {switch(p[i])
  164.                                    {        
  165.                                         case 0:        k=c[p[i]]/1000;m=(c[p[i]]%1000)/100;n=(c[p[i]]%100)/10;q=c[p[i]]%10;display();break;
  166.                                     case 1: k=c[p[i]]/1000;m=(c[p[i]]%1000)/100;n=(c[p[i]]%100)/10;q=c[p[i]]%10;display();break;
  167.                                         case 2:        k=c[p[i]]/1000;m=(c[p[i]]%1000)/100;n=(c[p[i]]%100)/10;q=c[p[i]]%10;display();break;
  168.                                     case 3:        k=c[p[i]]/1000;m=(c[p[i]]%1000)/100;n=(c[p[i]]%100)/10;q=c[p[i]]%10;display();break;
  169.                                         case 4:        k=c[p[i]]/1000;m=(c[p[i]]%1000)/100;n=(c[p[i]]%100)/10;q=c[p[i]]%10;display();break;
  170.                                         case 5:        

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

下载:
火警报警系统.rar (24.4 KB, 下载次数: 157)
回复

使用道具 举报

ID:214334 发表于 2017-6-24 21:54 | 显示全部楼层
下下来看看呢
回复

使用道具 举报

ID:270384 发表于 2018-1-3 09:48 来自手机 | 显示全部楼层
下载啦
回复

使用道具 举报

ID:449377 发表于 2018-12-28 17:20 | 显示全部楼层
楼主有相关论文吗
回复

使用道具 举报

ID:458066 发表于 2020-2-21 16:32 | 显示全部楼层
能不能说明一下那些部分实现什么功能呢?谢谢!
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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