找回密码
 立即注册

QQ登录

只需一步,快速开始

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

工业生产节能时控器单片机程序

[复制链接]
跳转到指定楼层
楼主
ID:112317 发表于 2016-4-6 18:25 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

节能时控器,根据每日供电波峰,波谷,定时用电。节能,降低用电成本。C51-AT89C2051 程序
源码: 569417381jsnk.rar (2.29 KB, 下载次数: 15)

  1. #include <AT89x051.H>                //器件配置文件
  2. #define uchar unsigned char                //变量类型的宏定义
  3. #define uint unsigned int
  4. uchar DATA_7SEG[10]={0xfc,0x60,0xda,0xf2,0x66,
  5.                     0xb6,0xbe,0xe0,0xfe,0xf6};        /*0~9的数码管段码*/
  6. uchar x[4];                                        /* 存放走时的数组*/
  7. uchar y[4]={0,0,0,0};                        /* 存放定时1的数组*/
  8. uchar z[4]={0,0,0,0};                        /* 存放定时2的数组*/
  9. uchar act[4]={0xfe,0xfd,0xfb,0xf7};        /*四位数码管的位选码*/
  10. void delay(uint k);                                //延时子函数声明
  11. void conv();                                                //走时转换子函数声明
  12. void p_out();                                                //判别定时到否子函数声明
  13. void p_out1();                                                //判别定时到否子函数1声明
  14. void t_adj();                                                //走时调整子函数声明
  15. uchar deda=0;           /*100mS计数单元清零*/
  16. bit d_05s=0;            /*0.5秒标志*/
  17. bit o_f1=0;                 /*定时1启/停标志*/
  18. bit o_f2=0;                 /*定时2启/停标志*/
  19. uchar set=0;                /*功能键标志*/
  20. uchar h=0;
  21. uchar n=0;
  22. uchar m=0;
  23. uchar flag;
  24. uchar left=0;
  25. uchar sec=0;
  26. uchar min=0;
  27. uchar hour=0;
  28. uchar min1=0;
  29. uchar hour1=0;
  30. uchar min2=0;
  31. uchar hour2=0;
  32. uchar up=0;
  33. bit flag1=0;
  34. bit flag2=0;

  35. /*显示走时*/
  36. void time()
  37. {
  38. for(h=0;h<4;h++)                       
  39.         {P1=DATA_7SEG[x[h]];        //输出数码管的字形码
  40.                 P3=act[h];p_out();                //输出数码管的位码。判断输出
  41. if(P3_2==0){if(d_05s==1)P1_0=1;else P1_0=0;}                /* 百位数码管点亮时,控制小数点
  42. (秒点)闪烁*/
  43.                 delay(2);}                         //每位数码管点亮2ms
  44. if(o_f1==1){P1=0x01;P3_3=1;P3_2=1;P3_1=0;P3_0=1;}/* 若定时1启动,
  45. 点亮十位数码管小数点*/
  46.         else{P1=0x00;P3_3=1;P3_2=1;P3_1=1;P3_0=1;}p_out();/*否则十位数码管
  47. 小数点不亮*/
  48. delay(2);
  49. if(o_f2==1){P1=0x01;P3_3=1;P3_2=1;P3_1=1;P3_0=0;} /* 若定时2启动,
  50. 点亮个位数码管小数点*/
  51.         else{P1=0x00;P3_3=1;P3_2=1;P3_1=1;P3_0=1;}p_out();/*否则个位数码管
  52. 小数点不亮*/
  53. delay(2);
  54. }

  55. /*定时器T0初始化*/
  56. void init_timer0()
  57. {
  58. TMOD=0x11;
  59. TH0=-(50235/256);
  60. TL0=-(50235%256);
  61. IE=0x8a;
  62. TR0=1;
  63. }

  64. /*定时器T1初始化*/
  65. void init_timer1()
  66. {
  67. TH1=-(5000/256);
  68. TL1=-(5000%256);
  69. }


  70. /*延时k*1ms子函数*/
  71. void delay(uint k)
  72. {
  73. uint i,j;
  74. for(i=0;i<k;i++){
  75. for(j=0;j<60;j++)
  76. {;}}
  77. }

  78. /*100mS定时中断服务子函数*/
  79. void zd0(void) interrupt 1
  80. {
  81. TH0=-(50235/256);                //重装100ms定时初值
  82. TL0=-(50235%256);
  83. deda++;                                        //100ms计时单元递增
  84. }

  85. /*10mS定时中断服务子函数*/
  86. void zd1(void) interrupt 3
  87. {uchar i,j;i=P1;j=P3;
  88.         TH1=-(5000/256);
  89.         TL1=-(5000%256);
  90. if(m==1)n++;
  91. if(n>=30){n=0;m=0;}
  92. P3_7=0;
  93. P1=0xff;
  94. if(P1!=0xff)
  95. {
  96. if(n==0)m=1;
  97. {if(n==1)
  98. {
  99. if(P1_0==0){set++;left=0;}
  100. if(set>=4)set=0;
  101. if(set==1)flag=0x55;
  102. if(P1_1==0)left++;
  103. if(left>=4)left=0;
  104. if(P1_2==0){up++;
  105. switch(left)
  106. {
  107. case 0:{if(up>=10)up=0;}break;
  108. case 1:{if(up>=6)up=0;}break;
  109. case 2:{if(up>=10)up=0;}break;
  110. case 3:{if(up>=3)up=0;}break;
  111. default:break;
  112. }
  113. }
  114. if(P1_2==0){
  115. switch(set)
  116. {case 0:break;
  117. case 1:x[left]=up;break;
  118. case 2:{y[left]=up;if(P1_3==0)o_f1=!o_f1;}break;
  119. case 3:{z[left]=up;if(P1_3==0)o_f2=!o_f2;}break;
  120. default:break;}
  121.                         }
  122. else {
  123. switch(set)
  124. {case 0:break;
  125. case 1:up=x[left];break;
  126. case 2:{up=y[left];if(P1_3==0)o_f1=!o_f1;}break;
  127. case 3:{up=z[left];if(P1_3==0)o_f2=!o_f2;}break;
  128. default:break;}
  129.         }}
  130. }}
  131. P1=i;P3=j;
  132. }

  133. /*显示调整走时*/
  134. void t_adj()
  135. {p_out1();
  136. for(h=0;h<4;h++)        //四位数码管每位点亮3ms
  137.         {if(h==left)P1=0x00;
  138.         else {P1=DATA_7SEG[x[h]];
  139.         P3=act[h];p_out();
  140.         delay(3);}}
  141.         P1=DATA_7SEG[up];P3=act[left];
  142.         hour=x[3]*10+x[2];min=x[1]*10+x[0];
  143.         p_out();
  144.         delay(12);        //需调整的数码管点亮12ms
  145. if(o_f1==1){P1=0x01;P3_3=1;P3_2=1;P3_1=0;P3_0=1;} /*若定时1启动,
  146. 点亮十位数码管小数点*/
  147.         else{P1=0x00;P3_3=1;P3_2=1;P3_1=1;P3_0=1;}p_out();/*否则十位数码管
  148. 小数点不亮*/
  149. delay(12);                //需调整的数码管点亮12ms
  150. if(o_f2==1){P1=0x01;P3_3=1;P3_2=1;P3_1=1;P3_0=0;} /*若定时2启动,
  151. 点亮个位数码管小数点*/
  152.         else{P1=0x00;P3_3=1;P3_2=1;P3_1=1;P3_0=1;}p_out();/*否则个位数码管
  153. 小数点不亮*/
  154. delay(12);                //需调整的数码管点亮12ms
  155. }

  156. /*显示调整定时1*/
  157. void t1_adj()
  158. {p_out1();
  159. for(h=0;h<4;h++)                //四位数码管每位点亮3ms
  160.         {if(h==left)P1=0x00;
  161.         else {P1=DATA_7SEG[y[h]];
  162.         P3=act[h];p_out();
  163.         delay(3);}}
  164.         P1=DATA_7SEG[up];P3=act[left];        //需调整的数码管点亮18ms
  165.         hour1=y[3]*10+y[2];min1=y[1]*10+y[0];
  166.         p_out();
  167. delay(18);
  168. if(o_f1==1){P1=0x01;P3_3=0;P3_2=1;P3_1=0;P3_0=1;} /*若定时1启动,
  169. 点亮十位数码管小数点*/
  170.         else{P1=0x01;P3_3=0;P3_2=1;P3_1=1;P3_0=1;} /*否则十位数码管
  171. 小数点不亮*/
  172.         p_out();
  173.         delay(18);                                                //需调整的数码管点亮18ms
  174. }


  175. /*显示调整定时2*/
  176. void t2_adj()
  177. {p_out1();
  178. for(h=0;h<4;h++)                                //四位数码管每位点亮3ms
  179.         {if(h==left)P1=0x00;
  180.         else {P1=DATA_7SEG[z[h]];                //需调整的数码管点亮18ms
  181.         P3=act[h];p_out();
  182.         delay(3);}}
  183.         P1=DATA_7SEG[up];P3=act[left];
  184. hour2=z[3]*10+z[2];min2=z[1]*10+z[0];
  185.         p_out();
  186. delay(18);
  187. if(o_f2==1){P1=0x01;P3_3=1;P3_2=0;P3_1=1;P3_0=0;} /*若定时2启动,
  188. 点亮个位数码管小数点*/
  189.         else{P1=0x01;P3_3=1;P3_2=0;P3_1=1;P3_0=1;} /*否则个位数码管
  190. 小数点不亮*/
  191.         p_out();
  192.         delay(18);                                //需调整的数码管点亮18ms
  193. }


  194. /*时、分、秒计时单元转换*/
  195. void conv()
  196. {
  197. if(deda<=5)d_05s=0;                //每500ms,秒点取反
  198.         else d_05s=1;
  199. if(deda>=10){sec++;deda=0;}        //每1000ms,秒单元递增
  200. if(sec>=60){min++;sec=0;}                //每60s,分单元递增
  201. if(min>=60){hour++;min=0;}        //每60m,时单元递增
  202. if(hour>=24){hour=0;}                        //每24h,时单元清零
  203. }

  204. /*判别定时到否子函数*/
  205. void p_out()
  206. {
  207. if(o_f1==1)                        //若定时1启动
  208. {if(hour==hour1)                //定时1时间到
  209. {if(min==min1)
  210. {flag1=1;if(d_05s==1)P3_4=0;else P3_4=1;}}}        //继电器输出标志置1,蜂鸣器间断鸣响
  211. if(flag1==1) P3_5=0;                        //若输出标志为1,继电器吸合

  212. if(o_f2==1)                        //若定时2启动
  213. {if(hour==hour2)                //定时2时间到
  214. {if(min==min2)
  215. {flag1=0;if(d_05s==1)P3_4=0;else P3_4=1;}}} //继电器输出标志置0,蜂鸣器间断鸣响
  216. if(flag1==0) P3_5=1;                        //若输出标志为0,继电器释放
  217. }

  218. /*判别定时到否子函数1*/
  219. void p_out1()
  220. {
  221. if(o_f1==1)                        //若定时1启动
  222. {if(hour==hour1)                //定时1时间到
  223. {if(min==min1)
  224. {flag1=1;}}}                        //继电器输出标志置1
  225. if(flag1==1) P3_5=0;        //若输出标志为1,继电器吸合

  226. if(o_f2==1)                        //若定时2启动
  227. {if(hour==hour2)                //定时2时间到
  228. {if(min==min2)
  229. {flag1=0;}}}                        //继电器输出标志置0
  230. if(flag1==0) P3_5=1;        //若输出标志为0,继电器释放
  231. }


  232. /*主函数*/
  233. void main()
  234. {
  235.         init_timer0();            /*定时器T0初始化*/
  236.         init_timer1();            /*定时器T1初始化*/
  237.        
  238.         while(1)
  239.         {
  240. /*将显示缓冲数组内容移到时、分计时单元*/
  241. hour=x[3]*10+x[2];min=x[1]*10+x[0];
  242. hour1=y[3]*10+y[2];min1=y[1]*10+y[0];
  243. hour2=z[3]*10+z[2];min2=z[1]*10+z[0];
  244. conv();                                        /*时、分、秒及100mS单元转换*/
  245. /*将转换后的时、分计时单元内容移到显示缓冲数组*/
  246. x[3]=hour/10;x[2]=hour%10;x[1]=min/10;x[0]=min%10;
  247. y[3]=hour1/10;y[2]=hour1%10;y[1]=min1/10;y[0]=min1%10;
  248. z[3]=hour2/10;z[2]=hour2%10;z[1]=min2/10;z[0]=min2%10;
  249. switch(set)
  250. {
  251. case 0:time();break;/*显示走时*/
  252. case 1:t_adj();break;/*显示调整走时*/
  253. case 2:t1_adj();break;/*显示调整定时1*/
  254. case 3:t2_adj();break;/*显示调整定时2*/
  255. default:break;
  256. }
  257. if(flag!=0x55)                                        /*判断RAM受干扰标志,若受干扰,
  258. 则显示器闪烁告警*/
  259.         {uchar i;P3_4=1;P3_5=1;
  260.                 for(i=0;i<100;i++)                /*点亮显示器200mS*/
  261.                 {
  262.                 P1=DATA_7SEG[x[3]];P3=0xf7;delay(1);
  263.                 P1=DATA_7SEG[x[2]];P3=0xfb;delay(1);
  264.                 P1=DATA_7SEG[x[1]];P3=0xfd;delay(1);
  265.                 P1=DATA_7SEG[x[0]];P3=0xfe;delay(1);
  266.                 }
  267.                
  268.                 P1=0xff;P3=0xff;delay(400);        /*熄灭显示器200mS*/
  269.                 P3_7=0;
  270. /*如有键按下达0.5S则退出闪烁状态同时掉电标志置55H。*/
  271. if(P1!=0xff){
  272. delay(10);if(P1_0==0)flag=0x55;F0:if(P1!=0xff)goto F0;
  273.                         }P3_7=1;
  274.         }
  275. else TR1=1;/*启动定时器1*/
  276. }}
复制代码



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

使用道具 举报

沙发
ID:109053 发表于 2016-4-7 00:23 | 只看该作者
有没有电路图参考一下..
回复

使用道具 举报

板凳
ID:99341 发表于 2016-5-3 21:48 | 只看该作者
楼主应该把电路图发一个让大家看看
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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