久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

標題: STC15F2K60S2單片機雨滴感應器AO信號如何用自帶的AD口接受? [打印本頁]

作者: NUO1234456789    時間: 2023-5-31 20:10
標題: STC15F2K60S2單片機雨滴感應器AO信號如何用自帶的AD口接受?
如題 雨滴感應器不是有AO口嗎 我想用它來測量雨量的大小(用自帶的AD) 請問如何可以做到
有代碼最好 我是小白 謝謝各位大神!

作者: csmyldl    時間: 2023-5-31 23:58
雨滴感應器輸出的是電壓還是電流信號?如果是電壓信號,可接P1.0-P1.7任意一路采集轉換
作者: chxelc    時間: 2023-6-1 08:04
以下是來自官方的示例程序 供參考


/*---------------------------------------------------------------------*/
/* --- STC MCU Limited ------------------------------------------------*/
/* --- STC15F4K60S4 系列 AD轉換查詢方式舉例----------------------------*/
/* 如果要在程序中使用此代碼,請在程序中注明使用了STC的資料及程序        */
/* 如果要在文章中應用此代碼,請在文章中注明使用了STC的資料及程序        */
/*---------------------------------------------------------------------*/

//本示例在Keil開發環境下請選擇Intel的8058芯片型號進行編譯
//若無特別說明,工作頻率一般為11.0592MHz


#include "reg51.h"
#include "intrins.h"

#define FOSC    11059200L
#define BAUD    115200

typedef unsigned char BYTE;
typedef unsigned int WORD;

#define     URMD    0           //0:使用定時器2作為波特率發生器
                                //1:使用定時器1的模式0(16位自動重載模式)作為波特率發生器
                                //2:使用定時器1的模式2(8位自動重載模式)作為波特率發生器

sfr T2H   = 0xd6;               //定時器2高8位
sfr T2L   = 0xd7;               //定時器2低8位

sfr P1M1 = 0x91;    //PxM1.n,PxM0.n     =00--->Standard,    01--->push-pull
sfr P1M0 = 0x92;    //                  =10--->pure input,  11--->open drain
sfr P0M1 = 0x93;
sfr P0M0 = 0x94;
sfr P2M1 = 0x95;
sfr P2M0 = 0x96;
sfr P3M1 = 0xB1;
sfr P3M0 = 0xB2;
sfr P4M1 = 0xB3;
sfr P4M0 = 0xB4;
sfr P5M1 = 0xC9;
sfr P5M0 = 0xCA;
sfr P6M1 = 0xCB;
sfr P6M0 = 0xCC;
sfr P7M1 = 0xE1;
sfr P7M0 = 0xE2;

sfr  AUXR       =   0x8e;       //輔助寄存器                              

sfr ADC_CONTR   =   0xBC;           //ADC控制寄存器
sfr ADC_RES     =   0xBD;           //ADC高8位結果
sfr ADC_LOW2    =   0xBE;           //ADC低2位結果
sfr P1ASF       =   0x9D;           //P1口第2功能控制寄存器

#define ADC_POWER   0x80            //ADC電源控制位
#define ADC_FLAG    0x10            //ADC完成標志
#define ADC_START   0x08            //ADC起始控制位
#define ADC_SPEEDLL 0x00            //540個時鐘
#define ADC_SPEEDL  0x20            //360個時鐘
#define ADC_SPEEDH  0x40            //180個時鐘
#define ADC_SPEEDHH 0x60            //90個時鐘

void InitUart();
void InitADC();
void SendData(BYTE dat);
BYTE GetADCResult(BYTE ch);
void Delay(WORD n);
void ShowResult(BYTE ch);

void main()
{
    P0M0 = 0x00;
    P0M1 = 0x00;
    P1M0 = 0x00;
    P1M1 = 0x00;
    P2M0 = 0x00;
    P2M1 = 0x00;
    P3M0 = 0x00;
    P3M1 = 0x00;
    P4M0 = 0x00;
    P4M1 = 0x00;
    P5M0 = 0x00;
    P5M1 = 0x00;
    P6M0 = 0x00;
    P6M1 = 0x00;
    P7M0 = 0x00;
    P7M1 = 0x00;

    InitUart();                     //初始化串口
    InitADC();                      //初始化ADC
    while (1)
    {
        ShowResult(0);              //顯示通道0
        ShowResult(1);              //顯示通道1
        ShowResult(2);              //顯示通道2
        ShowResult(3);              //顯示通道3
        ShowResult(4);              //顯示通道4
        ShowResult(5);              //顯示通道5
        ShowResult(6);              //顯示通道6
        ShowResult(7);              //顯示通道7
    }
}

