找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机多功能智能台灯制作(带时钟、姿态矫正、显示温度亮度)源程序

  [复制链接]
跳转到指定楼层
楼主
本帖最后由 电子哎嗨 于 2021-1-8 23:52 编辑

原创作品,禁止转载售卖,仅供学习参考!!!
功能说明:
1、上电之后LED灯点亮,代表当前灯是自动控制模式;
2、通过按键K5可以在自动和手动模式来回切换;
3、在手动模式下,按键K2,K3,K4分别对应一个灯光亮度;(k1按下时不可用)
4、在自动模式下,首先要检测到有人,才进行亮度的自动控制,否则台灯熄灭。可以挡住光敏电阻
的光线,或用手电筒来照射光敏电阻,模拟光照的变化,从而就可以看到台灯的亮度会随着环境中的
光照强度的改变而改变,效果是光照越弱,台灯越亮。如果人体传感器1分钟检测不到有人,台灯就
会自动熄灭。(光敏电阻在USB灯后面);
5、无论是自动模式还是手动模式,都是把亮度分为10个等级的,并在LCD上显示0-9;
6、设置日期时间:按下K1(设置)键,显示年位置会有光标闪烁,表示此时可以调节年份,如需调节年份,
按K3(加),K4(减)即可对年份进行调节。然后按K2(移动)键,显示月份位置会光标闪烁,同样的方法可
以调节月,再按K2键分别可设置日,时,分,秒。
7、靠近超声波时,蜂鸣器报警。

需要设计实物请私聊~
制作出来的实物图如下:

具体位置参考实物图

