找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 11563|回復(fù): 16
收起左側(cè)

單片機(jī)多功能智能臺(tái)燈制作(帶時(shí)鐘、姿態(tài)矯正、顯示溫度亮度)源程序

  [復(fù)制鏈接]
ID:331717 發(fā)表于 2020-12-21 13:38 | 顯示全部樓層 |閱讀模式
本帖最后由 電子哎嗨 于 2021-1-8 23:52 編輯

原創(chuàng)作品,禁止轉(zhuǎn)載售賣,僅供學(xué)習(xí)參考。。
功能說明:
1、上電之后LED燈點(diǎn)亮,代表當(dāng)前燈是自動(dòng)控制模式;
2、通過按鍵K5可以在自動(dòng)和手動(dòng)模式來回切換;
3、在手動(dòng)模式下,按鍵K2,K3,K4分別對(duì)應(yīng)一個(gè)燈光亮度;(k1按下時(shí)不可用)
4、在自動(dòng)模式下,首先要檢測(cè)到有人,才進(jìn)行亮度的自動(dòng)控制,否則臺(tái)燈熄滅?梢該踝」饷綦娮
的光線,或用手電筒來照射光敏電阻,模擬光照的變化,從而就可以看到臺(tái)燈的亮度會(huì)隨著環(huán)境中的
光照強(qiáng)度的改變而改變,效果是光照越弱,臺(tái)燈越亮。如果人體傳感器1分鐘檢測(cè)不到有人,臺(tái)燈就
會(huì)自動(dòng)熄滅。(光敏電阻在USB燈后面);
5、無論是自動(dòng)模式還是手動(dòng)模式,都是把亮度分為10個(gè)等級(jí)的,并在LCD上顯示0-9;
6、設(shè)置日期時(shí)間:按下K1(設(shè)置)鍵,顯示年位置會(huì)有光標(biāo)閃爍,表示此時(shí)可以調(diào)節(jié)年份,如需調(diào)節(jié)年份,
按K3(加),K4(減)即可對(duì)年份進(jìn)行調(diào)節(jié)。然后按K2(移動(dòng))鍵,顯示月份位置會(huì)光標(biāo)閃爍,同樣的方法可
以調(diào)節(jié)月,再按K2鍵分別可設(shè)置日,時(shí),分,秒。
7、靠近超聲波時(shí),蜂鳴器報(bào)警。

需要設(shè)計(jì)實(shí)物請(qǐng)私聊~
制作出來的實(shí)物圖如下:
48229EB52F5960EC7E533E9BE9CDD7A2.jpg
具體位置參考實(shí)物圖