/*----------------------------
發送ADC結果到PC
----------------------------*/
void ShowResult(BYTE ch)
{
    SendData(ch);                   //顯示通道號
    SendData(GetADCResult(ch));     //顯示ADC高8位結果

//    SendData(ADC_LOW2);           //顯示低2位結果
}

/*----------------------------
讀取ADC結果
----------------------------*/
BYTE GetADCResult(BYTE ch)
{
    ADC_CONTR = ADC_POWER | ADC_SPEEDLL | ch | ADC_START;
    _nop_();                        //等待4個NOP
    _nop_();
    _nop_();
    _nop_();
    while (!(ADC_CONTR & ADC_FLAG));//等待ADC轉換完成
    ADC_CONTR &= ~ADC_FLAG;         //Close ADC

    return ADC_RES;                 //返回ADC結果
}

/*----------------------------
初始化串口
----------------------------*/
void InitUart()
{
    SCON = 0x5a;                //設置串口為8位可變波特率
#if URMD == 0
    T2L = (65536 - (FOSC/4/BAUD));
    T2H = (65536 - (FOSC/4/BAUD)) >> 8;
    AUXR = 0x14;                //T2為1T模式, 并啟動定時器2
    AUXR |= 0x01;               //選擇定時器2為串口1的波特率發生器
#elif URMD == 1
    AUXR = 0x40;                //定時器1為1T模式
    TMOD = 0x00;                //定時器1為模式0(16位自動重載)
    TL1 = (65536 - (FOSC/4/BAUD));
    TH1 = (65536 - (FOSC/4/BAUD)) >> 8;
    TR1 = 1;                    //定時器1開始啟動
#else
    TMOD = 0x20;                //設置定時器1為8位自動重裝載模式
    AUXR = 0x40;                //定時器1為1T模式
    TH1 = TL1 = (256 - (FOSC/32/BAUD));
    TR1 = 1;
#endif
}

/*----------------------------
初始化ADC
----------------------------*/
void InitADC()
{
    P1ASF = 0xff;                   //設置P1口為AD口
    ADC_RES = 0;                    //清除結果寄存器
    ADC_CONTR = ADC_POWER | ADC_SPEEDLL;
    Delay(2);                       //ADC上電并延時
}

/*----------------------------
發送串口數據
----------------------------*/
void SendData(BYTE dat)
{
    while (!TI);                    //等待前一個數據發送完成
    TI = 0;                         //清除發送標志
    SBUF = dat;                     //發送當前數據
}

/*----------------------------
軟件延時
----------------------------*/
void Delay(WORD n)
{
    WORD x;

    while (n--)
    {
        x = 5000;
        while (x--);
    }
}


作者: man1234567    時間: 2023-6-1 17:29
雨滴感應器就是有再多的AO口,也不方便測量雨量大小。
雨滴感應器是為測有雨而設計的,有雨和有多大雨并不是一回事。
就象微波感應人體一樣,只要有人就報警,但一般無法分辨出有多少人。
作者: NUO1234456789    時間: 2023-6-1 19:03
chxelc 發表于 2023-6-1 08:04
以下是來自官方的示例程序 供參考

非常感謝 那怎么用它采集的數據 在LCD12864上顯示呢 小弟就是不知道怎么把它的數據給采集到
作者: wulin    時間: 2023-6-1 21:05
市售的雨滴傳感器模塊,其傳感器只是一片叉指型電極的電路板。雨水滴落到上面構成叉指間導電,從而檢測到有雨,但不能有效測量雨量的大小。如果用自帶AD的單片機可以代替傳感器模塊電路,只要用一個電阻與叉指型電極的電路板串聯,取分壓信號判斷即可。




歡迎光臨 (http://www.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 91精品国产91久久久久久最新 | 久在草 | 一区二区三区四区在线 | 亚洲一区二区电影网 | 亚洲第一区国产精品 | 久久久久久久久久久久久久av | 香蕉超碰 | 91人人爽| 国产福利网站 | 精品一区av | 四虎免费视频 | 国产精品国产成人国产三级 | 国产午夜精品久久久 | 国产日韩欧美激情 | 久久国产成人 | 黑人巨大精品欧美一区二区免费 | 精品久久久久久久久久久久久久 | 久久久精品一区 | 亚洲a人| 日韩视频国产 | 视频在线一区二区 | 欧美成人a| 国产情侣激情 | 国产9 9在线 | 中文 | 成人国产精品久久久 | 亚洲成人av在线播放 | 999国产精品视频 | 本道综合精品 | 久久99精品久久久久久 | 日本久久精 | 另类二区 | 尤物在线精品视频 | 中文字幕 国产精品 | 午夜专区 | 天天狠狠 | 日本免费在线 | 亚洲三级在线观看 | 91国产在线播放 | 不卡的av在线 | 日本三级全黄三级三级三级口周 | 久久久久久久亚洲精品 |