博客
关于我
2021年嵌入式第十二届省赛真题解析
阅读量:798 次
发布时间:2023-04-16

本文共 1222 字,大约阅读时间需要 4 分钟。

停车计费系统设计与实现

停车计费系统的核心功能模块包括数据接收处理、车辆信息存储与管理、费用计算以及用户界面显示。系统通过串口接收实时数据,并基于车辆到达和离场信息进行停车费用计算与管理。

1. 数据类型定义

车辆信息的存储采用结构体方式,便于管理和操作。定义的数据类型如下:

typedef struct {    uint8_t type[5];   // 停车类型    uint8_t id[5];     // 停车ID    uint8_t year;      // 年    uint8_t month;     // 月    uint8_t day;      // 日    uint8_t hour;     // 时    uint8_t min;      // 分    uint8_t sec;      // 秒    uint8_t empty_flag; // 空位标志} Data_Type;Data_Type Car_Data[8]; // 8个车位

2. 串口数据处理

系统通过串口接收停车数据,数据格式为22字节。首先进行数据包长度和内容的校验,确保接收的数据有效性。

3. 数据校验

校验过程包括:

  • 数据长度校验:检查接收数据长度是否为22字节。
  • 数据内容校验
    • 停车类型:必须为"VNBR"或"CNBR"。
    • 时间字段:年、月、日、时、分、秒均需有效。
    • 车辆ID:需为5位数字。
  • 4. 数据处理逻辑

    系统处理逻辑包括:

  • 车辆入库

    • 检查车库是否有空位。
    • 若无空位,返回错误信息。
    • 否则,记录车辆信息到相应车位,并更新空闲车位数量。
  • 车辆出库

    • 确认车辆类型与车库记录一致。
    • 计算停车时间差。
    • 根据停车类型计算费用。
    • 更新停车费用统计数据。
    • 发送收费信息至终端,并清空车位。
  • 5. 串口接收中断处理

    中断回调函数负责接收数据并存储:

    void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart) {    rx_buffer[rx_index++] = buffer;    HAL_UART_Receive_IT(&huart1, buffer, 1);}

    6. 时间与费用计算

    时间计算采用总秒转换为小时的方式,费用计算基于停车类型和价格设定。

    7. 界面显示

    系统通过LCD显示实时停车信息,包括:

    • 数据显示界面:显示现有车辆信息。
    • 参数设置界面:显示停车费用参数。

    8. 错误处理

    系统提供错误检测与处理机制,确保数据完整性和系统稳定运行。

    9. 按键操作

    按键用于切换界面和调整停车费用参数,实时反馈至LCD显示。

    10. 系统优化

    • 数据提取:提取车辆ID和类型信息。
    • 车位管理:利用结构体存储车辆信息,支持动态管理。
    • 内存管理:确保内存及时清空,防止数据污染。

    通过以上设计,系统能够实现高效的停车管理与费用计算,满足实际停车场景需求。

    转载地址:http://rygfk.baihongyu.com/

    你可能感兴趣的文章
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>
    MySQL _ MySQL常用操作
    查看>>
    MySQL – 导出数据成csv
    查看>>
    MySQL —— 在CentOS9下安装MySQL
    查看>>
    mysql 不区分大小写
    查看>>
    mysql 两列互转
    查看>>
    MySQL 中开启二进制日志(Binlog)
    查看>>
    MySQL 中文问题
    查看>>
    MySQL 中日志的面试题总结
    查看>>
    MySQL 中随机抽样:order by rand limit 的替代方案
    查看>>
    MySQL 为什么需要两阶段提交?
    查看>>
    mysql 为某个字段的值加前缀、去掉前缀
    查看>>
    mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
    查看>>
    mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
    查看>>
    mysql 主键重复则覆盖_数据库主键不能重复
    查看>>
    Mysql 优化 or
    查看>>
    mysql 优化器 key_mysql – 选择*和查询优化器
    查看>>
    MySQL 优化:Explain 执行计划详解
    查看>>
    Mysql 会导致锁表的语法
    查看>>