【单片机毕业设计】【mcuclub-jj-003】基于单片机的八层电梯的设计

news2025/1/11 14:08:02

      最近设计了一个项目基于单片机的八层电梯系统,与大家分享一下:

一、基本介绍

项目名:八层电梯
项目编号:mcuclub-jj-003
单片机类型:STC89C52、STM32F103C8T6

功能简介:
1、通过3*4矩阵键盘实现电梯内部的1-8层、开门、关门、呼叫(继电器模拟)
2、通过其中一个四相步进电机模拟电梯开关门(正反半圈)
3、通过另一个四相步进电机模拟电梯升降,每转一圈,代表一层
4、通过hx711采集电梯内重量,当开门时,电梯如果超载,则蜂鸣器报警,不关门,直到不超载
5、通过分离式红外对管模拟防夹,如果关门时触发,则自动开门
6、通过两个LED灯代表此时电梯上下行状态
7、通过数码管显示电梯处于的楼层
8、通过蓝牙,将当前楼层发送导外机

外机部分:
1、通过4*4矩阵键盘实现电梯外部的1-8层呼叫
2、通过8个LED灯,指示当前电梯到达的楼层
3、通过蓝牙,获取数据并发送楼层请求

二、51实物图

单片机型号:STC89C52

板子为绿色PCB板,两层板,厚度1.2,上下覆铜接地。元器件基本上为插针式,个别降压芯片会使用贴片式。

供电接口:TYPE-C

 

三、51仿真图

仿真软件版本:proteus8.9

电路连线方式:网络标号连线方式

注意:部分实物元器件仿真中没有,仿真中会用其他工作原理相似的元件代替,这样可能导致实物程序和仿真程序不一样

 

 四、32实物图

单片机型号:STM32F103C8T6

板子为绿色PCB板,两层板,厚度1.2,上下覆铜接地。元器件基本上为插针式,个别降压芯片会使用贴片式。

供电接口:TYPE-C

 

 五、原理图

软件版本:AD2013

电路连线方式:网络标号连线方式

注意:原理图只是画出了模块的引脚图,而并不是模块的内部结构原理图

内机:

 外机:

 

 六、PCB图

由原理图导出,封装很大一部分都是作者自己绘制,不提供封装库,只提供连接好的源文件。中间有一个项目编号,隐藏在单片机底座下,插入单片机后不会看到。

两层板,上下覆铜接地。

内机:

 

外机:

 

七、系统框图

本设计以单片机为核心控制器,加上其他模块一起组成此次设计的整个系统,此次设计包括主机和从机,主机和从机都包括中控部分、输入部分和输出部分。中控部分采用了单片机控制器,其主要作用是获取输入部分的数据,经过内部处理,逻辑判断,最终控制输出部分。

主机输入由四部分组成,第一部分是称重模块,通过该模块可以检测当前电梯内当前人体的重量,当检测到电梯内人体的重量大于设置的最大值进行报警提醒;第二部分是分离式红外对管检测模块,在电梯进行关门时,检测到有人,电梯门不打开;第三部分是矩阵键盘,通过该矩阵键盘用户可以输入想要到达的电梯楼层等;第四部分是供电模块,给整个系统进行供电;输出包括三个部分,第一部分是显示模块,通过数码管显示当前的楼层;第二部分是步进电机,控制电梯的运行及其电梯门的开关;第三部分是报警模块,检测到电梯内体重大于设置的最大值,进行报警提醒;第四部分是蓝牙模块,将当前按下的楼层数进行传输到外机进行显示

主机输处包括两个三个部分,第一部分是矩阵键盘模块,用户可以通过该模块进行电梯楼层的输入,第二部分是供电模块,用户可以通过该模块进行供电,第三部分是蓝牙模块,将内机输入的信息进行传输进来进行显示;输出通过LED指示灯指示当前的按下的楼层数。

具体系统框图如图所示。

 

 八、软件设计流程