原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  1. #include <reg52.h>                 //调用单片机头文件
  2. #define uchar unsigned char  //无符号字符型 宏定义        变量范围0~255
  3. #define uint  unsigned int         //无符号整型 宏定义        变量范围0~65535
  4. #include "eeprom52.h"
  5. #include "intrins.h"
  6. #include "ds1302.h"
  7. #include "lcd1602.h"
  8. #include "ultrasonic_wave.h"//超声波头函数

  9. bit flag_200ms ;
  10. bit flag_100ms ;
  11. bit flag_beep1_en;//定时模式开启标志
  12. bit flag_beep2_en;
  13. bit flag_beep3_en;

  14. sbit k1=P1^4;         //时间设置切换
  15. sbit k2=P1^5;         //光标移动
  16. sbit k3=P1^6;         //加
  17. sbit k4=P1^7;         //减
  18. sbit k5=P2^7;         //手动/自动

  19. sbit ADC_CS = P3^5;         //ADC0832引脚定义
  20. sbit ADC_CLK = P3^6;         
  21. sbit ADC_DAT = P3^7;
  22.          
  23. sbit LED = P2^6;         //自动模式指示灯

  24. sbit dq   = P2^1;          //18b20 IO口的定义
  25.          
  26. sbit Module = P2^2;          // 人体红外感应引脚定义
  27. sbit Beep = P2^0;          // 蜂鸣器引脚定义

  28. sbit Lamp = P1^3;          // 照明灯定义
  29. uchar gCount=0;                  // 全局计数变量
  30. uchar gIndex;                  // 亮度变量,0是最暗,9是最亮,一共10档
  31. uint  gTime=0;                                                                // 计时变量,用于计时多久没检测到有人

  32. uint temperature ;    //温度变量

  33. uchar menu_1;                  //时间/定时模式切换
  34. uchar menu_2;                  //调整时间
  35. uchar ret;                          //AD采集结果

  36. uchar key_time,flag_value;      //用做连加的中间变量
  37. bit key_500ms  ;


  38. /******************把数据保存到单片机内部eeprom中******************/
  39. void write_eeprom()
  40. {
  41.         SectorErase(0x2000);
  42.         byte_write(0x2000, fen1);
  43.         byte_write(0x2001, shi1);
  44.         byte_write(0x2002, open1);
  45.         byte_write(0x2058, a_a);        
  46. }

  47. /******************把数据从单片机内部eeprom中读出来*****************/
  48. void read_eeprom()
  49. {
  50.         fen1  = byte_read(0x2000);
  51.         shi1  = byte_read(0x2001);
  52.         open1 = byte_read(0x2002);
  53.         a_a   = byte_read(0x2058);
  54. }

  55. /**************开机自检eeprom初始化*****************/
  56. void init_eeprom()
  57. {
  58.         read_eeprom();                //先读
  59.         if(a_a != 1)                //新的单片机初始单片机内问eeprom
  60.         {
  61.                 fen1  = 3;
  62.                 shi1  = 8;
  63.                 open1  = 1;
  64.                 a_a = 1;
  65.                 write_eeprom();           //保存数据
  66.         }        
  67. }

  68. /*********************************************************/
  69. // ADC0832的时钟脉冲
  70. /*********************************************************/
  71. void WavePlus()
  72. {
  73.         _nop_();
  74.         ADC_CLK = 1;
  75.         _nop_();
  76.         ADC_CLK = 0;
  77. }

  78. /*********************************************************/
  79. // 获取指定通道的A/D转换结果
  80. /*********************************************************/
  81. uchar Get_ADC0832()
  82. {
  83.         uchar i;
  84.         uchar dat1=0;
  85.         uchar dat2=0;
  86.         
  87.         ADC_CLK = 0;                                // 电平初始化
  88.         ADC_DAT = 1;
  89.         _nop_();
  90.         ADC_CS = 0;
  91.         WavePlus();                                        // 起始信号
  92.         ADC_DAT = 1;
  93.         WavePlus();                                        // 通道选择的第一位
  94.         ADC_DAT = 0;      
  95.         WavePlus();                                        // 通道选择的第二位
  96.         ADC_DAT = 1;
  97.         
  98.         for(i=0;i<8;i++)                // 第一次读取
  99.         {
  100.                 dat1<<=1;
  101.                 WavePlus();
  102.                 if(ADC_DAT)
  103.                         dat1=dat1|0x01;
  104.                 else
  105.                         dat1=dat1|0x00;
  106.         }
  107.         
  108.         for(i=0;i<8;i++)                // 第二次读取
  109.         {
  110.                 dat2>>= 1;
  111.                 if(ADC_DAT)
  112.                         dat2=dat2|0x80;
  113.                 else
  114.                         dat2=dat2|0x00;
  115.                 WavePlus();
  116.         }
  117.         
  118.         _nop_();                                                // 结束此次传输
  119.         ADC_DAT = 1;
  120.         ADC_CLK = 1;
  121.         ADC_CS  = 1;   

  122.         if(dat1==dat2)                        // 返回采集结果
  123.                 return dat1;
  124.         else
  125.                 return 0;
  126. }

  127. /*********************************************************/
  128. // 自动控制
  129. /*********************************************************/
  130. void AutoControl(uchar num)
  131. {
  132.         if(num<30)                                                                                // 最亮
  133.                 gIndex=9;
  134.         else if((num>35)&&(num<45))                                       
  135.                 gIndex=8;
  136.         else if((num>50)&&(num<60))                                
  137.                 gIndex=7;
  138.         else if((num>65)&&(num<75))
  139.                 gIndex=6;
  140.         else if((num>80)&&(num<90))
  141.                 gIndex=5;
  142.         else if((num>95)&&(num<105))
  143.                 gIndex=4;
  144.         else if((num>110)&&(num<120))
  145.                 gIndex=3;
  146.         else if((num>125)&&(num<135))
  147.                 gIndex=2;
  148.         else if((num>140)&&(num<150))
  149.                 gIndex=1;
  150.         else if(num>155)                                                                 // 最暗
  151.                 gIndex=0;
  152. }


  153. /***********************18b20初始化函数*****************************/
  154. void init_18b20()
  155. {
  156.         bit q;
  157.         dq = 1;                                //把总线拿高
  158.         delay_uint(1);            //15us
  159.         dq = 0;                                //给复位脉冲
  160.         delay_uint(80);                //750us
  161.         dq = 1;                                //把总线拿高 等待
  162.         delay_uint(10);                //110us
  163.         q = dq;                                //读取18b20初始化信号
  164.         delay_uint(20);                //200us
  165.         dq = 1;                                //把总线拿高 释放总线
  166. }

  167. /*************写18b20内的数据***************/
  168. void write_18b20(uchar dat)
  169. {
  170.         uchar i;
  171.         for(i=0;i<8;i++)
  172.         {                                         //写数据是低位开始
  173.                 dq = 0;                         //把总线拿低写时间隙开始
  174.                 dq = dat & 0x01; //向18b20总线写数据了
  175.                 delay_uint(5);         // 60us
  176.                 dq = 1;                         //释放总线
  177.                 dat >>= 1;
  178.         }        
  179. }

  180. /*************读取18b20内的数据***************/
  181. uchar read_18b20()
  182. {
  183.         uchar i,value;
  184.         for(i=0;i<8;i++)
  185.         {
  186.                 dq = 0;                         //把总线拿低读时间隙开始
  187.                 value >>= 1;         //读数据是低位开始
  188.                 dq = 1;                         //释放总线
  189.                 if(dq == 1)                 //开始读写数据
  190.                         value |= 0x80;
  191.                 delay_uint(5);         //60us        读一个时间隙最少要保持60us的时间
  192.         }
  193.         return value;                 //返回数据
  194. }

  195. /*************读取温度的值 读出来的是小数***************/
  196. uint read_temp()
  197. {
  198.     uint value;                          
  199.         uchar low;                           //在读取温度的时候如果中断的太频繁了,就应该把中断给关了,否则会影响到18b20的时序
  200.         init_18b20();                   //初始化18b20
  201.         write_18b20(0xcc);           //跳过64位ROM
  202.         write_18b20(0x44);           //启动一次温度转换命令
  203.         delay_uint(50);                   //500us

  204.         init_18b20();                   //初始化18b20
  205.         
  206.         write_18b20(0xcc);           //跳过64位ROM
  207.         write_18b20(0xbe);           //发出读取暂存器命令
  208.         
  209.         EA = 0;
  210.         low = read_18b20();           //读温度低字节
  211.         value = read_18b20();  //读温度高字节
  212.         EA = 1;
  213.         value <<= 8;                   //把温度的高位左移8位
  214.         value |= low;                   //把读出的温度低位放到value的低八位中
  215.         value *= 0.625;               //转换到温度值 小数
  216.         return value;                   //返回读出的温度 带小数
  217. }



  218. /******************1ms 延时函数*******************/
  219. void delay_1ms(uint q)
  220. {
  221.         uint i,j;
  222.         for(i=0;i<q;i++)
  223.                 for(j=0;j<120;j++);
  224. }

  225. ///******************写星期函数*******************/
  226. //void write_week(uchar hang,uchar add,uchar week)//写星期函数
  227. //{
  228. //        if(hang==1)   
  229. //                write_com(0x80+add);
  230. //        else
  231. //                write_com(0x80+0x40+add);         
  232. //        switch(week)
  233. //        {
  234. //                case 1:write_data('M');//星期数为1时,显示
  235. //                           write_data('O');
  236. //                           write_data('N');
  237. //                           break;
  238. //           
  239. //                case 2:write_data('T');//星期数据为2时显示
  240. //                           write_data('U');
  241. //                           write_data('E');
  242. //                           break;
  243. //               
  244. //                case 3:write_data('W');//星期数据为3时显示
  245. //                           write_data('E');
  246. //                           write_data('D');
  247. //                           break;
  248. //               
  249. //                case 4:write_data('T');//星期数据为4是显示
  250. //                           write_data('H');
  251. //                           write_data('U');
  252. //                           break;
  253. //               
  254. //                case 5:write_data('F');//星期数据为5时显示
  255. //                           write_data('R');
  256. //                           write_data('I');
  257. //                           break;
  258. //               
  259. //                case 6:write_data('S');//星期数据为6时显示
  260. //                           write_data('T');
  261. //                           write_data('A');
  262. //                           break;
  263. //               
  264. //                case 7:write_data('S');//星期数据为7时显示
  265. //                           write_data('U');
  266. //                           write_data('N');
  267. //                           break;
  268. //        }
  269. //}

  270. /******************写亮度函数*******************/
  271. void write_light(uchar hang,uchar add,uchar light)//写星期函数
  272. {
  273.         if(hang==1)   
  274.                 write_com(0x80+add);
  275.         else
  276.                 write_com(0x80+0x40+add);         
  277.         
  278.         write_data(0x30+light);//显示亮度等级
  279.                
  280. }



  281. /*************时钟显示***************/
  282. void init_1602_ds1302()
  283. {
  284.         write_sfm2_ds1302(1,1,shi);                   //显示时
  285.         write_sfm2_ds1302(1,4,fen);                   //显示分
  286.         write_sfm2_ds1302(1,7,miao);           //显示秒
  287.         write_light(2,13,gIndex);                        //显示亮度
  288.   //write_sfm1(1,14,week);                           //显示星期
  289.     if(temperature<900)
  290.         {
  291.             write_sfm3_18B20(1,11,temperature);           //显示温度
  292.         }
  293.         write_sfm2_ds1302(2,2,nian);   //显示年
  294.         write_sfm2_ds1302(2,5,yue);           //显示月        
  295.         write_sfm2_ds1302(2,8,ri);           //显示日                        
  296. }                                                                           

  297. /************定时器0初始化程序*********/
  298. void init_time0()         
  299. {
  300.         EA   = 1;                   //开总中断
  301.         TMOD = TMOD|0x01;          //定时器0、工作方式1
  302.         TH0  = 252;                  //给定时器0的TH0装初值
  303.         TL0  = 24;              //给定时器0的TL0装初值
  304.         ET0  = 1;                  //开定时器0中断
  305.         TR0  = 1;                  //允许定时器0定时
  306. }



  307. /********************独立按键程序*****************/
  308. uchar key_can;         //按键值

  309. void key()         //独立按键
  310. {
  311.         static uchar key_new;
  312.         key_can = 20;                   //按键值还原
  313.     if(k1==0)                  //检测按键K1是否按下
  314.         {        
  315.                 delay_1ms(10);   //消除抖动 一般大约10ms
  316.                 if(k1==0)         //再次判断按键是否按下
  317.                 {
  318.                            key_new = 0;
  319.                         key_can = 1;                                 
  320.                 }
  321.                 while(!k1);         //检测按键是否松开
  322.         }
  323.         else
  324.         key_new = 1;        
  325.         
  326.         if(k2==0)                  //检测按键K1是否按下
  327.         {        
  328.                 delay_1ms(10);   //消除抖动 一般大约10ms
  329.                 if(k2==0)         //再次判断按键是否按下
  330.                 {
  331.                            key_new = 0;
  332.                         key_can = 2;
  333.                 }
  334.                 while(!k2);         //检测按键是否松开
  335.         }
  336.         else
  337.         key_new = 1;
  338.         
  339.         if(k3==0)                  //检测按键K1是否按下
  340.         {        
  341.                 delay_1ms(10);   //消除抖动 一般大约10ms
  342.                 if(k3==0)         //再次判断按键是否按下
  343.                 {
  344.                            key_new = 0;
  345.                         key_can = 3;         
  346.                 }
  347.                 while(!k3);         //检测按键是否松开
  348.         }
  349.         else
  350.         key_new = 1;        
  351.         
  352.         if(k4==0)                  //检测按键K1是否按下
  353.         {        
  354.                 delay_1ms(10);   //消除抖动 一般大约10ms
  355.                 if(k4==0)         //再次判断按键是否按下
  356.                 {
  357.                            key_new = 0;
  358.                         key_can = 4;         
  359.                 }
  360.                 while(!k4);         //检测按键是否松开
  361.         }
  362.         else
  363.         key_new = 1;
  364.         
  365.         if(k5==0)                  //检测按键K5是否按下
  366.         {        
  367.                 delay_1ms(10);   //消除抖动 一般大约10ms
  368.                 if(k5==0)         //再次判断按键是否按下
  369.                 {
  370.                            LED=~LED;                                        // 切换LED灯状态         
  371.                 }
  372.                 while(!k5);         //检测按键是否松开
  373.         }                        
  374.                
  375. }

  376. /**********************设置函数************************/
  377. void key_with()
  378. {
  379.         if(key_can == 1)        
  380.         {
  381.                 menu_1++;
  382.                 if(menu_1 == 1)         
  383.                 {
  384.                         menu_2 = 1;
  385.                         write_string(1,0,"    :  :    W:  ");                        
  386.                         write_string(2,0," 20  -  -       ");        
  387.                 }
  388.                
  389.                 if(menu_1 > 1)   
  390.                 {
  391.                         menu_1 = 0;
  392.                         write_guanbiao(1,2,0);        
  393.                         init_1602_dis_csf();      //初始化液晶显示               
  394.                 }
  395.         }
  396.         if(key_can == 2)        
  397.         {
  398.                 flag_200ms = 1;
  399.                 if(menu_1 == 1)                 
  400.                 {
  401.                         menu_2 ++;
  402.                         if(menu_2 > 7)
  403.                                 menu_2 = 1;
  404.                 }
  405.         }
  406.         if(menu_1 == 1)
  407.         {
  408.                 if(menu_2 == 1)                  
  409.                 {
  410.                         if(key_can == 3)        
  411.                         {
  412.                                 shi+=0x01;
  413.                                 if((shi & 0x0f) >= 0x0a)
  414.                                         shi = (shi & 0xf0) + 0x10;           ///***shi & 0xf0低四位清零,(shi & 0xf0) + 0x10向高位进1(高四位加1)***///                                if(shi >= 0x24)
  415.                                         shi = 0;
  416.                         }               
  417.                         if(key_can == 4)        
  418.                         {
  419.                                 if(shi == 0x00)         
  420.                                         shi = 0x24;
  421.                                 if((shi & 0x0f) == 0x00)  
  422.                                         shi = (shi | 0x0a) - 0x10;         ///***如果个位为0,高四位减1***///
  423.                                 shi -- ;
  424.                         }                                          
  425.                 }
  426.                 if(menu_2 == 2)                  
  427.                 {
  428.                         if(key_can == 3)        
  429.                         {
  430.                                 fen+=0x01;
  431.                                 if((fen & 0x0f) >= 0x0a)
  432.                                         fen = (fen & 0xf0) + 0x10;
  433.                                 if(fen >= 0x60)
  434.                                         fen = 0;
  435.                         }               
  436.                         if(key_can == 4)         
  437.                         {
  438.                                 if(fen == 0x00)
  439.                                         fen = 0x5a;
  440.                                 if((fen & 0x0f) == 0x00)
  441.                                         fen = (fen | 0x0a) - 0x10;
  442.                                 fen -- ;
  443.                         }        
  444.                 }
  445.                 if(menu_2 == 3)               
  446.                 {
  447.                         if(key_can == 3)        
  448.                         {
  449.                                 miao+=0x01;
  450.                                 if((miao & 0x0f) >= 0x0a)
  451.                                         miao = (miao & 0xf0) + 0x10;
  452.                                 if(miao >= 0x60)
  453.                                         miao = 0;
  454.                         }        
  455.                         if(key_can == 4)         
  456.                         {
  457.                                 if(miao == 0x00)
  458.                                         miao = 0x5a;
  459.                                 if((miao & 0x0f) == 0x00)
  460.                                         miao = (miao | 0x0a) - 0x10;
  461.                                 miao -- ;                        
  462.                         }
  463.                 }
  464.                 if(menu_2 == 4)                  
  465.                 {
  466.                         if(key_can == 3)        
  467.                         {
  468.                             week+=0x01;
  469.                                 if((week & 0x0f) >= 0x0a)
  470.                                         week = (week & 0xf0) + 0x10;
  471.                                 if(week >= 0x08)
  472.                                         week = 1;
  473.                         }               
  474.                         if(key_can == 4)                  
  475.                         {
  476.                                 if(week == 0x01)
  477.                                         week = 0x08;
  478.                                 if((week & 0x0f) == 0x00)
  479.                                         week = (week | 0x0a) - 0x10;
  480.                                 week -- ;
  481.                         }        
  482.                 }
  483.                 if(menu_2 == 5)                 
  484.                 {
  485.                         if(key_can == 3)        
  486.                         {
  487.                             nian+=0x01;
  488.                                 if((nian & 0x0f) >= 0x0a)
  489.                                         nian = (nian & 0xf0) + 0x10;
  490.                                 if(nian >= 0x9a)
  491.                                         nian = 1;
  492.                         }               
  493.                         if(key_can == 4)        
  494.                         {
  495.                                 if(nian == 0x01)
  496.                                         nian = 0x9a;
  497.                                 if((nian & 0x0f) == 0x00)
  498.                                         nian = (nian | 0x0a) - 0x10;
  499.                                 nian -- ;               
  500.                         }        
  501.                 }
  502.                 if(menu_2 == 6)                  
  503.                 {
  504.                         if(key_can == 3)        
  505.                         {
  506.                             yue+=0x01;
  507.                                 if((yue & 0x0f) >= 0x0a)
  508.                                         yue = (yue & 0xf0) + 0x10;
  509.                                 if(yue >= 0x13)
  510.                                         yue = 1;
  511.                         }               
  512.                         if(key_can == 4)         
  513.                         {
  514.                                 if(yue == 0x01)
  515.                                         yue = 0x13;
  516.                                 if((yue & 0x0f) == 0x00)
  517.                                         yue = (yue | 0x0a) - 0x10;
  518.                                 yue -- ;                                       
  519.                         }        
  520.                 }
  521.                 if(menu_2 == 7)                  
  522.                 {
  523.                         if(key_can == 3)        
  524.                         {
  525.                     ri+=0x01;
  526.                         if((ri & 0x0f) >= 0x0a)
  527.                                 ri = (ri & 0xf0) + 0x10;
  528.                         if(ri >= 0x32)
  529.                                 ri = 0;                        
  530.                         }               
  531.                         if(key_can == 4)                  
  532.                         {
  533.                                 if(ri == 0x01)
  534.                                         ri = 0x32;
  535.                                 if((ri & 0x0f) == 0x00)
  536.                                         ri = (ri | 0x0a) - 0x10;
  537.                                 ri -- ;                        
  538.                         }        
  539.                 }
  540.                 write_sfm2_ds1302(1,2,shi);           
  541.                 write_sfm2_ds1302(1,5,fen);           
  542.                 write_sfm2_ds1302(1,8,miao);         
  543.                 write_sfm1(1,14,week);                                          
  544.                 write_sfm2_ds1302(2,3,nian);           
  545.                 write_sfm2_ds1302(2,6,yue);           
  546.                 write_sfm2_ds1302(2,9,ri);           
  547.   ///***write_sfm3_18B20(2,12,temperature);           
  548.                 switch(menu_2)           // 光标显示
  549.                 {
  550.                         case 1:  write_guanbiao(1,2,1);  break;
  551.                         case 2:  write_guanbiao(1,5,1);  break;
  552.                         case 3:  write_guanbiao(1,8,1);  break;
  553.                         case 4:  write_guanbiao(1,14,1);  break;
  554.                         case 5:  write_guanbiao(2,3,1);  break;
  555.                         case 6:  write_guanbiao(2,6,1);  break;
  556.                         case 7:  write_guanbiao(2,9,1);  break;
  557.                 }
  558.                 write_time();           //把时间写进去
  559.         }                                
  560.                                 
  561. }

  562. /*****************主函数********************/
  563. void main()
  564. {        
  565.         P0 = P1 = P2 = P3 = 0xff;        //单片机IO口初始化为1
  566.         
  567.         LED=0;                                                // 指示灯点亮(自动模式指示灯)
  568.         ret=Get_ADC0832();                    // 获取AD采集结果(环境光照强度)
  569.         AutoControl(ret);                        // 上电先进行一次自动亮度控制        
  570.         AutoControl(ret+7);

  571.         delay_1ms(150);
  572.     Init_ultrasonic_wave();          //超声波定时器初始化
  573.         init_time0();                 //初始化定时器
  574.         init_ds1302();                 //ds1302初始化
  575.         init_1602();                 //lcd1602初始化
  576.         init_1602_dis_csf(); //lcd1602初始化显示
  577.         init_eeprom();       //开始初始化保存的数据
  578.         temperature = read_temp();        //先读出温度的值
  579.         delay_1ms(650);
  580.         temperature = read_temp();        //先读出温度的值
  581.         while(1)
  582.         {

  583.                 key();                //按键程序
  584.                 if(key_can < 10)
  585.                 {
  586.                         key_with();        
  587.                         if(menu_1 == 0)
  588.                         {
  589.                             if(LED==1)
  590.                                 {
  591.                                         if(key_can == 2)  //左移键
  592.                                         {
  593.                                                 gIndex=1;
  594.                                         }
  595.         
  596.                                         if(key_can == 3)  //加键
  597.                                         {
  598.                                            gIndex=5;                                
  599.                                         }
  600.         
  601.                                         if(key_can == 4)  //减键
  602.                                         {
  603.                                             gIndex=9;
  604.                                         }
  605.                                 }                                                                                   
  606.                         }
  607.                 }
  608.                         
  609.                 /* 亮度控制 */
  610.                 if(LED==0)                                                        // 如果LED是亮的                                       
  611.                 {
  612.                         if(gTime<60000)
  613.                         {
  614.                                 ret=Get_ADC0832();                    // 获取AD采集结果(环境光照强度)
  615.                                 AutoControl(ret);                        // 进行自动控制        
  616.                         }
  617.                 }
  618.                 delay_1ms(100);

  619.                 /*检测是否有人*/
  620.                 if(Module==1)
  621.                 {
  622.                         gTime=0;                                                                // 检测到有人,则把60秒计时清零
  623.                 }
  624.                 if(gTime>60000)                                                                // 如果gTime的值超过了60000
  625.                 {
  626.                         gTime=60000;                                                        // 则把gTime的值重新赋值为60000,避免过大溢出
  627.                         gIndex=0;                                                                // 如果1分钟检测不到有人,则把台灯熄灭
  628.                 }


  629.                 if(flag_200ms == 1)
  630.                 {                                                
  631.                         flag_200ms = 0;
  632.                         if(menu_1 == 0)
  633.                         {
  634.                                 read_time();                  //读时间
  635.                                 temperature = read_temp();        //先读出温度的值
  636.                                 init_1602_ds1302();   //显示时钟
  637.                         }
  638.                 }
  639.                 delay_1ms(1);

  640.                    StartModule();//启动超声波
  641.                 while(!RX)          //当RX为零时等待
  642.                 TR1=1;                  //开启计数
  643.                 while(RX);          //当RX为1计数并等待
  644.                 TR1=0;                  //关闭计数
  645.                 delay_1ms(20);
  646.                                 
  647.                 Conut(); //计算距离
  648.                    //距离小于30
  649.                 if(L_ < 30)
  650.                 {                                                                 
  651.                      Beep=~Beep;
  652.                          delay_1ms(1);        
  653.                          Beep=~Beep;
  654.                          delay_1ms(1);
  655.                          delay_1ms(100);        
  656.                 }
  657.                 else
  658.                 Beep=1;

  659.         }
  660. }

  661. /**************定时器0中断程序*****************/
  662. void time0() interrupt 1
  663. {                                                                                 
  664.         static uchar value;
  665.         TH0 = 252;
  666.         TL0 = 24;           //1ms
  667.         value ++;           
  668.         if((value % 100) == 0)         //100ms  
  669.         {
  670.                 flag_100ms = 1;
  671.         }
  672.         if(value >= 200)         //200ms
  673.         {
  674.                 value = 0;
  675.                 flag_200ms = 1;
  676.         }

  677.         gTime++;                                        // 每1毫秒,gTime变量加1
  678.     gCount++;                                    // 每1毫秒,gCount变量加1        
  679.         if(gCount==10)                                // 如果gCount加到10了
  680.         {
  681.                 gCount=0;                                                // 则将gCount清零,进入新一轮的计数
  682.                 if(gIndex!=0)                                // 如果说台灯不是最暗的(熄灭)
  683.                 {
  684.                         Lamp=0;                                                // 则把台灯点亮
  685.                 }
  686.         }
  687.         if(gCount==gIndex)                // 如果gCount计数到和gIndex一样了
  688.         {
  689.                 if(gIndex!=9)                                // 如果说台灯不是最亮的
  690.                 {
  691.                         Lamp=1;                                                // 则把台灯熄灭
  692.                 }
  693.         }

  694. }

  695. void time1() interrupt 3                  //T1中断用来计数器溢出,超过测距范围
  696. {
  697.         TH1=0;
  698.         TL1=0;
  699. }  
