找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 7992|回复: 5
收起左侧

51单片机电梯控制系统软硬件设计 附Proteus仿真程序

  [复制链接]
ID:704132 发表于 2020-3-15 09:34 | 显示全部楼层 |阅读模式

系统总体方案及硬件设计

电梯系统的升降的方案

为了更有效的进行电梯控制,现在使用最左边的数码管表示电梯上升和下降状态,使用另外一个一个数码管表示电梯此时所在的楼层,使用按键来控制电梯上升或者下降的状态。在每层楼之后需要进行判断上升或者下降。如果是在上升过程中,应先判断是否继续上升,然后在判断是否下降。如果是在下降过程中,应先判断是否继续下降,在判断是否上升。在上升改变为下降状态时,或者下降改变为上升状态时。数码管的状态应该相应改变


总体硬件设计

2.3按键系统设计

运用单片机的按键模拟电梯的楼层按键系统,可以在由一楼上升到八楼过程中,按下下降按键则可以改变上升状态变为下降状态。然后在八楼到一楼的下降过程中,按下上升按键则可以改变下降状态为上升状态。在任意楼层按下上升或者下降按键,都可以产生相应的上升或者下降的状态,如下图所示

2.4电梯所在楼层显示系统

运用8x8点阵数码管来模拟电梯的所在的楼层的显示和升降效果,8x8点阵数码管如下图所示

2.5电梯的显示灯和警报系统

运用延迟函数来实现到达层楼后接通P3.7接口来实现电梯的显示灯和警报,如下图所示

第3章 软件系统设计

3.1设计思路及关键技术

一个完整的电梯控制系统相当于一个简单的单片机系统,该系统是首判断有无按键按下,有按键按下后判断所在按键的楼层然后对按键的所在的楼层与电梯的所在的楼层作比较,然后判断电梯的升降问题,然后运用延时函数来延时电梯门开启的时间和电梯显示灯的时间,如果没有按键按下,电梯则不动处于原来的楼层,从而实现节省电力的效果。

3.2 软件流程

3.3 电梯智能控制系统的设计程序说明

这部分中定义了一些全局变量的数组和变量以及位标志,只是些定义的东西不需要画流程图了。这部分程序如下:

判断按键有无按键按下:


  1. unsigned int keyscan(void)//扫描功能:键盘扫描
  2. {
  3.               if(P1 != 0xff)
  4.               {
  5.                             switch(P1)
  6.                             {
  7.                                           case 0x7f:{return(8);break;}
  8.                                           case 0xbf:{return(7);break;}
  9.                                           case 0xdf:{return(6);break;}
  10.                                           case 0xef:{return(5);break;}
  11.                                           case 0xf7:{return(4);break;}
  12.                                           case 0xfb:{return(3);break;}
  13.                                           case 0xfd:{return(2);break;}
  14.                                           case 0xfe:{return(1);break;}
  15.                                           default:return(0);
  16.                             }
  17.               }
  18. }
  19. 判断按键没按下的时候处于等待的状态:
  20. void show(unsigned int i)//函数功能:电梯静止,并等待键盘
  21. {
  22.               uint k;
  23.               while(P1 != 0xff);
  24.               while(P1 == 0xff)
  25.               {
  26.                             for(k = 0;k < 8;k++)
  27.                             {
  28.                                           P0 = scan[k];
  29.                                           P2 = zm[(i * 8 + k)];
  30.                                           delay(1);
  31.                             }
  32.               }
  33. }
  34. 用延时函数来延长电梯的开门的时间:
  35. void delay(uint t)//延时函数
  36. {
  37.               uchar a;
  38.               while(t--)
  39.               for(a = 0;a < 122;a++);
  40. }
复制代码


第4章Proteus软件仿真

4.1 Proteus软件仿真

Proteus软件用于系统的仿真,编译软件采用keil UV3。程序的仿真用英国的labcenter公司的Protens V7.13。其果如下:加电后的结果如图此时电梯初始位置在0层

4.2 电梯上升到2楼的切换仿真

4.3 电梯下降到1楼的切换仿真


