基于51单片机的智能泊车引导系统仿真

仿真图:

在这里插入图片描述

芯片/模块的特点:

AT89C52简介:
AT89C52是一款经典的8位单片机,是意法半导体(STMicroelectronics)公司生产的一系列单片机之一。它基于8051内核,并具有许多与其兼容的特性。

AT89C52的主要特点如下:

内部存储器:AT89C52具有8KB的闪存(Flash)存储器,可用于存储用户程序和数据。这些存储器的内容可以通过编程器进行编程和擦除。

RAM存储器:AT89C52配备了256字节的随机存取存储器(RAM),用于暂存数据和程序的变量。

外部扩展性:AT89C52支持多种外部扩展设备的连接,包括外部存储器(如RAM、EEPROM)和外设(如ADC、LCD、UART等),通过外部硬件连接,可以扩展单片机的功能和应用。

通用I/O引脚:AT89C52拥有32个可编程的通用输入/输出引脚,可用于连接外部设备和与其他芯片进行通信。

定时器/计数器:AT89C52内置了3个16位定时器/计数器和一个可编程的串行定时器/计数器。这些计时器/计数器可用于实现定时功能、生成脉冲信号、测量时间间隔等。0

串行通信:AT89C52支持串行通信接口,包括UART(串行异步通信)和SPI(串行外设接口),便于与其他设备进行数据通信和交互。

低功耗模式:AT89C52具有多种低功耗模式,如空闲模式和电源下模式,在不需要执行任务的时候可以将CPU进入低功耗状态以节省能量。

宽电源电压范围:AT89C52的工作电压范围通常为4.0V至5.5V,可以满足大多数应用需求。

主程序:

#include <reg52.h>
#include <intrins.h>
#include <stdio.h>
#include "delay.h"
#include "lcd1602.h"

sbit PARKING_SPACE_1 = P3^6; //接口定义
sbit PARKING_SPACE_2 = P3^5;
sbit PARKING_SPACE_3 = P3^4;


xdata unsigned char dis0[16]; //定义显示区域临时存储数组
xdata unsigned char dis1[16];

unsigned char disFlag = 0; //显示标志
unsigned char i;

bit reportFlag = 0;          //上报标志
unsigned char occupiedFlag1 = 0; //位置标志
unsigned char occupiedFlag2 = 0; //位置标志
unsigned char occupiedFlag3 = 0; //位置标志
unsigned char occupiedNum = 0;     //占用总数

void Timer0_Init(void); //函数声明
void UART_SendStr(unsigned char *s, unsigned char length);
void UART_Init(void);
void UART_SendByte(unsigned char dat);

