• 基于51单片机的智能蓝牙路灯街灯控制系统proteus仿真原理图PCB


    功能:
    0.本系统采用STC89C52作为单片机
    1.液晶实时显示时间/环境光强/工作模式
    2.每隔5s向蓝牙串口发送一次信息
    3.支持路灯故障检测
    4.工作时间18~24时,两个路灯同时点亮,24时以后,B路灯关闭,若检测到由物体通过,路灯B点亮10s后关闭
    5.非工作时间,光照强度低于设定光照阈值,两个路灯点亮
    6.可蓝牙控制两个路灯状态
    7.按键更改时间/工作时间/光照阈值/工作模式/路灯亮度
    8.采用DC002作为电源接口可直接输入5V给整个系统供电

    原理图:
    在这里插入图片描述
    在这里插入图片描述

    PCB :
    在这里插入图片描述

    主程序:

    #define __MAIN_C
    #include 
    #include "main.h"
    
    bit dispFlag = 1;
    bit setFlag = 0;
    bit sendFlag = 0;
    unsigned char setIndex = 0;
    unsigned char lightValue;
    unsigned char lightValueA;
    unsigned char lightValueB;
    unsigned char lightLimit = 70;
    unsigned char timeLimit[4] = {
       18, 0, 5, 0};
    char dispMode = DISP_NORMAL;
    bit autoFlag = 0;
    bit lampBDelay = 0;
    bit lampAError = 0;
    bit lampBError = 0;
    bit lampASwitch;
    bit lampBSwitch;
    unsigned char lampAPWM = 3;
    unsigned char lampBPWM = 3;
    int cnt = 0;
    unsigned int time500us = 0;
    unsigned char i = 0;
    unsigned char R_buf[4];
    
    void main()
    {
       
        //初始化
        lampASwitch = LAMP_OFF;
        lampBSwitch = LAMP_OFF;
        LCD_Init();
        DS1302_Init();
        EEPROM52_Read();
        if (isNew == 1)
        {
       
            DS1302_WriteTime();
        }
        DS1302_ReadTime();
        EEPROM52_Init();
        Timer0_Init();
    
        UART0_Init();
        
        DelayMs(20);
        //开机显示
        LCD_DispStr(0, 0, "    Welcome!    ");
        DelayS(2);
        LCD_Clear();
        DS1302_ReadTime();
        DispNormal(setIndex);
    
        while(1)
        {
       
            // LCD1602液晶显示
            if (dispFlag == 1 && setFlag == 0)
            {
       
                dispFlag = 0;
                LampCtr();
                CheckLamp();
                DS1302_ReadTime();
    
                if (dispMode == DISP_NORMAL)
                {
       
                    DispNormal(setIndex);
                }
                else if (dispMode == SET_TIME_LIMIT)
                {
       
                    DispSetLimit(setIndex);
                }
                else if (dispMode == SET_LIGHT)
                {
       
                    DispSetLight(setIndex);
                }
                else if (dispMode == CHECK_LIGHT)
                {
       
                    DispCheckLight(setIndex);
                }
            }
    
            //发送一次串口信息
            if (sendFlag == 1)
            {
       
                sendFlag = 0;
    
                if (lampAError == 1)
                {
       
                    sprintf
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
  • 相关阅读:
    【小黑嵌入式系统第五课】嵌入式系统开发流程——开发工具、交叉开发环境、开发过程(生成&调试&测试)、发展趋势
    整形和浮点型是如何在内存中的存储
    STM32的TIM1之PWM互补输出_死区时间和刹车配置
    Java反射机制
    MySQL之InnoDB的锁类型与锁原理
    787. 归并排序
    多列等高实现
    基于Redis的分布式锁 以及 超详细的改进思路
    升级pip
    redis如何保证接口的幂等性
  • 原文地址:https://blog.csdn.net/jimo167913/article/details/128109196