STM32 インテリジェント カーテン制御システム シミュレーション設計に基づく (ソース プログラム + プロテウス シミュレーション + 説明ビデオを含む)

# STM32 インテリジェント カーテン デザインに基づく (ソース プログラム + プロテウス シミュレーションを含む)

シミュレーション:proteus8.11
プログラムコンパイラ:keil 5
プログラミング言語:C言語
No.C0007
データダウンロードリンク

解説ビデオ

STM32に基づくシンプルなインテリジェントカーテン制御システムのシミュレーション設計

機能の説明:

実装機能:

手動と自動の 2 つのモードがあります

自動モードでは、スライディングレオスタットは光センサーをシミュレートし、stm32 を介して検出され、しきい値と比較されます。

しきい値がしきい値よりも低い場合はカーテンを開け、しきい値がしきい値よりも高い場合はカーテンを閉じます。

手動モードでは、ボタンでカーテンの開閉を制御します。

シミュレーション図 (提供されるソース ファイル):

新しいバージョン:

新しいカバー

古いバージョン:

ここに画像の説明を挿入します

ソースプログラム (提供されるソースファイル):

#include "delay.h"
#include "sys.h"
#include "adc.h"
#include "1602.h"
#include "motor.h"
#include "bsp_dht11.h"
#define LED1 PAout(13)
#define LED2 PAout(14)
#define MOTOR PCout(0)

unsigned char dis_vol1[] = {
    
    "LUX:      % auto"};
unsigned char dis_vol2[] = {
    
    "  auto"};
unsigned char dis_vol3[] = {
    
    "manual"};
//函数声明
void display1(void);
void display2(void);
u16    LUX, HZ;
int main(void)
{
    
    
    unsigned int i;
    u16 ADCValue1, ADCValue2;
    float voltage1, voltage2;
    u8 Mflag = 2;
    u8 OPENflag = 0;	//起初代表窗帘关
    u8 AUTOflag = 0;	//起初代表自动
    delay_init();
    Adc_Init();
    GPIO_InitStructReadtempCmd();
    MotoR_GPIO();
    lcd_system_reset();
    LED1 = 1;
    LED2 = 0;
    MOTOR = 1;
    while(1)
    {
    
    
        ADCValue1 = Get_Adc_Average(ADC_Channel_0, 10);
        voltage1 = ((float)ADCValue1 / 4096) * 3.3; //计算电压
        LUX = (10000 * voltage1) / 33;
        display1();
        if(PCin(12) == 0) //自动
        {
    
    
            AUTOflag = 0;


            for(i = 0; i <6; i++)
                lcd_char_write(i, 1, dis_vol2[i]);
        }
        if(PCin(13) == 0) //手动
        {
    
    
            AUTOflag = 1;
            for(i = 0; i < 6; i++)
                lcd_char_write(i, 1, dis_vol3[i]);
        }
        if(PCin(10) == 0 && OPENflag == 0 && AUTOflag == 1)
        {
    
    
            LED1 = 0;
            LED2 = 1;
            MOTOR = 0; //开窗帘
            Mflag = 2;
            OPENflag = 1;	 //已经开好
        }
        if(PCin(11) == 0 && OPENflag == 1 && AUTOflag == 1)
        {
    
    
            LED1 = 1;
            LED2 = 0;
            MOTOR = 1; //关闭窗帘
            Mflag = 2;
            OPENflag = 0;	 //已经关好

        }
        if(LUX > 400) //40%  阈值
        {
    
    
            display1();
            Mflag = 1;		//光照足够,关闭窗帘
        }
        else
        {
    
    
            display1();
            Mflag = 0;	//光照不足,需要启动窗帘
        }
        if(Mflag == 1 && OPENflag == 1 && AUTOflag == 0)
        {
    
    
            LED1 = 1;
            LED2 = 0;
            MOTOR = 1; //关闭窗帘
            Mflag = 2;
            OPENflag = 0;	 //已经关好
        }
        else if(Mflag == 0 && OPENflag == 0 && AUTOflag == 0)
        {
    
    
            LED1 = 0;
            LED2 = 1;
            MOTOR = 0; //开窗帘
            Mflag = 2;
            OPENflag = 1;	 //已经开好

        }
    }
}

void display1()
{
    
    
    unsigned int i, j;
    dis_vol1[5] = LUX / 100 + 0x30;
    dis_vol1[6] = LUX % 100 / 10 + 0x30;
    dis_vol1[7] = '.';
    dis_vol1[8] = LUX % 10 + 0x30;
    for(i = 0; i < 12; i++)
        lcd_char_write(i, 0, dis_vol1[i]);
    //  	 for(j=0;j<15;j++)
    // 	  lcd_char_write(j,1,dis_vol2[j]);
}


ここに画像の説明を挿入します

情報一覧は以下の通りです。

ダウンロード方法:ビデオまたは記事の冒頭をご覧ください。
新着情報一覧

おすすめ

転載: blog.csdn.net/weixin_52733843/article/details/131553029