久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機(jī)密碼鎖(掉電可記憶)源程序

[復(fù)制鏈接]
ID:263893 發(fā)表于 2017-12-19 20:27 | 顯示全部樓層 |閱讀模式
單片機(jī)源程序如下:
  1.                                                         

  2. 程序功能: 本程序結(jié)合了24C02存儲器的存儲功能,可以掉電保存密碼。
  3.                         第一次運(yùn)行時(shí),若輸入000000原始密碼后無反應(yīng),可以試驗(yàn)著將主程序中前面的
  4.                         一小段被注釋線屏蔽的程序前的注釋線刪掉,然后重新編譯下載(可以將密碼還原為000000)。
  5.                         此后,再將這小段程序屏蔽掉,再編譯下載。方可正常使用。
  6.                    1、開鎖:
  7.                   下載程序后,直接按六次S1(即代表數(shù)字1),8位LED亮,鎖被打開,輸入密碼時(shí),
  8.                   六位數(shù)碼管依次顯示小橫杠。
  9.                   2、更改密碼:
  10.                   只有當(dāng)開鎖(LED亮)后,該功能方可使用。
  11.                   首先按下更改密碼鍵S11,然后設(shè)置相應(yīng)密碼,此時(shí)六位數(shù)碼管會(huì)顯示設(shè)置密碼對應(yīng)
  12.                   的數(shù)字。最后設(shè)置完六位后,按下S12確認(rèn)密碼更改,此后新密碼即生效。
  13.                   3、重試密碼:
  14.                   當(dāng)輸入密碼時(shí),密碼輸錯(cuò)后按下鍵S13,可重新輸入六位密碼。
  15.                   當(dāng)設(shè)置密碼時(shí),設(shè)置中途想更改密碼,也可按下此鍵重新設(shè)置。
  16.                   4、關(guān)閉密碼鎖:
  17.                   按下S14即可將打開的密碼鎖關(guān)閉。
  18. 推薦初級演示步驟:輸入原始密碼000000---按下更改密碼按鍵S11---按0到9設(shè)置密碼---按S12
  19.                         確認(rèn)密碼更改---按S14關(guān)閉密碼鎖---輸入新的密碼打開密碼鎖
  20. *******************************************************************************/
  21. #include<reg52.h>
  22. #include <intrins.h>
  23. #define uint unsigned int
  24. #define uchar unsigned char

  25. uchar old1,old2,old3,old4,old5,old6; //原始密碼000000
  26. uchar new1,new2,new3,new4,new5,new6;  //每次MCU采集到的密碼輸入
  27. uchar a=16,b=16,c=16,d=16,e=16,f=16; //送入數(shù)碼管顯示的變量
  28. uchar wei,key,temp;

  29. bit allow,genggai,ok,wanbi,retry,close;         //各個(gè)狀態(tài)位

  30. sbit dula=P2^6;
  31. sbit wela=P2^7;
  32. sbit beep=P2^3;
  33. sbit sda=P2^0;                          //IO口定義
  34. sbit scl=P2^1;

  35. unsigned char code table[]=
  36. {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,
  37. 0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00,0x40};

  38. /*****************IIC芯片24C02存儲器驅(qū)動(dòng)程序************************************/

  39. void nop()
  40. {
  41.         _nop_();
  42.         _nop_();
  43. }
  44. /////////24C02讀寫驅(qū)動(dòng)程序////////////////////
  45. void delay1(unsigned int m)
  46. {        unsigned int n;
  47.           for(n=0;n<m;n++);
  48. }

  49. void init()  //24c02初始化子程序
  50. {
  51.         scl=1;
  52.         nop();
  53.         sda=1;
  54.         nop();
  55. }

  56. void start()        //啟動(dòng)I2C總線
  57. {
  58.         sda=1;
  59.         nop();
  60.         scl=1;
  61.         nop();
  62.         sda=0;
  63.         nop();
  64.         scl=0;
  65.         nop();
  66. }

  67. void stop()         //停止I2C總線
  68. {
  69.         sda=0;
  70.         nop();
  71.         scl=1;
  72.         nop();
  73.         sda=1;
  74.         nop();
  75. }

  76. void writebyte(unsigned char j)  //寫一個(gè)字節(jié)
  77. {
  78.         unsigned char i,temp;
  79.            temp=j;
  80.            for (i=0;i<8;i++)
  81.    {
  82.            temp=temp<<1;
  83.            scl=0;
  84.            nop();
  85.            sda=CY;                //temp左移時(shí),移出的值放入了CY中
  86.            nop();
  87.            scl=1;                //待sda線上的數(shù)據(jù)穩(wěn)定后,將scl拉高
  88.            nop();
  89.    }
  90.    scl=0;
  91.    nop();
  92.    sda=1;
  93.    nop();
  94. }

  95. unsigned char readbyte()   //讀一個(gè)字節(jié)
  96. {
  97.    unsigned char i,j,k=0;
  98.    scl=0; nop(); sda=1;
  99.    for (i=0;i<8;i++)
  100.    {  
  101.                 nop(); scl=1; nop();
  102.               if(sda==1)
  103.                 j=1;
  104.               else
  105.                 j=0;
  106.               k=(k<<1)|j;
  107.                   scl=0;
  108.         }
  109.            nop();
  110.         return(k);
  111. }

  112. void clock()         //I2C總線時(shí)鐘
  113. {
  114.    unsigned char i=0;
  115.    scl=1;
  116.    nop();
  117.    while((sda==1)&&(i<255))
  118.              i++;
  119.    scl=0;
  120.    nop();
  121. }

  122. ////////從24c02的地址address中讀取一個(gè)字節(jié)數(shù)據(jù)/////
  123. unsigned char read24c02(unsigned char address)
  124. {
  125.    unsigned char i;
  126.    start();
  127.    writebyte(0xa0);
  128.    clock();
  129.    writebyte(address);
  130.    clock();
  131.    start();
  132.    writebyte(0xa1);
  133.    clock();
  134.    i=readbyte();
  135.    stop();
  136.    delay1(100);
  137.    return(i);
  138. }

  139. //////向24c02的address地址中寫入一字節(jié)數(shù)據(jù)info/////
  140. void write24c02(unsigned char address,unsigned char info)
  141. {
  142.    start();
  143.    writebyte(0xa0);
  144.    clock();
  145.    writebyte(address);
  146.    clock();
  147.    writebyte(info);
  148.    clock();
  149.    stop();
  150.    delay1(5000); //這個(gè)延時(shí)一定要足夠長,否則會(huì)出錯(cuò)。因?yàn)?4c02在從sda上取得數(shù)據(jù)后,還需要一定時(shí)間的燒錄過程。
  151. }
  152. /****************************密碼鎖程序模塊********************************************************/

  153. void delay(unsigned char i)
  154. {
  155.         uchar j,k;
  156.   for(j=i;j>0;j--)
  157.     for(k=125;k>0;k--);
  158. }

  159. void display(uchar a,uchar b,uchar c,uchar d,uchar e,uchar f)
  160. {
  161.    dula=0;
  162.    P0=table[a];
  163.    dula=1;
  164.    dula=0;

  165.    wela=0;
  166.    P0=0xfe;
  167.    wela=1;
  168.    wela=0;
  169.    delay(5);

  170.    P0=table[b];
  171.    dula=1;
  172.    dula=0;

  173.    P0=0xfd;
  174.    wela=1;
  175.    wela=0;
  176.    delay(5);

  177.    P0=table[c];
  178.    dula=1;
  179.    dula=0;

  180.    P0=0xfb;
  181.    wela=1;
  182.    wela=0;
  183.    delay(5);

  184.    P0=table[d];
  185.    dula=1;
  186.    dula=0;

  187.    P0=0xf7;
  188.    wela=1;
  189.    wela=0;
  190.    delay(5);

  191.    P0=table[e];
  192.    dula=1;
  193.    dula=0;

  194.    P0=0xef;
  195.    wela=1;
  196.    wela=0;
  197.    delay(5);

  198.    P0=table[f];
  199.    dula=1;
  200.    dula=0;

  201.    P0=0xdf;
  202.    wela=1;
  203.    wela=0;
  204.    delay(5);
  205. }


  206. void keyscan()
  207. {
  208.   {        
  209.     P3=0xfe;
  210.     temp=P3;
  211.     temp=temp&0xf0;
  212.     if(temp!=0xf0)
  213.     {
  214.       delay(10);
  215.       if(temp!=0xf0)
  216.       {        
  217.         temp=P3;
  218.         switch(temp)
  219.         {
  220.           case 0xee:
  221.                key=0;
  222.                            wei++;
  223.                break;

  224.           case 0xde:
  225.                key=1;
  226.                            wei++;
  227.                break;

  228.           case 0xbe:
  229.                key=2;
  230.                            wei++;
  231.                break;

  232.           case 0x7e:
  233.                key=3;
  234.                            wei++;
  235.                break;
  236.          }
  237.          while(temp!=0xf0)
  238.         {
  239.            temp=P3;
  240.            temp=temp&0xf0;
  241.            beep=0;
  242.          }
  243.          beep=1;
  244.       }
  245.     }
  246.     P3=0xfd;
  247.     temp=P3;
  248.     temp=temp&0xf0;
  249.     if(temp!=0xf0)
  250.     {
  251.       delay(10);
  252.       if(temp!=0xf0)
  253.       {
  254.         temp=P3;
  255.         switch(temp)
  256.         {
  257.           case 0xed:
  258.                key=4;
  259.                            wei++;
  260.                break;

  261.           case 0xdd:
  262.                key=5;
  263.                            wei++;
  264.                break;

  265.           case 0xbd:
  266.                key=6;
  267.                            wei++;
  268.                break;

  269.           case 0x7d:
  270.                key=7;
  271.                            wei++;
  272.                break;
  273.          }
  274.          while(temp!=0xf0)
  275.          {
  276.            temp=P3;
  277.            temp=temp&0xf0;
  278.            beep=0;
  279.          }
  280.          beep=1;
  281.       }
  282.       }
  283.     P3=0xfb;
  284.     temp=P3;
  285.     temp=temp&0xf0;
  286.     if(temp!=0xf0)
  287.     {
  288.       delay(10);
  289.       if(temp!=0xf0)
  290.       {
  291.         temp=P3;
  292.         switch(temp)
  293.         {
  294.           case 0xeb:
  295.                key=8;
  296.                            wei++;
  297.                break;

  298.           case 0xdb:
  299.                key=9;
  300.                            wei++;
  301.                break;
  302.                            
  303.           case 0xbb:
  304.                genggai=1;
  305.                            wei=0;
  306.                break;

  307.           case 0x7b:
  308.                              if(allow)
  309.                ok=1;
  310.                break;
  311.          }
  312.         while(temp!=0xf0)
  313.          {
  314.            temp=P3;
  315.            temp=temp&0xf0;
  316.            beep=0;
  317.          }
  318.          beep=1;
  319.       }
  320.       }
  321.           P3=0xf7;
  322.     temp=P3;
  323.     temp=temp&0xf0;
  324.     if(temp!=0xf0)
  325.     {
  326.       delay(10);
  327.       if(temp!=0xf0)
  328.       {
  329.         temp=P3;
  330.         switch(temp)
  331.         {
  332.           case 0xe7:
  333.                              retry=1;
  334.                break;

  335.           case 0xd7:
  336.                              close=1;
  337.                break;
  338.          }
  339.         while(temp!=0xf0)
  340.          {
  341.            temp=P3;
  342.            temp=temp&0xf0;
  343.            beep=0;
  344.          }
  345.          beep=1;
  346.       }
  347.       }
  348. }
  349. }

  350. void shumima()                //對按鍵采集來的數(shù)據(jù)進(jìn)行分配
  351. {
  352.         if(!wanbi)
  353.         {
  354.         switch(wei)
  355.         {
  356.                 case 1:new1=key;
  357.                             if(!allow)        a=17;
  358.                            else a=key;        break;
  359.                 case 2:new2=key;
  360.                                 if(a==17) b=17;
  361.                                 else b=key;        break;
  362.                 case 3:new3=key;
  363.                                 if(a==17) c=17;
  364.                                 else c=key;        break;
  365.                 case 4:new4=key;
  366.                                 if(a==17) d=17;
  367.                                 else d=key;        break;
  368.                 case 5:new5=key;
  369.                                 if(a==17) e=17;
  370.                                 else e=key;        break;
  371.                 case 6:new6=key;
  372.                                 if(a==17) f=17;
  373.                                 else f=key;
  374.                                 wanbi=1;        break;
  375.         }
  376.         }
  377. }

  378. void yanzheng()          //驗(yàn)證密碼是否正確
  379. {
  380.         if(wanbi)         //只有當(dāng)六位密碼均輸入完畢后方進(jìn)行驗(yàn)證
  381.         {
  382.         if((new1==old1)&(new2==old2)&(new3==old3)&(new4==old4)&(new5==old5)&(new6==old6))
  383.                 allow=1;        //當(dāng)輸入的密碼正確,會(huì)得到allowe置一
  384.         }
  385. }

  386. void main()
  387. {
  388.         
  389.         init();        //初始化24C02
  390. /*********下面的一小段程序的功能為格式化密碼存儲區(qū)。************
  391. ******當(dāng)24c02中這些存儲區(qū)由于其他程序的運(yùn)行而導(dǎo)致***************
  392. *******所存數(shù)據(jù)發(fā)生了變化,或者密碼遺忘時(shí),        ********************
  393. ******可以刪掉其前面的注釋線,然后重新編譯下載。****************
  394. ******而將密碼還原為000000后,請將下面的程序用******************
  395. ******注釋屏蔽掉,重新編譯、下載,方可正常使用****************/
  396. //        write24c02(110,0x00);
  397. //        write24c02(111,0x00);//24c02的第110到115地址單元作為密碼存儲區(qū)
  398. //        write24c02(112,0x00);
  399. //        write24c02(113,0x00);
  400. //        write24c02(114,0x00);
  401. //        write24c02(115,0x00);
  402. /*******************************************************************/


  403.         old1=read24c02(110);  
  404.         old2=read24c02(111);
  405.         old3=read24c02(112);
  406.         old4=read24c02(113);
  407.         old5=read24c02(114);
  408.         old6=read24c02(115);

  409.         while(1)
  410.         {
  411.                 keyscan();
  412.                 shumima();
  413.                 yanzheng();
  414.                 if(allow)         //驗(yàn)證完后,若allow為1,則開鎖
  415.                 {
  416.                         P1=0x00;
  417.                         if(!genggai)
  418.                                 wanbi=0;
  419.                 }
  420.                 if(genggai)          //當(dāng)S16更改密碼鍵被按下,genggai會(huì)被置一
  421.                 {
  422.                         if(allow)         //若已經(jīng)把鎖打開,才有更改密碼的權(quán)限
  423.                         {
  424.                                 while(!wanbi)        //當(dāng)新的六位密碼沒有設(shè)定完,則一直在這里循環(huán)
  425.                                 {
  426.                                          keyscan();
  427.                                         shumima();
  428.                                         if(retry|close)         //而當(dāng)探測到重試鍵S18或者關(guān)閉密碼鎖鍵S19被按下時(shí),則跳出
  429.                                         {        wanbi=1;
  430.                                                 break;
  431.                                         }
  432.                                         display(a,b,c,d,e,f);
  433.                                 }
  434.                         }
  435.                 }
  436.                 if(ok)          //更改密碼時(shí),當(dāng)所有六位新密碼均被按下時(shí),可以按下此鍵,結(jié)束密碼更改
  437.                 {                  //其他時(shí)間按下此鍵無效
  438.                         ok=0; wei=0;
  439.                         genggai=0;
  440.                         old1=new1;old2=new2;old3=new3; //此時(shí),舊的密碼將被代替
  441.                         old4=new4;old5=new5;old6=new6;
  442.                         //新密碼寫入存儲區(qū)。
  443.                         write24c02(110,old1);
  444.                         write24c02(111,old2);
  445.                         write24c02(112,old3);
  446.                         write24c02(113,old4);
  447.                         write24c02(114,old5);
  448.                         write24c02(115,old6);
  449.                         a=16;b=16;c=16;d=16;e=16;f=16;
  450.                 }
  451.                 if(retry)        //當(dāng)重試按鍵S18被按下,retry會(huì)被置位
  452.                 {
  453.                 retry=0; wei=0;wanbi=0;
  454.                 a=16;b=16;c=16;d=16;e=16;f=16;
  455.                 new1=0;new2=0;new3=0;new4=0;new5=0;new6=0;               
  456.                 }
  457.                 if(close)  //當(dāng)關(guān)閉密碼鎖按鍵被按下,close會(huì)被置位
  458.                 {
  459.                         close=0;genggai=0;//所有變量均被清零。
  460.                         wei=0;        wanbi=0;
  461.                         allow=0;
  462.                         P1=0xff;
  463.                         a=16;b=16;c=16;d=16;e=16;f=16;
  464.                         new1=0;new2=0;new3=0;new4=0;new5=0;new6=0;
  465.                 }
  466.                 display(a,b,c,d,e,f); //實(shí)時(shí)顯示
  467.         }
  468. }

復(fù)制代碼

回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 天天干com | 亚洲iv一区二区三区 | 黄色欧美 | 国产乱码精品一区二区三区五月婷 | 国产精品视频久久久久 | 亚洲成av人影片在线观看 | 国产成人精品综合 | 欧美区日韩区 | 成人免费观看男女羞羞视频 | 精品国产一区二区三区久久 | 一级毛片免费视频 | 亚洲第一黄色网 | 九九福利 | 日韩成人高清在线 | 欧美日韩亚洲二区 | 毛片一级黄色 | 国产三级国产精品 | 久久一级免费视频 | 成人午夜电影在线观看 | 国产中文原创 | 国产玖玖| 国产在线区 | 久久久久亚洲国产| 欧美黑人一区 | 国产精品久久国产精品99 gif | 91欧美激情一区二区三区成人 | 国内久久 | 夜夜骑首页 | 日韩精品免费在线观看 | 在线观看中文字幕 | 中文字幕中文字幕 | 欧美成人自拍 | 欧美啪啪| 日本午夜在线视频 | 男女污污动态图 | 天堂资源 | 日本免费在线观看视频 | 五月精品视频 | 亚洲一区中文字幕在线观看 | 久久久久国产精品午夜一区 | 91人人看|