原理圖如下(proteus仿真工程文件可到本帖附件中下載)
ZM])D`6MO1$HI5(T381Y5OF.png

單片機(jī)源程序如下:
  1. #include <reg52.h>                 //調(diào)用單片機(jī)頭文件
  2. #define uchar unsigned char  //無符號(hào)字符型 宏定義        變量范圍0~255
  3. #define uint  unsigned int         //無符號(hào)整型 宏定義        變量范圍0~65535
  4. #include "eeprom52.h"
  5. #include "intrins.h"
  6. #include "ds1302.h"
  7. #include "lcd1602.h"
  8. #include "ultrasonic_wave.h"//超聲波頭函數(shù)

  9. bit flag_200ms ;
  10. bit flag_100ms ;
  11. bit flag_beep1_en;//定時(shí)模式開啟標(biāo)志
  12. bit flag_beep2_en;
  13. bit flag_beep3_en;

  14. sbit k1=P1^4;         //時(shí)間設(shè)置切換
  15. sbit k2=P1^5;         //光標(biāo)移動(dòng)
  16. sbit k3=P1^6;         //加
  17. sbit k4=P1^7;         //減
  18. sbit k5=P2^7;         //手動(dòng)/自動(dòng)

  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;         //自動(dòng)模式指示燈

  24. sbit dq   = P2^1;          //18b20 IO口的定義
  25.          
  26. sbit Module = P2^2;          // 人體紅外感應(yīng)引腳定義
  27. sbit Beep = P2^0;          // 蜂鳴器引腳定義

  28. sbit Lamp = P1^3;          // 照明燈定義
  29. uchar gCount=0;                  // 全局計(jì)數(shù)變量
  30. uchar gIndex;                  // 亮度變量,0是最暗,9是最亮,一共10檔
  31. uint  gTime=0;                                                                // 計(jì)時(shí)變量,用于計(jì)時(shí)多久沒檢測(cè)到有人

  32. uint temperature ;    //溫度變量

  33. uchar menu_1;                  //時(shí)間/定時(shí)模式切換
  34. uchar menu_2;                  //調(diào)整時(shí)間
  35. uchar ret;                          //AD采集結(jié)果

  36. uchar key_time,flag_value;      //用做連加的中間變量
  37. bit key_500ms  ;


  38. /******************把數(shù)據(jù)保存到單片機(jī)內(nèi)部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. /******************把數(shù)據(jù)從單片機(jī)內(nèi)部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. /**************開機(jī)自檢eeprom初始化*****************/
  56. void init_eeprom()
  57. {
  58.         read_eeprom();                //先讀
  59.         if(a_a != 1)                //新的單片機(jī)初始單片機(jī)內(nèi)問eeprom
  60.         {
  61.                 fen1  = 3;
  62.                 shi1  = 8;
  63.                 open1  = 1;
  64.                 a_a = 1;
  65.                 write_eeprom();           //保存數(shù)據(jù)
  66.         }        
  67. }

  68. /*********************************************************/
  69. // ADC0832的時(shí)鐘脈沖
  70. /*********************************************************/
  71. void WavePlus()
  72. {
  73.         _nop_();
  74.         ADC_CLK = 1;
  75.         _nop_();
  76.         ADC_CLK = 0;
  77. }

  78. /*********************************************************/
  79. // 獲取指定通道的A/D轉(zhuǎn)換結(jié)果
  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();                                        // 起始信號(hào)
  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_();                                                // 結(jié)束此次傳輸
  119.         ADC_DAT = 1;
  120.         ADC_CLK = 1;
  121.         ADC_CS  = 1;   

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

  127. /*********************************************************/
  128. // 自動(dòng)控制
  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初始化函數(shù)*****************************/
  154. void init_18b20()
  155. {
  156.         bit q;
  157.         dq = 1;                                //把總線拿高
  158.         delay_uint(1);            //15us
  159.         dq = 0;                                //給復(fù)位脈沖
  160.         delay_uint(80);                //750us
  161.         dq = 1;                                //把總線拿高 等待
  162.         delay_uint(10);                //110us
  163.         q = dq;                                //讀取18b20初始化信號(hào)
  164.         delay_uint(20);                //200us
  165.         dq = 1;                                //把總線拿高 釋放總線
  166. }

  167. /*************寫18b20內(nèi)的數(shù)據(jù)***************/
  168. void write_18b20(uchar dat)
  169. {
  170.         uchar i;
  171.         for(i=0;i<8;i++)
  172.         {                                         //寫數(shù)據(jù)是低位開始
  173.                 dq = 0;                         //把總線拿低寫時(shí)間隙開始
  174.                 dq = dat & 0x01; //向18b20總線寫數(shù)據(jù)了
  175.                 delay_uint(5);         // 60us
  176.                 dq = 1;                         //釋放總線
  177.                 dat >>= 1;
  178.         }        
  179. }

  180. /*************讀取18b20內(nèi)的數(shù)據(jù)***************/
  181. uchar read_18b20()
  182. {
  183.         uchar i,value;
  184.         for(i=0;i<8;i++)
  185.         {
  186.                 dq = 0;                         //把總線拿低讀時(shí)間隙開始
  187.                 value >>= 1;         //讀數(shù)據(jù)是低位開始
  188.                 dq = 1;                         //釋放總線
  189.                 if(dq == 1)                 //開始讀寫數(shù)據(jù)
  190.                         value |= 0x80;
  191.                 delay_uint(5);         //60us        讀一個(gè)時(shí)間隙最少要保持60us的時(shí)間
  192.         }
  193.         return value;                 //返回?cái)?shù)據(jù)
  194. }

  195. /*************讀取溫度的值 讀出來的是小數(shù)***************/
  196. uint read_temp()
  197. {
  198.     uint value;                          
  199.         uchar low;                           //在讀取溫度的時(shí)候如果中斷的太頻繁了,就應(yīng)該把中斷給關(guān)了,否則會(huì)影響到18b20的時(shí)序
  200.         init_18b20();                   //初始化18b20
  201.         write_18b20(0xcc);           //跳過64位ROM
  202.         write_18b20(0x44);           //啟動(dòng)一次溫度轉(zhuǎn)換命令
  203.         delay_uint(50);                   //500us

  204.         init_18b20();                   //初始化18b20
  205.         
  206.         write_18b20(0xcc);           //跳過64位ROM
  207.         write_18b20(0xbe);           //發(fā)出讀取暫存器命令
  208.         
  209.         EA = 0;
  210.         low = read_18b20();           //讀溫度低字節(jié)
  211.         value = read_18b20();  //讀溫度高字節(jié)
  212.         EA = 1;
  213.         value <<= 8;                   //把溫度的高位左移8位
  214.         value |= low;                   //把讀出的溫度低位放到value的低八位中
  215.         value *= 0.625;               //轉(zhuǎn)換到溫度值 小數(shù)
  216.         return value;                   //返回讀出的溫度 帶小數(shù)
  217. }



  218. /******************1ms 延時(shí)函數(shù)*******************/
  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. ///******************寫星期函數(shù)*******************/
  226. //void write_week(uchar hang,uchar add,uchar week)//寫星期函數(shù)
  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');//星期數(shù)為1時(shí),顯示
  235. //                           write_data('O');
  236. //                           write_data('N');
  237. //                           break;
  238. //           
  239. //                case 2:write_data('T');//星期數(shù)據(jù)為2時(shí)顯示
  240. //                           write_data('U');
  241. //                           write_data('E');
  242. //                           break;
  243. //               
  244. //                case 3:write_data('W');//星期數(shù)據(jù)為3時(shí)顯示
  245. //                           write_data('E');
  246. //                           write_data('D');
  247. //                           break;
  248. //               
  249. //                case 4:write_data('T');//星期數(shù)據(jù)為4是顯示
  250. //                           write_data('H');
  251. //                           write_data('U');
  252. //                           break;
  253. //               
  254. //                case 5:write_data('F');//星期數(shù)據(jù)為5時(shí)顯示
  255. //                           write_data('R');
  256. //                           write_data('I');
  257. //                           break;
  258. //               
  259. //                case 6:write_data('S');//星期數(shù)據(jù)為6時(shí)顯示
  260. //                           write_data('T');
  261. //                           write_data('A');
  262. //                           break;
  263. //               
  264. //                case 7:write_data('S');//星期數(shù)據(jù)為7時(shí)顯示
  265. //                           write_data('U');
  266. //                           write_data('N');
  267. //                           break;
  268. //        }
  269. //}

  270. /******************寫亮度函數(shù)*******************/
  271. void write_light(uchar hang,uchar add,uchar light)//寫星期函數(shù)
  272. {
  273.         if(hang==1)   
  274.                 write_com(0x80+add);
  275.         else
  276.                 write_com(0x80+0x40+add);         
  277.         
  278.         write_data(0x30+light);//顯示亮度等級(jí)
  279.                
  280. }



  281. /*************時(shí)鐘顯示***************/
  282. void init_1602_ds1302()
  283. {
  284.         write_sfm2_ds1302(1,1,shi);                   //顯示時(shí)
  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. /************定時(shí)器0初始化程序*********/
  298. void init_time0()         
  299. {
  300.         EA   = 1;                   //開總中斷
  301.         TMOD = TMOD|0x01;          //定時(shí)器0、工作方式1
  302.         TH0  = 252;                  //給定時(shí)器0的TH0裝初值
  303.         TL0  = 24;              //給定時(shí)器0的TL0裝初值
  304.         ET0  = 1;                  //開定時(shí)器0中斷
  305.         TR0  = 1;                  //允許定時(shí)器0定時(shí)
  306. }



  307. /********************獨(dú)立按鍵程序*****************/
  308. uchar key_can;         //按鍵值

  309. void key()         //獨(dú)立按鍵
  310. {
  311.         static uchar key_new;
  312.         key_can = 20;                   //按鍵值還原
  313.     if(k1==0)                  //檢測(cè)按鍵K1是否按下
  314.         {        
  315.                 delay_1ms(10);   //消除抖動(dòng) 一般大約10ms
  316.                 if(k1==0)         //再次判斷按鍵是否按下
  317.                 {
  318.                            key_new = 0;
  319.                         key_can = 1;                                 
  320.                 }
  321.                 while(!k1);         //檢測(cè)按鍵是否松開
  322.         }
  323.         else
  324.         key_new = 1;        
  325.         
  326.         if(k2==0)                  //檢測(cè)按鍵K1是否按下
  327.         {        
  328.                 delay_1ms(10);   //消除抖動(dòng) 一般大約10ms
  329.                 if(k2==0)         //再次判斷按鍵是否按下
  330.                 {
  331.                            key_new = 0;
  332.                         key_can = 2;
  333.                 }
  334.                 while(!k2);         //檢測(cè)按鍵是否松開
  335.         }
  336.         else
  337.         key_new = 1;
  338.         
  339.         if(k3==0)                  //檢測(cè)按鍵K1是否按下
  340.         {        
  341.                 delay_1ms(10);   //消除抖動(dòng) 一般大約10ms
  342.                 if(k3==0)         //再次判斷按鍵是否按下
  343.                 {
  344.                            key_new = 0;
  345.                         key_can = 3;         
  346.                 }
  347.                 while(!k3);         //檢測(cè)按鍵是否松開
  348.         }
  349.         else
  350.         key_new = 1;        
  351.         
  352.         if(k4==0)                  //檢測(cè)按鍵K1是否按下
  353.         {        
  354.                 delay_1ms(10);   //消除抖動(dòng) 一般大約10ms
  355.                 if(k4==0)         //再次判斷按鍵是否按下
  356.                 {
  357.                            key_new = 0;
  358.                         key_can = 4;         
  359.                 }
  360.                 while(!k4);         //檢測(cè)按鍵是否松開
  361.         }
  362.         else
  363.         key_new = 1;
  364.         
  365.         if(k5==0)                  //檢測(cè)按鍵K5是否按下
  366.         {        
  367.                 delay_1ms(10);   //消除抖動(dòng) 一般大約10ms
  368.                 if(k5==0)         //再次判斷按鍵是否按下
  369.                 {
  370.                            LED=~LED;                                        // 切換LED燈狀態(tài)         
  371.                 }
  372.                 while(!k5);         //檢測(cè)按鍵是否松開
  373.         }                        
  374.                
  375. }

  376. /**********************設(shè)置函數(shù)************************/
  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向高位進(jìn)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;         ///***如果個(gè)位為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)           // 光標(biāo)顯示
  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();           //把時(shí)間寫進(jìn)去
  559.         }                                
  560.                                 
  561. }

  562. /*****************主函數(shù)********************/
  563. void main()
  564. {        
  565.         P0 = P1 = P2 = P3 = 0xff;        //單片機(jī)IO口初始化為1
  566.         
  567.         LED=0;                                                // 指示燈點(diǎn)亮(自動(dòng)模式指示燈)
  568.         ret=Get_ADC0832();                    // 獲取AD采集結(jié)果(環(huán)境光照強(qiáng)度)
  569.         AutoControl(ret);                        // 上電先進(jìn)行一次自動(dòng)亮度控制        
  570.         AutoControl(ret+7);

  571.         delay_1ms(150);
  572.     Init_ultrasonic_wave();          //超聲波定時(shí)器初始化
  573.         init_time0();                 //初始化定時(shí)器
  574.         init_ds1302();                 //ds1302初始化
  575.         init_1602();                 //lcd1602初始化
  576.         init_1602_dis_csf(); //lcd1602初始化顯示
  577.         init_eeprom();       //開始初始化保存的數(shù)據(jù)
  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采集結(jié)果(環(huán)境光照強(qiáng)度)
  615.                                 AutoControl(ret);                        // 進(jìn)行自動(dòng)控制        
  616.                         }
  617.                 }
  618.                 delay_1ms(100);

  619.                 /*檢測(cè)是否有人*/
  620.                 if(Module==1)
  621.                 {
  622.                         gTime=0;                                                                // 檢測(cè)到有人,則把60秒計(jì)時(shí)清零
  623.                 }
  624.                 if(gTime>60000)                                                                // 如果gTime的值超過了60000
  625.                 {
  626.                         gTime=60000;                                                        // 則把gTime的值重新賦值為60000,避免過大溢出
  627.                         gIndex=0;                                                                // 如果1分鐘檢測(cè)不到有人,則把臺(tái)燈熄滅
  628.                 }


  629.                 if(flag_200ms == 1)
  630.                 {                                                
  631.                         flag_200ms = 0;
  632.                         if(menu_1 == 0)
  633.                         {
  634.                                 read_time();                  //讀時(shí)間
  635.                                 temperature = read_temp();        //先讀出溫度的值
  636.                                 init_1602_ds1302();   //顯示時(shí)鐘
  637.                         }
  638.                 }
  639.                 delay_1ms(1);

  640.                    StartModule();//啟動(dòng)超聲波
  641.                 while(!RX)          //當(dāng)RX為零時(shí)等待
  642.                 TR1=1;                  //開啟計(jì)數(shù)
  643.                 while(RX);          //當(dāng)RX為1計(jì)數(shù)并等待
  644.                 TR1=0;                  //關(guān)閉計(jì)數(shù)
  645.                 delay_1ms(20);
  646.                                 
  647.                 Conut(); //計(jì)算距離
  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. /**************定時(shí)器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清零,進(jìn)入新一輪的計(jì)數(shù)
  682.                 if(gIndex!=0)                                // 如果說臺(tái)燈不是最暗的(熄滅)
  683.                 {
  684.                         Lamp=0;                                                // 則把臺(tái)燈點(diǎn)亮
  685.                 }
  686.         }
  687.         if(gCount==gIndex)                // 如果gCount計(jì)數(shù)到和gIndex一樣了
  688.         {
  689.                 if(gIndex!=9)                                // 如果說臺(tái)燈不是最亮的
  690.                 {
  691.                         Lamp=1;                                                // 則把臺(tái)燈熄滅
  692.                 }
  693.         }

  694. }

  695. void time1() interrupt 3                  //T1中斷用來計(jì)數(shù)器溢出,超過測(cè)距范圍
  696. {
  697.         TH1=0;
  698.         TL1=0;
  699. }  
復(fù)制代碼
資料群(注明來自51黑)861514012
必備的單片機(jī)開發(fā)軟件和教程視頻我已上傳到群里,有需要的可以自行進(jìn)去下載

全部資料51hei下載地址:
仿真.rar (78.23 KB, 下載次數(shù): 317)
源程序.rar (74.89 KB, 下載次數(shù): 326)

評(píng)分

參與人數(shù) 1黑幣 +100 收起 理由
admin + 100 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

回復(fù)

使用道具 舉報(bào)

ID:331717 發(fā)表于 2023-12-7 11:35 | 顯示全部樓層
材料清單已上傳資料群中,需要請(qǐng)自行下載
回復(fù)

使用道具 舉報(bào)

ID:859243 發(fā)表于 2021-11-16 22:30 | 顯示全部樓層
External model DLL "ADC083X.DLL" not found. GLE=0x000036B1.
怎么辦啊
回復(fù)

使用道具 舉報(bào)

ID:331717 發(fā)表于 2021-11-25 09:35 | 顯示全部樓層
coutHello 發(fā)表于 2021-11-16 22:30
External model DLL "ADC083X.DLL" not found. GLE=0x000036B1.
怎么辦啊

你這個(gè)應(yīng)該是使用了高版本的Proteus軟件,可以換低版本的試下,或者使用老版本的 ADC083X.DLL 文件替換新版本中的 ADC083X.DLL 文件。
回復(fù)

使用道具 舉報(bào)

ID:967018 發(fā)表于 2021-12-2 15:36 | 顯示全部樓層
大佬具體的原理是什么啊,能講解一下嗎?求求了
回復(fù)

使用道具 舉報(bào)

ID:331717 發(fā)表于 2021-12-6 19:38 | 顯示全部樓層
NANS 發(fā)表于 2021-12-2 15:36
大佬具體的原理是什么啊,能講解一下嗎?求求了

原理主要是通過光敏電阻感應(yīng)外界光強(qiáng),根據(jù)外界光強(qiáng)值的大小來自動(dòng)調(diào)節(jié)臺(tái)燈亮度,亮度調(diào)節(jié)是利用單片機(jī)控制PWM的占空比,從而來改變電壓的大小實(shí)現(xiàn)燈光亮度的調(diào)節(jié)。然后其中又加入了手動(dòng)調(diào)節(jié)功能、人體感應(yīng)功能、時(shí)鐘顯示功能、坐姿矯正功能,具體功能實(shí)現(xiàn)的原理可以仔細(xì)閱讀下源程序,里面注釋挺全的。
回復(fù)

使用道具 舉報(bào)

ID:991822 發(fā)表于 2021-12-20 21:53 | 顯示全部樓層
求材料清單
回復(fù)

使用道具 舉報(bào)

ID:824490 發(fā)表于 2021-12-21 17:26 | 顯示全部樓層
按鍵有點(diǎn)多,如果能改成用EC11編碼器,瞬間上了好幾個(gè)檔次。。
回復(fù)

使用道具 舉報(bào)

ID:915590 發(fā)表于 2021-12-27 22:05 | 顯示全部樓層
這個(gè)超聲波模塊是什么型號(hào)的?
回復(fù)

使用道具 舉報(bào)

ID:998128 發(fā)表于 2021-12-29 19:13 | 顯示全部樓層

加一,蹲一個(gè)材料清單
回復(fù)

使用道具 舉報(bào)

ID:295874 發(fā)表于 2022-1-8 20:27 | 顯示全部樓層
這里的時(shí)鐘模塊顯示數(shù)據(jù)為何不正確?
回復(fù)

使用道具 舉報(bào)

ID:1000334 發(fā)表于 2022-1-13 08:44 | 顯示全部樓層
可否給一個(gè)材料清單
回復(fù)

使用道具 舉報(bào)

ID:952197 發(fā)表于 2022-1-13 10:56 | 顯示全部樓層
求材料清單
回復(fù)

使用道具 舉報(bào)

ID:81365 發(fā)表于 2022-1-14 23:54 | 顯示全部樓層
姿態(tài)矯正應(yīng)該自動(dòng)實(shí)現(xiàn)吧
回復(fù)

使用道具 舉報(bào)

ID:1032870 發(fā)表于 2022-6-7 13:46 | 顯示全部樓層
想請(qǐng)問下,為什么仿真運(yùn)行不了,這個(gè)如何解決?
出現(xiàn)的問題顯示“cannot open  xxx.SDF"
回復(fù)

使用道具 舉報(bào)

ID:1055161 發(fā)表于 2022-12-25 23:21 | 顯示全部樓層
為什么溫度顯示不了呢
回復(fù)

使用道具 舉報(bào)

ID:1061818 發(fā)表于 2023-1-30 20:14 | 顯示全部樓層
有數(shù)碼管的嗎?
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表