STC15W4K系列单片机读取DHT11温湿度数据发送到串口

为了方便大家调试,点击进入程序下载地址

已经配置好了UART1和UART3两个串口,直接在main函数中改写     PrintString1("湿度:");     PrintString3("湿度:");   即可。

针对DHT11最主要的问题是   时序  。

本例程已经搭建好了DHT11库函数,delay延时函数的库函数,方便移植到其他型号的单片机上运行。

移植时只要根据不同的单片机型号和主时钟/颈枕频率改写相应的延时函数即可。

#include "dht11.h"
/****************★★★★★★★★★★★★★★★★★★★★★★★★*********************/
/**************STC15W4KS4-DHT11-UART1***********************************************/
/**************STC15W4KS4读取DHT11温湿度数据,通过UART1打印出来***********************/
/**************作者:隔壁家的老婆饼***************************************************/
/**************QQ:976764326***********************************************************/
/**************Email:976764326@qq.com************************************************/
/**************时间:2018/9***********************************************************/
/**************工作频率:11.0592MHz***************************************************/
/****************★★★★★★★★★★★★★★★★★★★★★★★★*********************/

#define u8 unsigned char
/*************    本地常量声明    **************/
#define MAIN_Fosc        11059600L    //定义主时钟

#define    RX1_Length    128        /* 接收缓冲长度 */
#define    RX3_Length    128        /* 接收缓冲长度 */
#define    UART_BaudRate1    115200UL     /* 波特率 */
#define    UART_BaudRate3    115200UL     /* 波特率 */


/*************    本地变量声明    **************/
u8    xdata    RX1_Buffer[RX1_Length];    //接收缓冲
u8    xdata    RX3_Buffer[RX3_Length];    //接收缓冲
u8    TX1_read,RX1_write;    //读写索引(指针).
u8    TX3_read,RX3_write;    //读写索引(指针).
bit    B_TX1_Busy,B_TX3_Busy;
unsigned char Table_LCD[]="0123456789.";
unsigned char humy[4];
unsigned char temp[4];
/*************    本地函数声明    **************/
void    UART1_config(u8 brt);    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
void    UART3_config(u8 brt);    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer3做波特率.

void     PrintString1(u8 *puts);
void     PrintString3(u8 *puts);


void IO_Init()
{
    /
    //注意: STC15W4K32S4系列的芯片,上电后所有与PWM相关的IO口均为
    //      高阻态,需将这些口设置为准双向口或强推挽模式方可正常使用
    //相关IO: P0.6/P0.7/P1.6/P1.7/P2.1/P2.2
    //        P2.3/P2.7/P3.7/P4.2/P4.4/P4.5
    /
    P0M1 = 0;    P0M0 = 0;    //设置P0.0~P0.7为准双向口
    P1M1 = 0;    P1M0 = 0;    //设置P1.0~P1.7为准双向口
    P2M1 = 0;    P2M0 = 0;    //设置P2.0~P2.7为准双向口 
    P3M1 = 0;    P3M0 = 0;    //设置P3.0~P3.7为准双向口
    P4M1 = 0;    P4M0 = 0;    //设置P4.0~P4.7为准双向口
    P5M1 = 0;    P5M0 = 0;    //设置P5.0~P5.7为准双向口
}

void main()
{
    unsigned char val;
    IO_Init();
    UART1_config(1);    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
    UART3_config(3);    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer3做波特率.
    
     EA = 1;
    PrintString1("DS18B20-15W4K UART1 TEST!\r\n");
    PrintString3("DS18B20-15W4K UART3 TEST!\r\n");

    while(1)
    {
        GetDHT11_Data();
        val=(tempH+tempL+humyH+humyL)&0xff;
        if(val==CheckData)
        {
            humy[0]=Table_LCD[humyH/10];
            humy[1]=Table_LCD[humyH%10];
            PrintString1("湿度:");
            PrintString1(humy);
            PrintString1("%RH\n");
            Delay1ms(1000);
            
            temp[0]=Table_LCD[tempH/10];
            temp[1]=Table_LCD[tempH%10];
            PrintString1("温度:");
            PrintString1(temp);
            PrintString1("℃\n");
            Delay(3);
            
            
            
        }
        
    }
}


void    SetTimer2Baudraye(u16 dat)    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
{
    AUXR &= ~(1<<4);    //Timer stop
    AUXR &= ~(1<<3);    //Timer2 set As Timer
    AUXR |=  (1<<2);    //Timer2 set as 1T mode
    TH2 = dat / 256;
    TL2 = dat % 256;
    IE2  &= ~(1<<2);    //禁止中断
    AUXR |=  (1<<4);    //Timer run enable
}