void main(void)
{
    Timer0_Init(); //定时器0初始化
    UART_Init();

    LCD_Init();  //初始化液晶
    DelayMs(20); //延时有助于稳定
    LCD_Clear(); //清屏


    while (1)
    {
        if (PARKING_SPACE_1 == 0) //车位检测到
        {
            occupiedFlag1 = 1;
        } //标志
        else
        {
            occupiedFlag1 = 0;
        }

        if (PARKING_SPACE_2 == 0) //车位检测到
        {
            occupiedFlag2 = 1;
        } //标志
        else
        {
            occupiedFlag2 = 0;
        }

        if (PARKING_SPACE_3 == 0) //车位检测到
        {
            occupiedFlag3 = 1;
        } //标志
        else
        {
            occupiedFlag3 = 0;
        }

        if (disFlag == 1) //定时显示
        {
            disFlag = 0; //标志位清零
            if (occupiedFlag1 == 1)
            {
                LCD_DispStr(0, 1, "P ");
            } //显示占用
            else
            {
                LCD_DispStr(0, 1, "N ");
            }

            if (occupiedFlag2 == 1)
            {
                LCD_DispStr(2, 1, "P ");
            } //显示占用
            else
            {
                LCD_DispStr(2, 1, "N ");
            }

            if (occupiedFlag3 == 1)
            {
                LCD_DispStr(4, 1, "P ");
            } //显示占用
            else
            {
                LCD_DispStr(4, 1, "N ");
            }
            occupiedNum = occupiedFlag1 + occupiedFlag2 + occupiedFlag3;                      //占用总数
            sprintf(dis0, "1 2 3  P:%d  N:%d ", (int)occupiedNum, (int)(3 - occupiedNum)); //打印
            LCD_DispStr(0, 0, dis0);                                           //显示
        }

        if (reportFlag == 1) //入库上报一次数据
        {
            reportFlag = 0; //清楚标志
            sprintf(dis1, "P:%d  N:%d ", (int)occupiedNum, (int)(3 - occupiedNum)); //打印

            if (occupiedFlag1 == 1)
            {
                UART_SendStr("N01 Parking ", 12);
            } //发送占用
            else
            {
                UART_SendStr("N01 Void    ", 12);
            }
            UART_SendStr("\r\n", 2); //换行
            DelayMs(1);

            if (occupiedFlag2 == 1)
            {
                UART_SendStr("N02 Parking ", 12);
            } //发送占用
            else
            {
                UART_SendStr("N02 Void    ", 12);
            }
            UART_SendStr("\r\n", 2); //换行
            DelayMs(1);

            if (occupiedFlag3 == 1)
            {
                UART_SendStr("N03 Parking ", 12);
            } //发送占用
            else
            {
                UART_SendStr("N03 Void    ", 12);
            }
            UART_SendStr("\r\n", 2); //换行
            DelayMs(1);

            UART_SendStr(dis1, 9);
            UART_SendStr("\r\n", 2);
        }
    }
}

void Timer0_Init(void)
{
    TMOD |= 0x01;                //使用模式1,16位定时器,使用"|"符号可以在使用多个定时器时不受影响
    TH0 = (65536 - 18432) / 256; //重新赋值 20ms
    TL0 = (65536 - 18432) % 256;
    EA = 1;  //总中断打开
    ET0 = 1; //定时器中断打开
    TR0 = 1; //定时器开关打开
}

void Timer0_Interrupt(void) interrupt 1
{
    static unsigned int time_20ms = 0;


    TH0 = (65536 - 18432) / 256; //重新赋值 20ms
    TL0 = (65536 - 18432) % 256;

    time_20ms++;

    if (time_20ms > 250)
    {
        reportFlag = 1; //串口上报标志 调试使用的
        time_20ms = 0;
    }

    if (time_20ms % 50 == 0) //定时
    {
        disFlag = 1;
    }
}

void UART_Init(void)
{
    SCON = 0x50;  // SCON: 模式 1, 8-bit UART, 使能接收
    TMOD |= 0x20; // TMOD: timer 1, mode 2, 8-bit 重装
    TH1 = 0xFD;   // TH1:  重装值 9600 波特率 晶振 11.0592MHz
    TL1 = TH1;
    TR1 = 1; // TR1:  timer 1 打开
    EA = 1;  //打开总中断
    ES = 1;  //打开串口中断
}

void UART_SendByte(unsigned char dat)
{
    unsigned char time_out;
    time_out = 0x00;
    SBUF = dat;                       //将数据放入SBUF中
    while ((!TI) && (time_out < 100)) //检测是否发送出去
    {
        time_out++;
        DelayUs10x(2);
    }       //未发送出去 进行短暂延时
    TI = 0; //清除ti标志
}

void UART_SendStr(unsigned char *s, unsigned char length)
{
    unsigned char cnt;
    cnt = 0x00;
    while (cnt < length) //发送长度对比
    {
        UART_SendByte(*s); //放松单字节数据
        s++;              //指针++
        cnt++;            //下一个++
    }
}

void UART_Interrupt(void) interrupt 4 //串行中断服务程序
{
    unsigned char r_buf;
    if (RI) //判断是接收中断产生
    {
        RI = 0; //标志位清零
        r_buf = SBUF;
    }
    if (TI) //如果是发送标志位,清零
    {
        TI = 0;
    }
}

设计文件:

链接:https://pan.baidu.com/s/1t1CtgJNAmosCsxFd2g5lmg?pwd=yyby

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值