找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机密码锁仿真-我的课程设计

[复制链接]
跳转到指定楼层
楼主

密码锁仿真使用说明

一、 配钥匙:
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键,门锁绿灯熄灭,门锁重新回到闭合状态,等待开门。
三、 删除钥匙
11号、2号开关为断开状态,此时点击一下门锁KEY1键,可以看到门锁蓝灯点亮,
此时点击一下门锁KEY4键,即删除了第一把所配的钥匙,门锁所有灯熄灭,回到等待开门状态。(重复此动作,即可一次删除第二把、第三把钥匙。)
2、此后,点击、闭合1号开关(刚才已经注入过数据的那把钥匙),可以看到门锁红灯点亮,蜂鸣器长叫,表示有人用已经删除的钥匙开门,报警。此时,若断开1号开关,再点击一下门锁KEY4键,报警解除,门锁又回到等待开门状态。

注意:1、仿真不同于实物,操作数据无法关闭后无法保存,所以以上演示过程,仿真要一直运行,关闭仿真后等于重新开始。
2、若配过钥匙后,,断开开关按门锁复位键,可以恢复以前删除的所有钥匙。
3、同理,点击一下钥匙的复位键,也可以清楚已经注入的数据。
4、点击按键时,可以放大仿真窗口,方便操作。
      5、门锁绿灯点亮,即为开门。