第五章 心得体会
经过调试之后,使用单片机来模拟电梯的运行过程的是可行的,但是由于我选用的是方案一,模型比较简单,功能也较为单一。仅能上下升降而不可以选择任意的楼层停止。
改进的话就应该如同方案二一样,设计多个按键就可以对不同楼层进行操作。但是由于自身水平有限,对于该段操作流程理解的逻辑流程还是有点些乱,编写的程序也无法使用,所以在接下来的学习中,应该根据自身的对于单片机掌握的情况对单片机进行一些有针对性的学习。因为51单片机确实比较基础,仅有8位IO口,比较容易掌握。难的是自己的逻辑思维能力和C语言应用能力,能讲模型转化为程序编辑出来。在参考资料的过程中,有很多想法也设计了很多程序但是这些程序都有着很多的缺陷仅能完成自己想做的部分功能。
还有需要改进的地方就是编写的时候很多可以用宏定义定义的常数都没有用宏定义去定义参数。
总的来说,这段时间对于程序的编写和对于方案的设计有一定程度的提升自身的水平。

  1. #include <reg51.h>
  2. #include <intrins.h>
  3. #define uchar unsigned char
  4. #define uint unsigned int
  5. sbit p36 = P3^6;//p36接通P3.6接口
  6. sbit p37 = P3^7; //p37接通P3.7接口
  7. void delay(uint t);//定义全局变量
  8. uint terminal;
  9. uint outset = 0;
  10. uint flag = 0;
  11. uint flag1 = 0;
  12. uint flag2 = 0;

  13. uchar code scan[] = {0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//扫描代码
  14. //以下为显示"0,1,2,3,4,5,6,7,8"的8x8点阵代码
  15. uchar code zm[] = {
  16. 0x00,0x18,0x24,0x24,0x24,0x24,0x18,0x00,0x00,0x10,0x1c,0x10,0x10,0x10,0x3c,0x00,0x00,0x38,0x44,
  17. 0x40,0x20,0x10,0x7c,0x00,0x00,0x38,0x44,0x30,0x40,0x44,0x38,0x00,0x00,0x20,0x30,0x28,0x24,0x7e,
  18. 0x20,0x00,0x00,0x7c,0x04,0x3c,0x40,0x40,0x3c,0x00,0x00,0x38,0x44,0x3c,0x44,0x44,0x38,0x00,0x00,
  19. 0x7e,0x40,0x40,0x20,0x10,0x10,0x00,0x00,0x38,0x44,0x38,0x44,0x44,0x38,0x00};
  20. //以下函数功能:提示楼层到,蜂鸣器发声及LED闪亮
  21. void soundandled(uint j)
  22. {
  23.               uint i,k;
  24.               P0 = 0xff;
  25.               P2 = 0xff;
  26.               for(i = 0;i < 20;i++)
  27.               {
  28.                             p36 = 0;
  29.                             delay(10);
  30.                             p36 = 1;
  31.                             for(k = 0;k < 8;k++)
  32.                             {
  33.                                           P0 = scan[k];
  34.                                           P2 = zm[j * 8 + k];
  35.                                           p37 = 1;
  36.                                           delay(5);
  37.                                           p37 = 0;
  38.                             }
  39.               }
  40. }
  41. unsigned int keyscan(void)//扫描功能:键盘扫描
  42. {
  43.               if(P1 != 0xff)
  44.               {
  45.                             switch(P1)
  46.                             {
  47.                                           case 0x7f:{return(8);break;}
  48.                                           case 0xbf:{return(7);break;}
  49.                                           case 0xdf:{return(6);break;}
  50.                                           case 0xef:{return(5);break;}
  51.                                           case 0xf7:{return(4);break;}
  52.                                           case 0xfb:{return(3);break;}
  53.                                           case 0xfd:{return(2);break;}
  54.                                           case 0xfe:{return(1);break;}
  55.                                           default:return(0);
  56.                             }
  57.               }
  58. }
  59. void downmove(uint m,uint n)//函数功能:电梯下行
  60. {
  61.               uint k,j,i;
  62.               for(k = m * 8;k > n * 8;k--)
  63.               {
  64.                             for(j = 0;j < 30;j++)
  65.                             {
  66.                                           for(i = 7;(i >= 0) && (i < 8);i--)
  67.                                           {
  68.                                                         if(P1!= 0xff)
  69.                                                         {
  70.                                                                       outset = keyscan();
  71.                                                                       if((outset > n)&&(outset < m))
  72.                                                                       {
  73.                                                                                     flag1 = outset;
  74.                                                                                     outset = n;
  75.                                                                                     n = flag1;
  76.                                                                                     terminal = n;
  77.                                                                       }while(P1 != 0xff);
  78.                                                         }//在最里面循环中加判别,可增加按键灵敏度,如果不加则只能运行完所有循环才能进入下一步
  79.                                                         P0 = scan[i];
  80.                                                         P2 = zm[(i + k) % 72];
  81.                                                         delay(1);
  82.                                           }
  83.                             }
  84.               }
  85. }
  86. //以下函数功能:电梯上行
  87. void upmove(unsigned int m,unsigned int n)
  88. {
  89.               uint i,j,k;
  90.               for(k = m * 8;k < n * 8;k++)
  91.               {            
  92.                             for(j = 0;j < 30;j++)
  93.                             {
  94.                                           for(i = 0;i < 8;i++)
  95.                                           {
  96.                                                         if(P1 != 0xff)
  97.                                                         {
  98.                                                                       outset = keyscan();
  99.                                                                       if((outset > m)&&(outset < n))
  100.                                                                       {
  101.                                                                                     flag1 = outset;
  102.                                                                                     outset = n;
  103.                                                                                     n = flag1;
  104.                                                                                     terminal = n;
  105.                                                                       }
  106.                                                                       while(P1 != 0xff);
  107.                                                         }
  108.                                                         P0 = scan[i];
  109.                                                         P2 = zm[(i + k)%72];
  110.                                                         delay(1);
  111.                                           }
  112.                             }
  113.               }
  114. }
  115. void show(unsigned int i)//函数功能:电梯静止,并等待键盘
  116. {
  117.               uint k;
  118.               while(P1 != 0xff);
  119.               while(P1 == 0xff)
  120.               {
  121.                             for(k = 0;k < 8;k++)
  122.                             {
  123.                                           P0 = scan[k];
  124.                                           P2 = zm[(i * 8 + k)];
  125.                                           delay(1);
  126.                             }
  127.               }
  128. }
  129. void main()//主程序
  130. {
  131.               p37 = 0;
  132.               P2 = 0xff;
  133.               P0 = 0x00;
  134.               while(1)
  135.               {
  136.                             show(flag);//显示电梯初始位置,等待按键动作
  137.                             terminal = keyscan();//获取键值
  138.                             if(terminal > flag)
  139.                             {upmove(flag,terminal);soundandled(terminal);}
  140. //如果键值大于初始位置,电梯上行
  141.                             if(terminal < flag)
  142.                             {downmove(flag,terminal);soundandled(terminal);}
  143. //如果键值大于初始位置,电梯下行
  144.                             flag = terminal;
  145.                             if(outset != 0)
  146.                             {
  147.                                           if(outset > terminal)
  148.                                           {upmove(terminal,outset);soundandled(outset);}
  149.                                           if(terminal > outset)
  150.                                           {downmove(terminal,outset);soundandled(outset);}
  151.                                           flag = outset;
  152.                                           outset = 0;
  153.                             }
  154.               }
  155. }
  156. void delay(uint t)//延时函数
  157. {
  158.               uchar a;
  159.               while(t--)
  160.               for(a = 0;a < 122;a++);
  161. }
复制代码


仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
51hei.gif

51hei.png

Keil代码与Proteus8.8 7.5仿真下载:
仿真程序文档.7z (350.32 KB, 下载次数: 295)

评分

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

查看全部评分

回复

使用道具 举报

ID:733618 发表于 2020-4-20 22:26 来自手机 | 显示全部楼层
好资料,51黑有你更精彩!!!
回复

使用道具 举报

ID:812518 发表于 2020-8-8 21:30 | 显示全部楼层
这波操作绝了 感谢感谢
回复

使用道具 举报

ID:1034506 发表于 2024-1-5 16:25 | 显示全部楼层
"elevator" - 0 Error(s), 1 Warning(s).有个警告
回复

使用道具 举报

ID:1034506 发表于 2024-1-5 17:27 | 显示全部楼层
Text1.c(59): warning C291: not every exit path returns a value
回复

使用道具 举报

ID:1034506 发表于 2024-1-8 15:54 | 显示全部楼层
蜂鸣器不发声音
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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