欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1708|回復: 0
打印 上一主題 下一主題
收起左側

本程序結合了24C02存儲器的存儲功能,可以掉電保存密碼作為學習分享

[復制鏈接]
跳轉到指定樓層
樓主
ID:1038970 發表于 2022-7-21 17:50 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. /*******************************************************************************
  2.                                         “天祥電子”        傾情奉獻
  3. ********************************************************************************
  4.                                                                 功能鍵
  5.                                                 S6---S15        數字鍵0-9
  6.                                 S16---更改密碼                S17---更改密碼完畢后確認
  7.                                 S18---重試密碼、重新設定        S19---關閉密碼鎖
  8.                                 初始密碼:000000         密碼位數:6位
  9.                                 注意:掉電后,所設密碼會丟失,重新上點時,密碼恢復為原始的000000
  10.                                 與P1相連的8位發光LED點亮代表鎖被打開;熄滅代表鎖被鎖上

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

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

  38. bit allow,genggai,ok,wanbi,retry,close;         //各個狀態位

  39. sbit dula=P2^6;
  40. sbit wela=P2^7;
  41. sbit beep=P2^3;
  42. sbit sda=P2^0;                          //IO口定義
  43. sbit scl=P2^1;

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

  47. /*****************IIC芯片24C02存儲器驅動程序************************************/

  48. void nop()
  49. {
  50.         _nop_();
  51.         _nop_();
  52. }
  53. /////////24C02讀寫驅動程序////////////////////
  54. void delay1(unsigned int m)
  55. {        unsigned int n;
  56.           for(n=0;n<m;n++);
  57. }

  58. void init()  //24c02初始化子程序
  59. {
  60.         scl=1;
  61.         nop();
  62.         sda=1;
  63.         nop();
  64. }

  65. void start()        //啟動I2C總線
  66. {
  67.         sda=1;
  68.         nop();
  69.         scl=1;
  70.         nop();
  71.         sda=0;
  72.         nop();
  73.         scl=0;
  74.         nop();
  75. }

  76. void stop()         //停止I2C總線
  77. {
  78.         sda=0;
  79.         nop();
  80.         scl=1;
  81.         nop();
  82.         sda=1;
  83.         nop();
  84. }

  85. void writebyte(unsigned char j)  //寫一個字節
  86. {
  87.         unsigned char i,temp;
  88.            temp=j;
  89.            for (i=0;i<8;i++)
  90.    {
  91.            temp=temp<<1;
  92.            scl=0;
  93.            nop();
  94.            sda=CY;                //temp左移時,移出的值放入了CY中
  95.            nop();
  96.            scl=1;                //待sda線上的數據穩定后,將scl拉高
  97.            nop();
  98.    }
  99.    scl=0;
  100.    nop();
  101.    sda=1;
  102.    nop();
  103. }

  104. unsigned char readbyte()   //讀一個字節
  105. {
  106.    unsigned char i,j,k=0;
  107.    scl=0; nop(); sda=1;
  108.    for (i=0;i<8;i++)
  109.    {  
  110.                 nop(); scl=1; nop();
  111.               if(sda==1)
  112.                 j=1;
  113.               else
  114.                 j=0;
  115.               k=(k<<1)|j;
  116.                   scl=0;
  117.         }
  118.            nop();
  119.         return(k);
  120. }

  121. void clock()         //I2C總線時鐘
  122. {
  123.    unsigned char i=0;
  124.    scl=1;
  125.    nop();
  126.    while((sda==1)&&(i<255))
  127.              i++;
  128.    scl=0;
  129.    nop();
  130. }

  131. ////////從24c02的地址address中讀取一個字節數據/////
  132. unsigned char read24c02(unsigned char address)
  133. {
  134.    unsigned char i;
  135.    start();
  136.    writebyte(0xa0);
  137.    clock();
  138.    writebyte(address);
  139.    clock();
  140.    start();
  141.    writebyte(0xa1);
  142.    clock();
  143.    i=readbyte();
  144.    stop();
  145.    delay1(100);
  146.    return(i);
  147. }

  148. //////向24c02的address地址中寫入一字節數據info/////
  149. void write24c02(unsigned char address,unsigned char info)
  150. {
  151.    start();
  152.    writebyte(0xa0);
  153.    clock();
  154.    writebyte(address);
  155.    clock();
  156.    writebyte(info);
  157.    clock();
  158.    stop();
  159.    delay1(5000); //這個延時一定要足夠長,否則會出錯。因為24c02在從sda上取得數據后,還需要一定時間的燒錄過程。
  160. }
  161. /****************************密碼鎖程序模塊********************************************************/

  162. void delay(unsigned char i)
  163. {
  164.         uchar j,k;
  165.   for(j=i;j>0;j--)
  166.     for(k=125;k>0;k--);
  167. }

  168. void display(uchar a,uchar b,uchar c,uchar d,uchar e,uchar f)
  169. {
  170.    dula=0;
  171.    P0=table[a];
  172.    dula=1;
  173.    dula=0;
  174.    
  175.    wela=0;
  176.    P0=0xfe;
  177.    wela=1;
  178.    wela=0;
  179.    delay(5);
  180.    
  181.    P0=table[b];
  182.    dula=1;
  183.    dula=0;
  184.    
  185.    P0=0xfd;
  186.    wela=1;
  187.    wela=0;
  188.    delay(5);

  189.    P0=table[c];
  190.    dula=1;
  191.    dula=0;
  192.    
  193.    P0=0xfb;
  194.    wela=1;
  195.    wela=0;
  196.    delay(5);
  197.    
  198.    P0=table[d];
  199.    dula=1;
  200.    dula=0;
  201.    
  202.    P0=0xf7;
  203.    wela=1;
  204.    wela=0;
  205.    delay(5);
  206.    
  207.    P0=table[e];
  208.    dula=1;
  209.    dula=0;
  210.    
  211.    P0=0xef;
  212.    wela=1;
  213.    wela=0;
  214.    delay(5);
  215.    
  216.    P0=table[f];
  217.    dula=1;
  218.    dula=0;
  219.    
  220.    P0=0xdf;
  221.    wela=1;
  222.    wela=0;
  223.    delay(5);
  224. }


  225. void keyscan()
  226. {
  227.   {       
  228.     P3=0xfe;
  229.     temp=P3;
  230.     temp=temp&0xf0;
  231.     if(temp!=0xf0)
  232.     {
  233.       delay(10);
  234.       if(temp!=0xf0)
  235.       {       
  236.         temp=P3;
  237.         switch(temp)
  238.         {
  239.           case 0xee:
  240.                key=0;
  241.                            wei++;
  242.                break;

  243.           case 0xde:
  244.                key=1;
  245.                            wei++;
  246.                break;

  247.           case 0xbe:
  248.                key=2;
  249.                            wei++;
  250.                break;

  251.           case 0x7e:
  252.                key=3;
  253.                            wei++;
  254.                break;
  255.          }
  256.          while(temp!=0xf0)
  257.         {
  258.            temp=P3;
  259.            temp=temp&0xf0;
  260.            beep=0;
  261.          }
  262.          beep=1;
  263.       }
  264.     }
  265.     P3=0xfd;
  266.     temp=P3;
  267.     temp=temp&0xf0;
  268.     if(temp!=0xf0)
  269.     {
  270.       delay(10);
  271.       if(temp!=0xf0)
  272.       {
  273.         temp=P3;
  274.         switch(temp)
  275.         {
  276.           case 0xed:
  277.                key=4;
  278.                            wei++;
  279.                break;

  280.           case 0xdd:
  281.                key=5;
  282.                            wei++;
  283.                break;

  284.           case 0xbd:
  285.                key=6;
  286.                            wei++;
  287.                break;

  288.           case 0x7d:
  289.                key=7;
  290.                            wei++;
  291.                break;
  292.          }
  293.          while(temp!=0xf0)
  294.          {
  295.            temp=P3;
  296.            temp=temp&0xf0;
  297.            beep=0;
  298.          }
  299.          beep=1;
  300.       }
  301.       }
  302.     P3=0xfb;
  303.     temp=P3;
  304.     temp=temp&0xf0;
  305.     if(temp!=0xf0)
  306.     {
  307.       delay(10);
  308.       if(temp!=0xf0)
  309.       {
  310.         temp=P3;
  311.         switch(temp)
  312.         {
  313.           case 0xeb:
  314.                key=8;
  315.                            wei++;
  316.                break;

  317.           case 0xdb:
  318.                key=9;
  319.                            wei++;
  320.                break;
  321.                           
  322.           case 0xbb:
  323.                genggai=1;
  324.                            wei=0;
  325.                break;

  326.           case 0x7b:
  327.                              if(allow)
  328.                ok=1;
  329.                break;
  330.          }
  331.         while(temp!=0xf0)
  332.          {
  333.            temp=P3;
  334.            temp=temp&0xf0;
  335.            beep=0;
  336.          }
  337.          beep=1;
  338.       }
  339.       }
  340.           P3=0xf7;
  341.     temp=P3;
  342.     temp=temp&0xf0;
  343.     if(temp!=0xf0)
  344.     {
  345.       delay(10);
  346.       if(temp!=0xf0)
  347.       {
  348.         temp=P3;
  349.         switch(temp)
  350.         {
  351.           case 0xe7:
  352.                              retry=1;
  353.                break;

  354.           case 0xd7:
  355.                              close=1;
  356.                break;
  357.          }
  358.         while(temp!=0xf0)
  359.          {
  360.            temp=P3;
  361.            temp=temp&0xf0;
  362.            beep=0;
  363.          }
  364.          beep=1;
  365.       }
  366.       }
  367. }
  368. }

  369. void shumima()                //對按鍵采集來的數據進行分配
  370. {
  371.         if(!wanbi)
  372.         {
  373.         switch(wei)
  374.         {
  375.                 case 1:new1=key;
  376.                             if(!allow)        a=17;
  377.                            else a=key;        break;
  378.                 case 2:new2=key;
  379.                                 if(a==17) b=17;
  380.                                 else b=key;        break;
  381.                 case 3:new3=key;
  382.                                 if(a==17) c=17;
  383.                                 else c=key;        break;
  384.                 case 4:new4=key;
  385.                                 if(a==17) d=17;
  386.                                 else d=key;        break;
  387.                 case 5:new5=key;
  388.                                 if(a==17) e=17;
  389.                                 else e=key;        break;
  390.                 case 6:new6=key;
  391.                                 if(a==17) f=17;
  392.                                 else f=key;
  393.                                 wanbi=1;        break;
  394.         }
  395.         }
  396. }

  397. void yanzheng()          //驗證密碼是否正確
  398. {
  399.         if(wanbi)         //只有當六位密碼均輸入完畢后方進行驗證
  400.         {
  401.         if((new1==old1)&(new2==old2)&(new3==old3)&(new4==old4)&(new5==old5)&(new6==old6))
  402.                 allow=1;        //當輸入的密碼正確,會得到allowe置一
  403.         }
  404. }

  405. void main()
  406. {
  407.        
  408.         init();        //初始化24C02
  409. /*********下面的一小段程序的功能為格式化密碼存儲區。************
  410. ******當24c02中這些存儲區由于其他程序的運行而導致***************
  411. *******所存數據發生了變化,或者密碼遺忘時,        ********************
  412. ******可以刪掉其前面的注釋線,然后重新編譯下載。****************
  413. ******而將密碼還原為000000后,請將下面的程序用******************
  414. ******注釋屏蔽掉,重新編譯、下載,方可正常使用****************/
  415. //        write24c02(110,0x00);
  416. //        write24c02(111,0x00);//24c02的第110到115地址單元作為密碼存儲區
  417. //        write24c02(112,0x00);
  418. //        write24c02(113,0x00);
  419. //        write24c02(114,0x00);
  420. //        write24c02(115,0x00);
  421. /*******************************************************************/


  422.         old1=read24c02(110);  
  423.         old2=read24c02(111);
  424.         old3=read24c02(112);
  425.         old4=read24c02(113);
  426.         old5=read24c02(114);
  427.         old6=read24c02(115);

  428.         while(1)
  429.         {
  430.                 keyscan();
  431.                 shumima();
  432.                 yanzheng();
  433.                 if(allow)         //驗證完后,若allow為1,則開鎖
  434.                 {
  435.                         P1=0x00;
  436.                         if(!genggai)
  437.                                 wanbi=0;
  438.                 }
  439.                 if(genggai)          //當S16更改密碼鍵被按下,genggai會被置一
  440.                 {
  441.                         if(allow)         //若已經把鎖打開,才有更改密碼的權限
  442.                         {
  443.                                 while(!wanbi)        //當新的六位密碼沒有設定完,則一直在這里循環
  444.                                 {
  445.                                          keyscan();
  446.                                         shumima();
  447.                                         if(retry|close)         //而當探測到重試鍵S18或者關閉密碼鎖鍵S19被按下時,則跳出
  448.                                         {        wanbi=1;
  449.                                                 break;
  450.                                         }
  451.                                         display(a,b,c,d,e,f);
  452.                                 }
  453.                         }
  454.                 }
  455.                 if(ok)          //更改密碼時,當所有六位新密碼均被按下時,可以按下此鍵,結束密碼更改
  456.                 {                  //其他時間按下此鍵無效
  457.                         ok=0; wei=0;
  458.                         genggai=0;
  459.                         old1=new1;old2=new2;old3=new3; //此時,舊的密碼將被代替
  460.                         old4=new4;old5=new5;old6=new6;
  461.                         //新密碼寫入存儲區。
  462.                         write24c02(110,old1);
  463.                         write24c02(111,old2);
  464.                         write24c02(112,old3);
  465.                         write24c02(113,old4);
  466.                         write24c02(114,old5);
  467.                         write24c02(115,old6);
  468.                         a=16;b=16;c=16;d=16;e=16;f=16;
  469.                 }
  470.                 if(retry)        //當重試按鍵S18被按下,retry會被置位
  471.                 {
  472.                 retry=0; wei=0;wanbi=0;
  473.                 a=16;b=16;c=16;d=16;e=16;f=16;
  474.                 new1=0;new2=0;new3=0;new4=0;new5=0;new6=0;               
  475.                 }
  476.                 if(close)  //當關閉密碼鎖按鍵被按下,close會被置位
  477.                 {
  478.                         close=0;genggai=0;//所有變量均被清零。
  479.                         wei=0;        wanbi=0;
  480.                         allow=0;
  481.                         P1=0xff;
  482.                         a=16;b=16;c=16;d=16;e=16;f=16;
  483.                         new1=0;new2=0;new3=0;new4=0;new5=0;new6=0;
  484.                 }
  485.                 display(a,b,c,d,e,f); //實時顯示
  486.         }
  487. }
復制代碼


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

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

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表