主机系统的主流程图如图所示;在主程序中:首先对各个模块进行初始化,随后进入while主循环,在主循环中,首先进入第一个函数按键函数,该函数主要分为两部分,第一部分为调用按键扫描函数获取按键键值,第二部分通过键值进行相应的处理操作,比如确定楼层数、开门、关门;紧接着进入第二个函数处理函数,获取电梯内的重量,及其获取外机按下的楼层数;然后进入第三个函数显示函数,数码管显示当前楼层,LED显示当前的电梯方向;然后进入第四个函数处理函数,当电梯处于停止状态时,按下的电梯楼层数为目标楼层数,如果当前电梯为下行方向,当前楼层高于按下楼层,当电梯下行,检测到按下楼层小于当前运行楼层,则目标楼层为按下楼层。如果当前电梯上行,检测到按下楼层高于当前楼层,目标楼层为按下楼层;如果当前楼层比目标楼层高,电梯下行,且电梯运行楼层到达当前的楼层数-1,如果当前楼层比目标楼层低,电梯上升,如果电梯运动时间到达,当前楼层加一,当前楼层等于目标楼层,如果门是关闭的,开门,如果门已经打开了,开启停留定时,如果超重,门不关闭且声光报警,如果没超重,门关闭,关闭声光报警,如果停留时间到达,如果门是开启的,关门,如果触发防夹,标记未停留完成,门已关闭清除当前按下楼层标志位,如果电梯方向为下降,清除当前楼层下标志位,发送当前楼层,如果电梯方向为上升,清除当前楼层上标志位,发送当前楼层

 

 九、部分程序展示

软件版本:keil5

逻辑程序和驱动程序分开,分布于main.c和其他.c文件