复制代码
资料群(注明来自51黑)861514012
必备的单片机开发软件和教程视频我已上传到群里,有需要的可以自行进去下载

全部资料51hei下载地址:
仿真.rar (78.23 KB, 下载次数: 301)
源程序.rar (74.89 KB, 下载次数: 310)

评分

参与人数 1黑币 +100 收起 理由
admin + 100 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

来自 2#
ID:331717 发表于 2023-12-7 11:35 | 只看该作者
材料清单已上传资料群中,需要请自行下载
回复

使用道具 举报

板凳
ID:859243 发表于 2021-11-16 22:30 | 只看该作者
External model DLL "ADC083X.DLL" not found. GLE=0x000036B1.
怎么办啊
回复

使用道具 举报

地板
ID:331717 发表于 2021-11-25 09:35 | 只看该作者
coutHello 发表于 2021-11-16 22:30
External model DLL "ADC083X.DLL" not found. GLE=0x000036B1.
怎么办啊

你这个应该是使用了高版本的Proteus软件,可以换低版本的试下,或者使用老版本的 ADC083X.DLL 文件替换新版本中的 ADC083X.DLL 文件。
回复

使用道具 举报

5#
ID:967018 发表于 2021-12-2 15:36 | 只看该作者
大佬具体的原理是什么啊,能讲解一下吗?求求了
回复