void    UART1_config(u8 brt)    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
{
    u8    i;
    /*********** 波特率使用定时器2 *****************/
    if(brt == 2)
    {
        AUXR |= 0x01;        //S1 BRT Use Timer2;
        SetTimer2Baudraye(65536UL - (MAIN_Fosc / 4) / UART_BaudRate1);
    }

    /*********** 波特率使用定时器1 *****************/
    else
    {
        TR1 = 0;
        AUXR &= ~0x01;        //S1 BRT Use Timer1;
        AUXR |=  (1<<6);    //Timer1 set as 1T mode
        TMOD &= ~(1<<6);    //Timer1 set As Timer
        TMOD &= ~0x30;        //Timer1_16bitAutoReload;
        TH1 = (65536UL - (MAIN_Fosc / 4) / UART_BaudRate1) / 256;
        TL1 = (65536UL - (MAIN_Fosc / 4) / UART_BaudRate1) % 256;
        ET1 = 0;    //禁止中断
        INT_CLKO &= ~0x02;    //不输出时钟
        TR1  = 1;
    }
    /*************************************************/

    SCON = (SCON & 0x3f) | (1<<6);    // 8位数据, 1位起始位, 1位停止位, 无校验
//    PS  = 1;    //高优先级中断
    ES  = 1;    //允许中断
    REN = 1;    //允许接收
    P_SW1 = P_SW1 & 0x3f;    //切换到 P3.0 P3.1
//    P_SW1 = (P_SW1 & 0x3f) | (1<<6);    //切换到P3.6 P3.7
//    P_SW1 = (P_SW1 & 0x3f) | (2<<6);    //切换到P1.6 P1.7 (必须使用内部时钟)

    for(i=0; i<RX1_Length; i++)        RX1_Buffer[i] = 0;
    B_TX1_Busy  = 0;
    TX1_read    = 0;
    RX1_write   = 0;
}

void    UART3_config(u8 brt)    // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer3做波特率.
{
    u8    i;
    /*********** 波特率固定使用定时器2 *****************/
    if(brt == 2)
    {
        S3CON &= ~(1<<6);    //BRT select Timer2
        SetTimer2Baudraye(65536UL - (MAIN_Fosc / 4) / UART_BaudRate3);
    }
    /*********** 波特率使用定时器3 *****************/
    else
    {
        S3CON |= (1<<6);    //BRT select Timer3
        T4T3M &= 0xf0;        //停止计数, 清除控制位
        IE2  &= ~(1<<5);    //禁止中断
        T4T3M |=  (1<<1);    //1T
        T4T3M &= ~(1<<2);    //定时
        T4T3M &= ~1;        //不输出时钟
        TH3 = (65536UL - (MAIN_Fosc / 4) / UART_BaudRate3) / 256;
        TL3 = (65536UL - (MAIN_Fosc / 4) / UART_BaudRate3) % 256;
        T4T3M |=  (1<<3);    //开始运行
    }
    
    S3CON &= ~(1<<5);    //禁止多机通讯方式
    S3CON &= ~(1<<7);    // 8位数据, 1位起始位, 1位停止位, 无校验
    IE2   |=  (1<<3);    //允许中断
    S3CON |=  (1<<4);    //允许接收
    P_SW2 &= ~2;        //切换到 P0.0 P0.1
//    P_SW2 |= 2;            //切换到 P5.0 P5.1

    for(i=0; i<RX3_Length; i++)        RX3_Buffer[i] = 0;
    B_TX3_Busy  = 0;
    TX3_read    = 0;
    RX3_write   = 0;
}


void PrintString1(u8 *puts)
{
    for (; *puts != 0;    puts++)
    {
        B_TX1_Busy = 1;        //标志发送忙
        SBUF = *puts;        //发一个字节
        while(B_TX1_Busy);    //等待发送完成
    }
}

void PrintString3(u8 *puts)
{
    for (; *puts != 0;    puts++)
    {
        B_TX3_Busy = 1;        //标志发送忙
        S3BUF = *puts;        //发一个字节
        while(B_TX3_Busy);    //等待发送完成
    }
}

/********************* UART1中断函数************************/
void UART1_int (void) interrupt UART1_VECTOR
{
    if(RI)
    {
        RI = 0;
        RX1_Buffer[RX1_write] = SBUF;
        if(++RX1_write >= RX1_Length)    RX1_write = 0;
    }

    if(TI)
    {
        TI = 0;
        B_TX1_Busy = 0;
    }
}
/********************* UART3中断函数************************/
void UART3_int (void) interrupt UART3_VECTOR
{
    if(RI3)
    {
        CLR_RI3();
        RX3_Buffer[RX3_write] = S3BUF;
        if(++RX3_write >= RX3_Length)    RX3_write = 0;
    }

    if(TI3)
    {
        CLR_TI3();
        B_TX3_Busy = 0;
    }

}

 

 完整版程序链接:https://download.csdn.net/download/huzibaba111/10655954

  • 0
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值