void Manage_function(void)
{
  if(flag_lift == 0)                            //如果当前电梯停止
  {
    if(flag_stop == 1 && flag_door == 0)
    {
      if(flag_floor_d[1] == 1 || flag_floor_u[1] == 1)                 //一楼按下,目标楼层为一楼
      {
        target_floor = 1;
      }
      else if(flag_floor_d[2] == 2 || flag_floor_u[2] == 2)            //二楼按下,目标楼层为二楼
      {
        target_floor = 2;
      }
      else if(flag_floor_d[3] == 3 || flag_floor_u[3] == 3)            //三楼按下,目标楼层为三楼
      {
        target_floor = 3;
      }
      else if(flag_floor_d[4] == 4 || flag_floor_u[4] == 4)            //四楼按下,目标楼层为四楼
      {
        target_floor = 4;
      }
      else if(flag_floor_d[5] == 5 || flag_floor_u[5] == 5)            //五楼按下,目标楼层为五楼
      {
        target_floor = 5;
      }
      else if(flag_floor_d[6] == 6 || flag_floor_u[6] == 6)            //六楼按下,目标楼层为六楼
      {
        target_floor = 6;
      }
      else if(flag_floor_d[7] == 7 || flag_floor_u[7] == 7)            //七楼按下,目标楼层为七楼
      {
        target_floor = 7;
      }
      else if(flag_floor_d[8] == 8 || flag_floor_u[8] == 8)            //八楼按下,目标楼层为八楼
      {
        target_floor = 8;
      }
    }
  }
  if(flag_lift == 1)                            //如果电梯当前方向下降
  {
    if(flag_floor_d[7] == 7)                    //如果七楼下
    {
      if(current_floor > 7) //如果当前高于七楼,目标楼层等于七楼
      {
        target_floor = 7;
      }
    }
    else if(flag_floor_d[6] == 6)                //如果六楼下
    {
      if(current_floor > 6) //如果当前高于六楼,目标楼层等于六楼
      {
        target_floor = 6;
      }
    }
    else if(flag_floor_d[5] == 5)           //如果五楼下
    {
      if(current_floor > 5) //如果当前高于五楼,目标楼层等于五楼
      {
        target_floor = 5;
      }
    }
    else if(flag_floor_d[4] == 4)           //如果四楼下
    {
      if(current_floor > 4) //如果当前高于四楼,目标楼层等于四楼
      {
        target_floor = 4;
      }
    }
    else if(flag_floor_d[3] == 3)           //如果三楼下
    {
      if(current_floor > 3) //如果当前高于三楼,目标楼层等于三楼
      {
        target_floor = 3;
      }
    }
    else if(flag_floor_d[2] == 2)           //如果二楼下
    {
      if(current_floor > 2) //如果当前高于二楼,目标楼层等于二楼
      {
        target_floor = 2;
      }
    }
    else if(flag_floor_d[1] == 1)           //如果一楼
    {
      if(current_floor > 1) //如果当前高于一楼,目标楼层等于一楼
        target_floor = 1;
    }
  }
  if(flag_lift == 2)                            //如果当前电梯上升
  {
    if(flag_floor_u[2] == 2)                //如果二楼上
    {
      if(current_floor < 2) //如果当前楼层低于二楼,目标楼层等于二楼
      {
        target_floor = 2;
      }
    }
    else if(flag_floor_u[3] == 3)           //如果三楼上
    {
      if(current_floor < 3) //如果当前楼层低于三楼,目标楼层等于三楼
      {
        target_floor = 3;
      }
    }
    else if(flag_floor_u[4] == 4)           //如果四楼上
    {
      if(current_floor < 4) //如果当前楼层低于四楼,目标楼层等于四楼
      {
        target_floor = 4;
      }
    }
    else if(flag_floor_u[5] == 5)           //如果五楼上
    {
      if(current_floor < 5) //如果当前楼层低于五楼,目标楼层等于五楼
      {
        target_floor = 5;
      }
    }
    else if(flag_floor_u[6] == 6)           //如果六楼上
    {
      if(current_floor < 6) //如果当前楼层低于六楼,目标楼层等于六楼
      {
        target_floor = 6;
      }
    }
    else if(flag_floor_u[7] == 7)           //如果七楼上
    {
      if(current_floor < 7) //如果当前楼层低于七楼,目标楼层等于七楼
      {
        target_floor = 7;
      }
    }
    else if(flag_floor_u[8] == 8)           //如果八楼上
    {
      if(current_floor < 8) //如果当前楼层低于八楼,目标楼层等于八楼
      {
        target_floor = 8;
      }
    }
  }
  
  if(current_floor > target_floor)          //如果当前楼层比目标楼层高,电梯下降
  {
    flag_timer_begin = 0;
    flag_stop = 0;
    flag_lift = 1;
    if(flag_bujin_2_o == 0 && flag_bujin_2_c == 0 && flag_door == 0)
    {
      flag_bujin_1_c = 1;
      flag_bujin_1_o = 0;
    }
    flag_send = 0;
  }
  else if(current_floor < target_floor)     //如果当前楼层比目标楼层低,电梯上升
  {
    flag_timer_begin = 0;
    flag_stop = 0;
    flag_lift = 2;
    if(flag_bujin_2_o == 0 && flag_bujin_2_c == 0 && flag_door == 0)
    {
      flag_bujin_1_c = 0;
      flag_bujin_1_o = 1;
    }
    flag_send = 0;
  }
  else                                      //当前楼层等于目标楼层
  {
    if(flag_stop == 0)              //如果没有停留完成
    {
      if(flag_door == 0)            //如果门是关闭的,开门
      {
        flag_bujin_2_o = 1;
        flag_bujin_2_c = 0;
      }
      else if(flag_door == 1)       //如果门已经打开了
      {
        flag_timer_begin_s = 1;     //开启停留定时
      }
      if(weight_value > 1000|| INFRARED == 1) //如果超重了,进行蜂鸣器提醒,清除停留时间计数
      {
        timer1_count_s = 0;
        if(weight_value > 1000)                 //如果超重,声光报警
        {
          if(time_num % 15 == 0)
          {
            BEEP = ~BEEP;
          }
        }
      }
      else if(weight_value < 1000)              //如果没有超重,蜂鸣器关闭
      {
        BEEP = 1;
      }
      if(flag_time_s == 1)          //如果停留时间到达
      {
        flag_timer_begin_s = 0;
        flag_time_s = 0;
        flag_stop= 1;
      }
    }
    if(flag_stop == 1)              //如果停留完成
    {
      if(flag_door == 1)            //如果门是开启的,关门
      {
        flag_bujin_2_o = 0;
        flag_bujin_2_c = 1;
        if(INFRARED == 1 && flag_bujin_2_c == 1)  //如果触发防夹,标记未停留完成
        {
          flag_door = 0;
          flag_stop = 0;
        }
      }
      else if(flag_door == 0)      //如果门已关闭清除当前按下楼层标志位
      {
        if(flag_lift == 1)          //如果电梯方向为下降,清除当前楼层下标志位
        {
          if(flag_send == 0)
          {
            send_buf[1] = (current_floor/10*0x10 + current_floor%10);
            Uart_Sent_Str(send_buf);
            flag_send = 1;
          }
          flag_floor_d[target_floor] = 0;
        }
        if(flag_lift == 2)          //如果电梯方向为上升,清除当前楼层上标志位
        {
          if(flag_send == 0)
          {
            send_buf[1] = (current_floor/10*0x10 + current_floor%10);
            Uart_Sent_Str(send_buf);
            flag_send = 1;
          }
          flag_floor_u[target_floor] = 0;
        }
        if(flag_lift == 0)
        {
          flag_floor_d[target_floor] = 0;
          flag_floor_u[target_floor] = 0;
        }
        flag_timer_begin = 1;       //开启定时
      }
    }
  }
  if(flag_time == 1)                //定时500ms到达,清除电梯运动标志位
  {
    flag_timer_begin = 0;
    flag_lift = 0;
    flag_time = 0;
    flag_floor_d[current_floor] = 0;
    flag_floor_u[current_floor] = 0;
  }
}