使用道具 举报

6#
ID:331717 发表于 2021-12-6 19:38 | 只看该作者
NANS 发表于 2021-12-2 15:36
大佬具体的原理是什么啊,能讲解一下吗?求求了

原理主要是通过光敏电阻感应外界光强,根据外界光强值的大小来自动调节台灯亮度,亮度调节是利用单片机控制PWM的占空比,从而来改变电压的大小实现灯光亮度的调节。然后其中又加入了手动调节功能、人体感应功能、时钟显示功能、坐姿矫正功能,具体功能实现的原理可以仔细阅读下源程序,里面注释挺全的。
回复

使用道具 举报

7#
ID:991822 发表于 2021-12-20 21:53 | 只看该作者
求材料清单
回复

使用道具 举报

8#
ID:824490 发表于 2021-12-21 17:26 | 只看该作者
按键有点多,如果能改成用EC11编码器,瞬间上了好几个档次。。
回复

使用道具 举报

9#
ID:915590 发表于 2021-12-27 22:05 | 只看该作者
这个超声波模块是什么型号的?
回复

使用道具 举报

10#
ID:998128 发表于 2021-12-29 19:13 | 只看该作者

加一,蹲一个材料清单
回复

使用道具 举报

11#
ID:295874 发表于 2022-1-8 20:27 | 只看该作者
这里的时钟模块显示数据为何不正确?
回复

使用道具 举报

12#
ID:1000334 发表于 2022-1-13 08:44 | 只看该作者
可否给一个材料清单
回复

使用道具 举报

13#
ID:952197 发表于 2022-1-13 10:56 | 只看该作者
求材料清单
回复

使用道具 举报

14#
ID:81365 发表于 2022-1-14 23:54 | 只看该作者
姿态矫正应该自动实现吧
回复

使用道具 举报

15#
ID:1032870 发表于 2022-6-7 13:46 | 只看该作者
想请问下,为什么仿真运行不了,这个如何解决?
出现的问题显示“cannot open  xxx.SDF"
回复

使用道具 举报

16#
ID:1055161 发表于 2022-12-25 23:21 | 只看该作者
为什么温度显示不了呢
回复

使用道具 举报

17#
ID:1061818 发表于 2023-1-30 20:14 | 只看该作者
有数码管的吗?
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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