门锁程序:
  1. #include<reg51.h>
  2. #define SL 60//同步信号低电平时间设定
  3. #define SH 60//同步信号高电平时间设定
  4. #define DH 15//数据信号高电平时间设定
  5. #define DL 2 //数据信号低电平时间松瓒?
  6. #define SLM 110//同步信号低电平最大时间设定
  7. #define SHM 110//同步信号高电平最大时间设定
  8. #define DHM 30//数据信号高电平最大时间设定
  9. #define DLM 13//数据信号低电平最大时间设定
  10. #define SL_F 140//同步信号低电平时间设定
  11. #define SH_F 140//同步信号高电平时间设定
  12. #define DH_F 80//数据信号高电平时间设定
  13. #define DL_F 30 //数据信号低电平时间设定
  14. sbit P10=P1^0;//输入端口
  15. sbit P11=P1^1;//输出端口
  16. sbit LED_G=P3^0;
  17. sbit LED_R=P3^1;
  18. sbit LED_Y=P3^2;
  19. sbit LED_B=P3^3;
  20. sbit sound=P2^0;
  21. sbit key_1=P0^0;
  22. sbit key_2=P0^1;
  23. sbit key_3=P0^2;
  24. sbit key_4=P0^3;
  25. unsigned char data_1,data_2,data_3,data_4;
  26. unsigned int e=0;
  27. unsigned char t=0;
  28. unsigned char h=0;
  29. unsigned char d=0;
  30. unsigned char c=0;
  31. bit                flag_1=0;
  32. bit                flag_2=0;
  33. bit                flag_3=0;
  34. bit                flag_4=0;
  35. void GET_DATA(void)//提取信息
  36. {

  37. for (h=0;h<8;h++)
  38. {
  39.    d<<=0x01;
  40.    t=0;

  41.    while(!P10);
  42.    while(P10&&t<DHM)//高电平计数
  43.     t++;
  44.    if (t>DL&&t<DLM)//时间在100us左右为 数据0
  45.     d|=0x00;
  46.    else
  47.     if (t>DH&&t<DHM)//时间在200us左右为 数据1
  48.      d|=0x01;
  49.     else
  50.      return ;//在高电平计数超过时,则认为错误,退出  
  51. }
  52. data_1=d;

  53. for (h=0;h<8;h++)
  54. {
  55.    c<<=0x01;
  56.    t=0;

  57.    while(!P10);
  58.    while(P10&&t<DHM)//高电平计数
  59.     t++;
  60.    if (t>DL&&t<DLM)//时间在100us左右为 数据0
  61.     c|=0x00;
  62.    else
  63.     if (t>DH&&t<DHM)//时间在200us左右为 数据1
  64.      c|=0x01;
  65.     else
  66.      return ;//在高电平计数超过时,则认为错误,退出  
  67. }
  68. data_2=c;
  69. }


  70. void SEND_SYN(void)//发送同步位
  71. {
  72. unsigned int k=0;
  73. P10=0;
  74. while(k<100)//每次发送一组数据前加入低电平,具体值看测试, 发现数据间间隔加大可以使错误率减小,通讯速率加快
  75.    k++;

  76. P10=1;//同步位高电平
  77. k=0;
  78. while(k<SL_F)//高电平1MS左右
  79.    k++;

  80. P10=0;//同步位低电平
  81. k=0;
  82. while(k<SH_F)//低电平1MS左右
  83.    k++;   
  84. }

  85. void SEND_DATA(unsigned char a,unsigned char b)//数据位发送
  86. {
  87. unsigned char i;
  88. unsigned char j;

  89. SEND_SYN();
  90. for (i=0;i<8;i++)//发送8位数据
  91. {
  92.    if (a&0x80)//从高位开始发送
  93.    {
  94.     P10=1;//如果是1则发送高电平200us
  95.     j=0;
  96.     while(j<DH_F)
  97.      j++;
  98.     P10=0;
  99.     j=0;
  100.     while(j<DL_F)//发送低电平100us
  101.      j++;
  102.    }
  103.    else
  104.    {
  105.     P10=1;//如果是0则发送高电平100us
  106.     j=0;
  107.     while(j<DL_F)
  108.      j++;
  109.     P10=0;
  110.     j=0;
  111.     while(j<DL_F)//发送低电平100us
  112.      j++;
  113.    }
  114.    a<<=0x01;
  115. }
  116. for (i=0;i<8;i++)//发送8位数据
  117. {
  118.    if (b&0x80)//从高位开始发送
  119.    {
  120.     P10=1;//如果是1则发送高电平200us
  121.     j=0;
  122.     while(j<DH_F)
  123.      j++;
  124.     P10=0;
  125.     j=0;
  126.     while(j<DL_F)//发送低电平100us
  127.      j++;
  128.    }
  129.    else
  130.    {
  131.     P10=1;//如果是0则发送高电平100us
  132.     j=0;
  133.     while(j<DL_F)
  134.      j++;
  135.     P10=0;
  136.     j=0;
  137.     while(j<DL_F)//发送低电平100us
  138.      j++;
  139.    }
  140.    b<<=0x01;
  141. }   
  142. }
  143. 钥匙程序:
  144. #include<reg51.h>

  145. #define SL 60//同步信号低电平时间设定
  146. #define SH 60//同步信号高电平时间设定
  147. #define DH 15//数据信号高电平时间设定
  148. #define DL 2 //数据信号低电平时间松瓒?
  149. #define SLM 110//同步信号低电平最大时间设定
  150. #define SHM 110//同步信号高电平最大时间设定
  151. #define DHM 30//数据信号高电平最大时间设定
  152. #define DLM 13//数据信号低电平最大时间设定

  153. #define SL_F 140//同步信号低电平时间设定
  154. #define SH_F 140//同步信号高电平时间设定
  155. #define DH_F 80//数据信号高电平时间设定
  156. #define DL_F 30 //数据信号低电平时间松瓒?

  157. sbit key_1=P0^7;
  158. sbit key_2=P0^6;
  159. sbit LED_G=P3^2;
  160. sbit LED_Y=P3^1;
  161. sbit LED_B=P3^0;

  162. sbit P10=P1^0;//output pin
  163. sbit P11=P1^1;//input pin

  164. unsigned char data_1,data_2;
  165. unsigned int e=0;
  166. unsigned char t=0;
  167. unsigned char h=0;
  168. unsigned char d=0;
  169. unsigned char c=0;

  170. bit                flag_1=0;
  171. bit                flag_2=0;
  172. unsigned char addr_self[3]={0x35,0x52};        
  173. const unsigned  char CRC_TABLE[16]={0x00,0x31,0x62,0x53,0xC4,0xF5,0xA6,0x97,
  174.                                                               0xB9,0x88,0xDB,0xEA,0x7D,0x4C,0x1F,0x2E};
  175. /****************************************/
  176. /*功能:CRC_8校验                                                */
  177. /*入口:待校验的数据指针和数据长度            */
  178. /****************************************/
  179. void CalculateCRC8(unsigned char *PData,unsigned char Len)         //CRC校验子程序
  180. {
  181.          unsigned char Temp,CRC;
  182.         CRC=0;
  183.         while(Len--)
  184.         {
  185.                 Temp=CRC>>4;
  186.                 CRC<<=4;
  187.                 CRC^=CRC_TABLE[Temp^(*PData>>4)];

  188.                 Temp=CRC>>4;
  189.                 CRC<<=4;
  190.                 CRC^=CRC_TABLE[Temp^(*PData&0x0F)];
  191.                 PData++;
  192.         }
  193. }



  194. void GET_DATA(void)//提取信息
  195. {


  196. for (h=0;h<8;h++)
  197. {
  198.    d<<=0x01;
  199.    t=0;

  200.    while(!P10);
  201.    while(P10&&t<DHM)//高电平计数
  202.     t++;
  203.    if (t>DL&&t<DLM)//时间在100us左右为 数据0
  204.     d|=0x00;
  205.    else
  206.     if (t>DH&&t<DHM)//时间在200us左右为 数据1
  207.      d|=0x01;
  208.     else
  209.      return ;//在高电平计数超过时,则认为错误,退出  
  210. }
  211. data_1=d;

  212. for (h=0;h<8;h++)
  213. {
  214.    c<<=0x01;
  215.    t=0;

  216.    while(!P10);
  217.    while(P10&&t<DHM)//高电平计数
  218.     t++;
  219.    if (t>DL&&t<DLM)//时间在100us左右为 数据0
  220.     c|=0x00;
  221.    else
  222.     if (t>DH&&t<DHM)//时间在200us左右为 数据1
  223.      c|=0x01;
  224.     else
  225.      return ;//在高电平计数超过时,则认为错误,退出  
  226. }
  227. data_2=c;
  228. CalculateCRC8(addr_self,2);         //CRC校验
  229. }


  230. void SEND_SYN(void)//发送同步位
  231. {
  232. unsigned int k=0;
  233. P10=0;
  234. while(k<100)//每次发送一组数据前加入低电平,具体值看测试, 发现数据间间隔加大可以使错误率减小,通讯速率加快
  235.    k++;

  236. P10=1;//同步位高电平
  237. k=0;
  238. while(k<SL_F)//高电平1MS左右
  239.    k++;

  240. P10=0;//同步位低电平
  241. k=0;
  242. while(k<SH_F)//低电平1MS左右
  243.    k++;   
  244. }

  245. void SEND_DATA(unsigned char a,unsigned char b)//数据位发送
  246. {
  247. unsigned char i;
  248. unsigned char j;
  249. CalculateCRC8(addr_self,2);         //CRC校验
  250. SEND_SYN();
  251. for (i=0;i<8;i++)//发送8位数据
  252. {
  253.    if (a&0x80)//从高位开始发送
  254.    {
  255.     P10=1;//如果是1则发送高电平200us
  256.     j=0;
  257.     while(j<DH_F)
  258.      j++;
  259.     P10=0;
  260.     j=0;
  261.     while(j<DL_F)//发送低电平100us
  262.      j++;
  263.    }
  264.    else
  265.    {
  266.     P10=1;//如果是0则发送高电平100us
  267.     j=0;
  268.     while(j<DL_F)
  269.      j++;
  270.     P10=0;
  271.     j=0;
  272.     while(j<DL_F)//发送低电平100us
  273.      j++;
  274.    }
  275.    a<<=0x01;
  276. }
  277. for (i=0;i<8;i++)//发送8位数据
  278. {
  279.    if (b&0x80)//从高位开始发送
  280.    {
  281.     P10=1;//如果是1则发送高电平200us
  282.     j=0;
  283.     while(j<DH_F)
  284.      j++;
  285.     P10=0;
  286.     j=0;
  287.     while(j<DL_F)//发送低电平100us
  288.      j++;
  289.    }
  290.    else
  291.    {
  292.     P10=1;//如果是0则发送高电平100us
  293.     j=0;
  294.     while(j<DL_F)
  295.      j++;
  296.     P10=0;
  297.     j=0;
  298.     while(j<DL_F)//发送低电平100us
  299.      j++;
  300.    }
  301.    b<<=0x01;
  302. }

  303. }
  304. void main(void)
  305. {

  306. key_1=1;
  307. key_2=1;
  308. LED_G=0;
  309. LED_Y=0;
  310. LED_B=0;

  311. while(1)
  312. {
  313.         if(flag_1==0&&flag_2==0)
  314.         {
  315.                 if(data_2==0xab)
  316.                 LED_G=1;
  317.                 else
  318.                 LED_G=0;

  319.             SEND_DATA(data_1,data_2);
  320.                 P10=1;
  321.     }



  322.                   if(key_2==0)
  323.         {
  324.                 while(key_2==0);
  325.                  flag_1=1;
  326.                   LED_B=1;
  327.                   LED_G=0;
  328.         
  329.     }
  330.         if(key_1==0&&flag_2==1)
  331.         {
  332.                 while(key_1==0);
  333.                  
  334.                   LED_Y=0;
  335.                   flag_2=0;
  336.     }
  337.         if(flag_1==1)

  338.         {
  339.                 while(!P10);                 
  340.                  e=0;
  341.                  while(P10&&(e<SHM))//对高电平计数
  342.                  e++;        
  343.                  if ((e>SH)&&(e<SHM))// 如果时间为1000us左右则进行低电平检测
  344.                  {  
  345.                     e=0;
  346.                     while(!P10&&(e<SHM))//对低电平计数
  347.                     e++;
  348.         
  349.             if ((e>SL)&&(e<SHM))//如果低电平时间为1000us左右则认为同步位正确,接收数据
  350.             {
  351.         
  352.              GET_DATA();
  353.                  if(data_2==0xaa)
  354.                  {
  355.                          LED_Y=1;
  356.                    LED_B=0;
  357.                    flag_1=0;
  358.                    flag_2=1;
  359.                    data_2=data_2+1;

  360.                   }

  361.             }
  362.           }

  363.          }
  364. }
  365. }
  366. void main(void)
  367. {

  368.         LED_G=0;
  369.         LED_R=0;
  370.         LED_Y=0;
  371.         LED_B=0;

  372.         while(1)
  373.         {
  374.                   if(flag_1==0)
  375.                   { while(!P10)

  376.                     e=0;
  377.                    while(P10&&(e<SHM))//对高电平计数
  378.              e++;        
  379.              if ((e>SH)&&(e<SHM))// 如果时间为1000us左右则进行低电平检测
  380.              {  
  381.                     e=0;
  382.                     while(!P10&&(e<SHM))//对低电平计数
  383.                      e++;
  384.         
  385.                     if ((e>SL)&&(e<SHM))//如果低电平时间为1000us左右则认为同步位正确,接收数据
  386.                     {
  387.         
  388.                      GET_DATA();
  389.                          if(data_1>data_4&&data_2==0xab)
  390.                           {
  391.                                 LED_G=1;
  392.                                    LED_R=0;
  393.                         }
  394.                          if(data_1<=data_4&&data_2==0xab)
  395.                           {
  396.                                 LED_G=0;
  397.                                    LED_R=1;
  398.                                 flag_4=1;

  399.                         }
  400.         
  401.                     }
  402.                    }
  403.                  }
  404.                    if(flag_4==1)
  405.                    sound=~sound;




  406.                          if(key_1==0&&flag_1==0)
  407.                         {
  408.                         LED_B=1;
  409.                         while(key_1==0);                        
  410.                         flag_1=1;
  411.                         LED_G=0;
  412.                         LED_R=0;
  413.                         flag_4=0;
  414.                         sound=0;
  415.                     }


  416.                          if(key_2==0&&flag_1&&flag_2==0)
  417.                         {

  418.                         LED_Y=1;
  419.                         while(key_1==0);                        
  420.                         LED_Y=0;
  421.                         data_3++;
  422.                     SEND_DATA(data_3,0xaa);
  423.                         P10=1;
  424.                         
  425.                         flag_2=1;

  426.                     }
  427.                         if(key_3==0&&flag_1)
  428.                         {
  429.                         LED_B=1;
  430.                         while(key_1==0);
  431.                         LED_B=0;
  432.                         LED_G=0;
  433.                         LED_Y=0;                        
  434.                         flag_1=0;
  435.                         flag_2=0;
  436.                     }
  437.                         if(key_4==0&&flag_1&&flag_2==0)
  438.                         {                        
  439.                          while(key_4==0);
  440.                          data_4++;
  441.                         LED_B=0;
  442.                         LED_G=0;
  443.                         LED_Y=0;                        
  444.                         flag_1=0;
  445.                         flag_2=0;
  446.                         }
  447.                         if(key_4==0&&flag_1==0&&flag_2==0)
  448.                         {
  449.                                 LED_R=0;
  450.                                 LED_B=0;
  451.                                 LED_G=0;
  452.                                 LED_Y=0;
  453.                                 flag_4=0;
  454.                                 sound=0;                        
  455.                         }






  456.         }
  457. }
复制代码



全部资料51hei下载地址:
密码锁仿真所有资料.zip (77.32 KB, 下载次数: 22)

评分

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

查看全部评分

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

使用道具 举报

沙发
ID:1 发表于 2018-7-1 02:15 | 只看该作者
好资料,51黑有你更精彩!!!
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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