资料请点击跳转到官网下载

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/272.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux修炼】5.vim详解

每一个不曾起舞的日子&#xff0c;都是对生命的辜负。 Linux-yum&vim工具的使用本节目标1. Linux 软件包管理器 yum1.1 什么是软件包1.2 关于rzsz1.3 查看软件包1.4 如何安装软件1.5 如何卸载软件2. Linux编辑器-vim的使用&#xff08;重点&#xff09;2.1 什么是vim&#…

C++内存管理

1.C内存分布 学习C内存分布之前&#xff0c;先小试牛刀一下。 int globalVar 1; static int staticGlobalVar 1; void Test() {static int staticVar 1;int localVar 1;int num1[10] { 1, 2, 3, 4 };char char2[] "abcd";const char* pChar3 "abcd&quo…

webpack--》webpack底层深入讲解,从初识到精通,真正实现从0到1的过程

目录 webpack webpack的基本使用 安装 配置 修改自定义打包的入口与出口 优化js或图片的存放路径 配置webpack中符号的使用 webpack中相关插件安装 webpack-dev-server html-webpack-plugin clean-webpack-plugin webpack中的loader 打包处理css文件 打包处理les…

TPM分析笔记(十二)TPM PCR操作

目录一、PCR初始化&#xff08;Initializing PCR&#xff09;二、PCR的扩展&#xff08;Extend of a PCR&#xff09;2.1 其他PCR命令三、使用PCR Banks进行扩展&#xff08;Using Extend with PCR Banks&#xff09;四、事件记录&#xff08;Recording Events&#xff09;五、…

Java递归实现树形结构的两种方式

目录0、引言1、数据准备2、类型转化3、递归实现方法3.1、Java7及以下纯Java递归实现3.2、Java8及以上借助lamda表达式实现0、引言 在开发的过程中&#xff0c;很多业务场景需要一个树形结构的结果集进行前端展示&#xff0c;也可以理解为是一个无限父子结构&#xff0c;常见的…

【老师见打系列】:我只是写了一个自动回复讨论的脚本~

文章目录&#x1f31f;好久不见⛳️实现过程&#x1f334;老操作了兄弟们~&#x1f422;一步拿捏讨论&#x1f496;美图结束语专栏Python零基础入门篇&#x1f4a5;Python网络蜘蛛&#x1f4a5;Python数据分析Django基础入门宝典&#x1f4a5;小玩意儿&#x1f4a5;Web前端学习…

2022海德堡桂冠论坛(HLF)见闻录

今年9月下旬&#xff0c;我前往德国参加了第九届海德堡桂冠论坛。因疫情原因停摆两年后&#xff0c;海德堡桂冠论坛再次以线下形式举办&#xff0c;会场热闹非凡&#xff0c;作为计算机与数学界的社交盛宴当之无愧。 海德堡桂冠论坛&#xff08;Heidelberg Laureate Forum, HLF…

IGV-GSAman |「功能基因组时代」的高效率科研工具

写在前面 今天周末&#xff0c;转眼10月份只剩一周。万万没想到&#xff0c;一个月下去&#xff0c;我还是花了不少时间在完善「GSAman」。至于为什么本来「两个小时」就干完的事情&#xff0c;可以干成「22天」&#xff1f;到底还是我对前面的版本&#xff0c;不太满意。当然…

Attack Lab

Attack Lab 从CMU官网下载完所需实验包后&#xff0c;内有官方文档以及.tar压缩包&#xff0c;使用tar -xvf targetk.tar解压后&#xff0c;得到如下文件 The fifiles in targetk include: README.txt: A fifile describing the contents of the directory ctarget: An execut…

web自动化测试框架

本文介绍web自动化测试框架 ●Base&#xff1a;用来对Selenium API进行二次封装。 对Selenium API进行二次封装的目的是简化一些复杂的操作&#xff0c;但是千万不要为了封装而封装。 封装好后&#xff0c;其他页面类可以集成basepage&#xff0c;调用这些方法。 from sele…

