密碼鎖仿真.jpg (728.07 KB, 下載次數: 67)
下載附件
密碼鎖仿真
2018-6-21 12:49 上傳
密碼鎖仿真使用說明
一、 配鑰匙: 1、 打開仿真,把門鎖.hex和鑰匙.hex下載到相應單片機里,單片機晶振都統一設置為12MHz,運行仿真,可以看到門鎖的指示燈和鑰匙的指示燈都為熄滅狀態。此時門鎖為等待開門狀態,兩把鑰匙為沒有注入開門密碼狀態。 2、 點擊、閉合1號開關(按按鍵右邊的小紅色箭頭),點擊一下1號鑰匙KEY2,此時可以看到1號鑰匙藍燈點亮,為等待注入數據狀態。 3、 點擊一下門鎖KEY1鍵,可以看到門鎖藍燈點亮,此時為即將注入數據狀態(也是刪除鑰匙的前一步,下面細說,跳過)。 4、 點擊一下門鎖KEY2鍵,可以看到1號鑰匙藍燈熄滅,黃燈點亮。此狀態表示數據注入成功。點擊、斷開1號開關,點擊一下門鎖KEY3鍵,門鎖指示燈全部熄滅,此時門鎖回到等待開門狀態。點擊一下1號鑰匙KEY1,此時可以看到1號鑰匙綠燈點亮、黃燈熄滅。此時為鑰匙已經注入開門密碼狀態。 5、 當配第二把鑰匙時,重復以上過程即可,只是要把對1號開關、按鍵的操作改為2號開關、按鍵。(配鑰匙時,開關只能同時閉合一個) 二、 開門: 1、將注入過數據的1號鑰匙(綠燈點亮)的開關點擊、閉合。此時即可看到門鎖綠燈點亮,表示門鎖被打開。此時可以點擊、打開1號開關,點擊一下門鎖KEY4鍵,門鎖綠燈熄滅,門鎖重新回到閉合狀態,等待開門。 三、 刪除鑰匙 1、1號、2號開關為斷開狀態,此時點擊一下門鎖KEY1鍵,可以看到門鎖藍燈點亮, 此時點擊一下門鎖KEY4鍵,即刪除了第一把所配的鑰匙,門鎖所有燈熄滅,回到等待開門狀態。(重復此動作,即可一次刪除第二把、第三把鑰匙。) 2、此后,點擊、閉合1號開關(剛才已經注入過數據的那把鑰匙),可以看到門鎖紅燈點亮,蜂鳴器長叫,表示有人用已經刪除的鑰匙開門,報警。此時,若斷開1號開關,再點擊一下門鎖KEY4鍵,報警解除,門鎖又回到等待開門狀態。
注意:1、仿真不同于實物,操作數據無法關閉后無法保存,所以以上演示過程,仿真要一直運行,關閉仿真后等于重新開始。 2、若配過鑰匙后,,斷開開關按門鎖復位鍵,可以恢復以前刪除的所有鑰匙。 3、同理,點擊一下鑰匙的復位鍵,也可以清楚已經注入的數據。 4、點擊按鍵時,可以放大仿真窗口,方便操作。 5、門鎖綠燈點亮,即為開門。 門鎖程序: - #include<reg51.h>
- #define SL 60//同步信號低電平時間設定
- #define SH 60//同步信號高電平時間設定
- #define DH 15//數據信號高電平時間設定
- #define DL 2 //數據信號低電平時間松瓚?
- #define SLM 110//同步信號低電平最大時間設定
- #define SHM 110//同步信號高電平最大時間設定
- #define DHM 30//數據信號高電平最大時間設定
- #define DLM 13//數據信號低電平最大時間設定
- #define SL_F 140//同步信號低電平時間設定
- #define SH_F 140//同步信號高電平時間設定
- #define DH_F 80//數據信號高電平時間設定
- #define DL_F 30 //數據信號低電平時間設定
- sbit P10=P1^0;//輸入端口
- sbit P11=P1^1;//輸出端口
- sbit LED_G=P3^0;
- sbit LED_R=P3^1;
- sbit LED_Y=P3^2;
- sbit LED_B=P3^3;
- sbit sound=P2^0;
- sbit key_1=P0^0;
- sbit key_2=P0^1;
- sbit key_3=P0^2;
- sbit key_4=P0^3;
- unsigned char data_1,data_2,data_3,data_4;
- unsigned int e=0;
- unsigned char t=0;
- unsigned char h=0;
- unsigned char d=0;
- unsigned char c=0;
- bit flag_1=0;
- bit flag_2=0;
- bit flag_3=0;
- bit flag_4=0;
- void GET_DATA(void)//提取信息
- {
- for (h=0;h<8;h++)
- {
- d<<=0x01;
- t=0;
- while(!P10);
- while(P10&&t<DHM)//高電平計數
- t++;
- if (t>DL&&t<DLM)//時間在100us左右為 數據0
- d|=0x00;
- else
- if (t>DH&&t<DHM)//時間在200us左右為 數據1
- d|=0x01;
- else
- return ;//在高電平計數超過時,則認為錯誤,退出
- }
- data_1=d;
- for (h=0;h<8;h++)
- {
- c<<=0x01;
- t=0;
- while(!P10);
- while(P10&&t<DHM)//高電平計數
- t++;
- if (t>DL&&t<DLM)//時間在100us左右為 數據0
- c|=0x00;
- else
- if (t>DH&&t<DHM)//時間在200us左右為 數據1
- c|=0x01;
- else
- return ;//在高電平計數超過時,則認為錯誤,退出
- }
- data_2=c;
- }
- void SEND_SYN(void)//發送同步位
- {
- unsigned int k=0;
- P10=0;
- while(k<100)//每次發送一組數據前加入低電平,具體值看測試, 發現數據間間隔加大可以使錯誤率減小,通訊速率加快
- k++;
- P10=1;//同步位高電平
- k=0;
- while(k<SL_F)//高電平1MS左右
- k++;
- P10=0;//同步位低電平
- k=0;
- while(k<SH_F)//低電平1MS左右
- k++;
- }
- void SEND_DATA(unsigned char a,unsigned char b)//數據位發送
- {
- unsigned char i;
- unsigned char j;
- SEND_SYN();
- for (i=0;i<8;i++)//發送8位數據
- {
- if (a&0x80)//從高位開始發送
- {
- P10=1;//如果是1則發送高電平200us
- j=0;
- while(j<DH_F)
- j++;
- P10=0;
- j=0;
- while(j<DL_F)//發送低電平100us
- j++;
- }
- else
- {
- P10=1;//如果是0則發送高電平100us
- j=0;
- while(j<DL_F)
- j++;
- P10=0;
- j=0;
- while(j<DL_F)//發送低電平100us
- j++;
- }
- a<<=0x01;
- }
- for (i=0;i<8;i++)//發送8位數據
- {
- if (b&0x80)//從高位開始發送
- {
- P10=1;//如果是1則發送高電平200us
- j=0;
- while(j<DH_F)
- j++;
- P10=0;
- j=0;
- while(j<DL_F)//發送低電平100us
- j++;
- }
- else
- {
- P10=1;//如果是0則發送高電平100us
- j=0;
- while(j<DL_F)
- j++;
- P10=0;
- j=0;
- while(j<DL_F)//發送低電平100us
- j++;
- }
- b<<=0x01;
- }
- }
- 鑰匙程序:
- #include<reg51.h>
- #define SL 60//同步信號低電平時間設定
- #define SH 60//同步信號高電平時間設定
- #define DH 15//數據信號高電平時間設定
- #define DL 2 //數據信號低電平時間松瓚?
- #define SLM 110//同步信號低電平最大時間設定
- #define SHM 110//同步信號高電平最大時間設定
- #define DHM 30//數據信號高電平最大時間設定
- #define DLM 13//數據信號低電平最大時間設定
- #define SL_F 140//同步信號低電平時間設定
- #define SH_F 140//同步信號高電平時間設定
- #define DH_F 80//數據信號高電平時間設定
- #define DL_F 30 //數據信號低電平時間松瓚?
- sbit key_1=P0^7;
- sbit key_2=P0^6;
- sbit LED_G=P3^2;
- sbit LED_Y=P3^1;
- sbit LED_B=P3^0;
- sbit P10=P1^0;//output pin
- sbit P11=P1^1;//input pin
- unsigned char data_1,data_2;
- unsigned int e=0;
- unsigned char t=0;
- unsigned char h=0;
- unsigned char d=0;
- unsigned char c=0;
- bit flag_1=0;
- bit flag_2=0;
- unsigned char addr_self[3]={0x35,0x52};
- const unsigned char CRC_TABLE[16]={0x00,0x31,0x62,0x53,0xC4,0xF5,0xA6,0x97,
- 0xB9,0x88,0xDB,0xEA,0x7D,0x4C,0x1F,0x2E};
- /****************************************/
- /*功能:CRC_8校驗 */
- /*入口:待校驗的數據指針和數據長度 */
- /****************************************/
- void CalculateCRC8(unsigned char *PData,unsigned char Len) //CRC校驗子程序
- {
- unsigned char Temp,CRC;
- CRC=0;
- while(Len--)
- {
- Temp=CRC>>4;
- CRC<<=4;
- CRC^=CRC_TABLE[Temp^(*PData>>4)];
- Temp=CRC>>4;
- CRC<<=4;
- CRC^=CRC_TABLE[Temp^(*PData&0x0F)];
- PData++;
- }
- }
- void GET_DATA(void)//提取信息
- {
- for (h=0;h<8;h++)
- {
- d<<=0x01;
- t=0;
- while(!P10);
- while(P10&&t<DHM)//高電平計數
- t++;
- if (t>DL&&t<DLM)//時間在100us左右為 數據0
- d|=0x00;
- else
- if (t>DH&&t<DHM)//時間在200us左右為 數據1
- d|=0x01;
- else
- return ;//在高電平計數超過時,則認為錯誤,退出
- }
- data_1=d;
- for (h=0;h<8;h++)
- {
- c<<=0x01;
- t=0;
- while(!P10);
- while(P10&&t<DHM)//高電平計數
- t++;
- if (t>DL&&t<DLM)//時間在100us左右為 數據0
- c|=0x00;
- else
- if (t>DH&&t<DHM)//時間在200us左右為 數據1
- c|=0x01;
- else
- return ;//在高電平計數超過時,則認為錯誤,退出
- }
- data_2=c;
- CalculateCRC8(addr_self,2); //CRC校驗
- }
- void SEND_SYN(void)//發送同步位
- {
- unsigned int k=0;
- P10=0;
- while(k<100)//每次發送一組數據前加入低電平,具體值看測試, 發現數據間間隔加大可以使錯誤率減小,通訊速率加快
- k++;
- P10=1;//同步位高電平
- k=0;
- while(k<SL_F)//高電平1MS左右
- k++;
- P10=0;//同步位低電平
- k=0;
- while(k<SH_F)//低電平1MS左右
- k++;
- }
- void SEND_DATA(unsigned char a,unsigned char b)//數據位發送
- {
- unsigned char i;
- unsigned char j;
- CalculateCRC8(addr_self,2); //CRC校驗
- SEND_SYN();
- for (i=0;i<8;i++)//發送8位數據
- {
- if (a&0x80)//從高位開始發送
- {
- P10=1;//如果是1則發送高電平200us
- j=0;
- while(j<DH_F)
- j++;
- P10=0;
- j=0;
- while(j<DL_F)//發送低電平100us
- j++;
- }
- else
- {
- P10=1;//如果是0則發送高電平100us
- j=0;
- while(j<DL_F)
- j++;
- P10=0;
- j=0;
- while(j<DL_F)//發送低電平100us
- j++;
- }
- a<<=0x01;
- }
- for (i=0;i<8;i++)//發送8位數據
- {
- if (b&0x80)//從高位開始發送
- {
- P10=1;//如果是1則發送高電平200us
- j=0;
- while(j<DH_F)
- j++;
- P10=0;
- j=0;
- while(j<DL_F)//發送低電平100us
- j++;
- }
- else
- {
- P10=1;//如果是0則發送高電平100us
- j=0;
- while(j<DL_F)
- j++;
- P10=0;
- j=0;
- while(j<DL_F)//發送低電平100us
- j++;
- }
- b<<=0x01;
- }
- }
- void main(void)
- {
- key_1=1;
- key_2=1;
- LED_G=0;
- LED_Y=0;
- LED_B=0;
- while(1)
- {
- if(flag_1==0&&flag_2==0)
- {
- if(data_2==0xab)
- LED_G=1;
- else
- LED_G=0;
- SEND_DATA(data_1,data_2);
- P10=1;
- }
- if(key_2==0)
- {
- while(key_2==0);
- flag_1=1;
- LED_B=1;
- LED_G=0;
-
- }
- if(key_1==0&&flag_2==1)
- {
- while(key_1==0);
-
- LED_Y=0;
- flag_2=0;
- }
- if(flag_1==1)
- {
- while(!P10);
- e=0;
- while(P10&&(e<SHM))//對高電平計數
- e++;
- if ((e>SH)&&(e<SHM))// 如果時間為1000us左右則進行低電平檢測
- {
- e=0;
- while(!P10&&(e<SHM))//對低電平計數
- e++;
-
- if ((e>SL)&&(e<SHM))//如果低電平時間為1000us左右則認為同步位正確,接收數據
- {
-
- GET_DATA();
- if(data_2==0xaa)
- {
- LED_Y=1;
- LED_B=0;
- flag_1=0;
- flag_2=1;
- data_2=data_2+1;
- }
- }
- }
- }
- }
- }
- void main(void)
- {
- LED_G=0;
- LED_R=0;
- LED_Y=0;
- LED_B=0;
- while(1)
- {
- if(flag_1==0)
- { while(!P10)
- e=0;
- while(P10&&(e<SHM))//對高電平計數
- e++;
- if ((e>SH)&&(e<SHM))// 如果時間為1000us左右則進行低電平檢測
- {
- e=0;
- while(!P10&&(e<SHM))//對低電平計數
- e++;
-
- if ((e>SL)&&(e<SHM))//如果低電平時間為1000us左右則認為同步位正確,接收數據
- {
-
- GET_DATA();
- if(data_1>data_4&&data_2==0xab)
- {
- LED_G=1;
- LED_R=0;
- }
- if(data_1<=data_4&&data_2==0xab)
- {
- LED_G=0;
- LED_R=1;
- flag_4=1;
- }
-
- }
- }
- }
- if(flag_4==1)
- sound=~sound;
- if(key_1==0&&flag_1==0)
- {
- LED_B=1;
- while(key_1==0);
- flag_1=1;
- LED_G=0;
- LED_R=0;
- flag_4=0;
- sound=0;
- }
- if(key_2==0&&flag_1&&flag_2==0)
- {
- LED_Y=1;
- while(key_1==0);
- LED_Y=0;
- data_3++;
- SEND_DATA(data_3,0xaa);
- P10=1;
-
- flag_2=1;
- }
- if(key_3==0&&flag_1)
- {
- LED_B=1;
- while(key_1==0);
- LED_B=0;
- LED_G=0;
- LED_Y=0;
- flag_1=0;
- flag_2=0;
- }
- if(key_4==0&&flag_1&&flag_2==0)
- {
- while(key_4==0);
- data_4++;
- LED_B=0;
- LED_G=0;
- LED_Y=0;
- flag_1=0;
- flag_2=0;
- }
- if(key_4==0&&flag_1==0&&flag_2==0)
- {
- LED_R=0;
- LED_B=0;
- LED_G=0;
- LED_Y=0;
- flag_4=0;
- sound=0;
- }
- }
- }
復制代碼
全部資料51hei下載地址:
密碼鎖仿真所有資料.zip
(77.32 KB, 下載次數: 22)
2018-6-21 12:59 上傳
點擊文件名下載附件
密碼鎖仿真所有資料 下載積分: 黑幣 -5
|