【iOS】—— 仿写知乎日报第一周总结

目录知乎日报第一周完成情况遇到的问题&#xff1a;1.线程问题&#xff1a;2.SDWebImage加载图片3.实现无限刷新界面4.点击主界面cell进入后的界面知乎日报第一周完成情况 在这周开始了仿写知乎日报的任务&#xff0c;在第一周里&#xff0c;我完成了主界面&#xff0c;以及滚…

新人入手mac折腾过程中遇到的解决方案

本文将长期更新&#xff0c;以记录个人的使用。 终端美化 …还没有美化完&#xff0c;不过推荐看这篇文章Mac终端美化指南 homebrew homebrew是Mac OS X上的强大的包管理工具&#xff0c;可以高效管理各种软件包&#xff0c;官方说法是&#xff1a;The missing package mana…

ArcGIS:如何新建图层组并添加数据、切换数据视图和布局视图、修改符号系统?

目录 01 如何新建图层组&#xff1f; 02 如何在图层组中添加数据 03 如何切换数据视图和布局视图 03 如何修改符号系统&#xff1f; 3.1 如何快捷的修改一下符号样式&#xff1f; 3.2 如何修改符号系统的色带 3.2.1 色带视图的取消 3.3 修改符号系统中的标注显示 3.4 如…

大气湍流退化图像复原技术研究及DSP实现

目录 第一章 绪论 1 1.1 研究背景 1 1.2 国内外研究现状 1 1.3 本文的研究内容 5 1.4 本文的组织结构 5 第二章 大气湍流退化图像复原技术 7 2.1 图像退化及复原数学模型概述 7 2.1.1 图像退化的数学模型 7 2.1.2 图像复原的数学模型 8 2.2 大气湍流退化图像概述 9 2.2.1 大气…

插件内存分析

rtspsrc 1. 当pipleline为rtspsrc加其他插件时&#xff0c;如果让其他插件卡主会发生什么事情呢&#xff1f;以rtspsrcfakesink为例&#xff08;gst-launch-1.0.exe rtspsrc locationrtsp://xxx ! fakesink&#xff09;&#xff0c;修改fakesink的代码&#xff0c;让render中…

基于SSM的图书馆阅览室预约管理系统,高质量论文范例,可直接参考使用,附送源码、数据库脚本

目录 1.项目技术栈 2.适合对象 3.适合课题 4.项目功能概述 4.1 项目功能汇总 4.2 项目功能介绍 5. 高质量论文范例 6. 毕业设计撰写视频教程 6.部分运行截图 1.项目技术栈 前端必学三个基础&#xff0c;"HTML、CSS、JS"&#xff0c;基本每个B/S架构项目都要…

C++【搜索二叉树】

目录 一、什么是搜索二叉树 二、搜索二叉树如何删除数据 删除的是叶子结点的情况 删除的结点下面仅有一个子节点&#xff08;托孤&#xff09;&#xff08;要删除的结点只有一个孩子&#xff09; 替换法删除 &#xff08;要删除的结点有两个个孩子&#xff09; 三、写一…

腾讯前辈熬夜肝了一个月整理的《Linux内核学习笔记》,啃完受益匪浅不走弯路

小编热衷于收集整理资源&#xff0c;记录踩坑到爬坑的过程。希望能把自己所学&#xff0c;实际工作中使用的技术、学习方法、心得及踩过的一些坑&#xff0c;记录下来。也希望想做Linux内核高级工程师的你一样&#xff0c;通过我的分享可以少走一些弯路&#xff0c;可以形成一套…

【数据结构】常见七大排序总结

目录 一、插入排序&#xff1a;直接插入排序【稳定排序方法】 二、插入排序&#xff1a;希尔排序【不稳定排序方法】 三、选择排序&#xff1a;直接选择排序【不稳定排序方法】 四、选择排序&#xff1a;堆排序【不稳定排序方法】 五、交换排序&#xff1a;冒泡排序【稳定…

基于单片机MC9S12XS128的两轮自平衡小车设计

目 录 1.绪论 1 1.1研究背景与意义 1 1.2两轮自平衡车的关键技术 2 1.2.1系统设计 2 1.2.2数学建模 2 1.2.3姿态检测系统 2 1.2.4控制算法 3 1.3本文主要研究目标与内容 3 1.4论文章节安排 3 2.系统原理分析 5 2.1控制系统要求分析 5 2.2平衡控制原理分析 5 2.3自平衡小车数学…