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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1005|回復: 1
打印 上一主題 下一主題
收起左側

測溫寶盒--紅外溫度

[復制鏈接]
跳轉到指定樓層
樓主
ID:451622 發(fā)表于 2018-12-21 16:26 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
#include <reg51.h>
#include"intrins.h"

//************************************
#define uint unsigned int
#define uchar unsigned char
#define Nack_counter 10

//**************端口定義**************
sbit SCL=P1^2;//時鐘線
sbit SDA=P1^1;//數據線
sbit SCL1=P1^4;
sbit SDA1=P1^3;
sbit LED=P2^3;      //檢測溫度指示燈

//************數據定義****************
uchar flag1;
bdata uchar flag;//可位尋址數據
sbit bit_out=flag^7;
sbit bit_in=flag^0;
sbit rw = P2^1;
sbit rs=P2^0;
sbit LCD_EN  = P2^2;
sbit PSB = P2^7;
uchar code  dis1[ ] = {"測溫寶盒"};
uchar code  dis2[ ] = {"Chen Chaowen"};
uchar code dis3[]={"溫度: "};
uchar code dis4[]={"℃"};
uchar code dis5[]={"溫馨提示:"};
uchar code dis6[]={"檢測結束"};
uchar DataH,DataL,Pecreg,j;
uchar condition,condition1,condition2,last,K;//溫度十位,個位提取及合成。


//************函數聲明*****************************************
void start_bit(); //MLX90614 發(fā)起始位子程序
void stop_bit(); //MLX90614 發(fā)結束位子程序
uchar rx_byte(void); //MLX90614 接收字節(jié)子程序
void send_bit(void); //MLX90614 發(fā)送位子程序
void tx_byte(uchar dat_byte); //MLX90614 接收字節(jié)子程序
void receive_bit(void); //MLX90614 接收位子程序
uint memread(void); //讀溫度數據
uchar rx_byte1(void); //MLX90614 接收字節(jié)子程序
void send_bit1(void); //MLX90614 發(fā)送位子程序
void tx_byte1(uchar dat_byte); //MLX90614 接收字節(jié)子程序
void receive_bit1(void); //MLX90614 接收位子程序
uint memread1(void); //讀溫度數據
uint compute();
void writecom(uchar com);
void writedat(uchar dat);
void init();
void first();
void delay(uint z);
void Close();          //關閉檢測
void display(uint Tem);
void Judge();//自動復位判斷
void display1(uint Tem);//轉換不顯示
//*************主函數**************************************

void InitTimer0(void)
{
    TMOD = 0x01;
    TH0 = (65535-45872)/256;
    TL0 = (65535-445872)%256;
    EA = 1;
    ET0 = 1;
    TR0 = 1;
}
void Timer0Interrupt(void) interrupt 1
{
    TH0 = (65535-45872)/256;
    TL0 = (65535-445872)%256;
    j++;
}
void main()
{
    uchar i,k=0;;
    SCL=1;
    delay(10);
    SDA=1;
    delay(10);
    SCL=0;
    delay(10);
    SCL=1;
    delay(10);
    InitTimer0();

    init();
    first();
    delay(100000);
    init();
    while(1)
    {
        LED=0;   
        writecom(0x88+0x43);                    //設置顯示位置為第一行的第1個字符
        i = 0;
        while(dis3[i] != '\0')//
        {
            LED=0;
            writedat(dis3[i]);          //顯示字符" 溫度: "
            i++;
            delay(30);                     //控制兩字之間顯示速度
        }
        writecom(0x98+0X42);               //設置顯示位置為第二行第4個字符
        display(compute());     //顯示攝氏度
        Judge();
        delay(100);
        writecom(0x98+0X45);                 //設置顯示位置為第二行第9個字符
        i = 0;
        while(dis4[i] != '\0')
        {
            LED=0;
            writedat(dis4[i]);          //顯示字符"℃"
            i++;
                delay(30);                     //控制兩字之間顯示速度
        }
        delay(1000);
        if(j>=200)//10秒
        {
            K=1;
            Close();
            delay(10000);
            while(1)//熄屏判斷
            {
                init();
                LED=1;
                display1(compute());   
                 Judge();
                if(K==0)break;
            }
        }
    }
}

//*********求數值平均與最高值*******
uint compute()
{
    long int sum1=0,sum2=0;
    int sum_aver,aver1,aver2;
    uchar i;
    for(i=0;i<5;i++)
    {
        sum1=sum1+memread();
        delay(5);//取值間隔時間
    }
    for(i=0;i<5;i++)
    {
        sum2=sum2+memread1();
        delay(5);//取值間隔時間
    }
    aver1=sum1/5;
    aver2=sum2/5;
    if(aver1>=aver2)sum_aver=aver1;
    else sum_aver=aver2;
    return(sum_aver);
}

//*********輸入轉換并顯示*********
void display(uint Tem)
{
    uint T,a,b;
    T=Tem*2;

    if(T>=27315)
    {
        T=T-27315;
        a=T/100;
        b=T-a*100;
        
        if(a>=100)
        {
            writedat(0x30+a/100);    //百位顯示
            a=a%100;
            writedat(0x30+a/10);        //十位顯示
            a=a%10;
            writedat(0x30+a);        //個位顯示
        }
        else if(a>=10)
        {
            writedat(0x30+a/10);
            condition1=a/10;
            a=a%10;
            writedat(0x30+a);
            condition2=a;
        }
        else
        {
            writedat(0x30+a);
        }
        writedat(0x2e);//顯示點
        if(b>=10)
        {
            writedat(0x30+b/10);
            writedat(0x30+b%10);
        }
        else
        {
            writedat(0x30);
        }
    }
    else
    {
        T=27315-T;
        a=T/100;
        b=T-a*100;
        writedat(0x2d);

        if(a>=10)
        {
            writedat(0x30+a/10);
            a=a%10;
            writedat(0x30+a);
        }
        else
        {
            writedat(0x30+a);
        }
        writedat(0x2e);//顯示點
   
        if(b>=10)
        {
            writedat(0x30+b/10);
            b=b%10;
            writedat(0x30+b);
        }
        else
        {
            writedat(0x30);
            writedat(0x30+b);
        }
    }
}
void display1(uint Tem)//轉換不顯示
{
    uint T,a,b;
    T=Tem*2;

    if(T>=27315)
    {
        T=T-27315;
        a=T/100;
        b=T-a*100;
        if(a>=10)
        {
            condition1=a/10;
            a=a%10;
            condition2=a;
        }
    }
}



//****************mlx90614啟動函數
void start_bit(void)
{
    SDA=SDA1=1;
    _nop_();_nop_();_nop_();_nop_();_nop_();
    SCL=SCL1=1;
    _nop_();_nop_();_nop_();_nop_();_nop_();
    SDA=SDA1=0;
    _nop_();_nop_();_nop_();_nop_();_nop_();
    SCL=SCL1=0;
    _nop_();_nop_();_nop_();_nop_();_nop_();
}

//-----------------mlx90614終止函數
void stop_bit(void)
{
    SCL=SCL1=0;
    _nop_();_nop_();_nop_();_nop_();_nop_();
    SDA=SDA1=0;
    _nop_();_nop_();_nop_();_nop_();_nop_();
    SCL=SCL1=1;
    _nop_();_nop_();_nop_();_nop_();_nop_();
    SDA=SDA1=1;
    }


//---------發(fā)送一個字節(jié)---------
void tx_byte(uchar dat_byte)
{
    char i,n,dat;
    n=Nack_counter;
    TX_again:
    dat=dat_byte;
    for(i=0;i<8;i++)
    {
    if(dat&0x80)
    bit_out=1;
    else
    bit_out=0;
    send_bit();
    dat=dat<<1;
    }
    receive_bit();
    if(bit_in==1)
    {
    stop_bit();
    if(n!=0)
    {n--;goto Repeat;}
    else
    goto exit;
    }
    else
    goto exit;
    Repeat:
    start_bit();
    goto TX_again;
    exit: ;
}
void tx_byte1(uchar dat_byte)
{
    char i,n,dat;
    n=Nack_counter;
    TX_again:
    dat=dat_byte;
    for(i=0;i<8;i++)
    {
    if(dat&0x80)
    bit_out=1;
    else
    bit_out=0;
    send_bit1();
    dat=dat<<1;
    }
    receive_bit1();
    if(bit_in==1)
    {
    stop_bit();
    if(n!=0)
    {n--;goto Repeat;}
    else
    goto exit;
    }
    else
    goto exit;
    Repeat:
    start_bit();
    goto TX_again;
    exit: ;
}

//-----------發(fā)送一個位---------
void send_bit(void)
{
    if(bit_out==0)
    SDA=0;
    else
    SDA=1;
    _nop_();
    SCL=1;
    _nop_();_nop_();_nop_();_nop_();
    _nop_();_nop_();_nop_();_nop_();
    SCL=0;
    _nop_();_nop_();_nop_();_nop_();
    _nop_();_nop_();_nop_();_nop_();
}
void send_bit1(void)
{
    if(bit_out==0)
    SDA1=0;
    else                  
    SDA1=1;
    _nop_();
    SCL1=1;
    _nop_();_nop_();_nop_();_nop_();
    _nop_();_nop_();_nop_();_nop_();
    SCL1=0;
    _nop_();_nop_();_nop_();_nop_();
    _nop_();_nop_();_nop_();_nop_();
}


//----------接收一個字節(jié)--------
uchar rx_byte(void)
{
    uchar i,dat;
    dat=0;
    for(i=0;i<8;i++)
    {
    dat=dat<<1;
    receive_bit();
    if(bit_in==1)
    dat=dat+1;
    }
    send_bit();
    return dat;
}
uchar rx_byte1(void)
{
    uchar i,dat;
    dat=0;
    for(i=0;i<8;i++)
    {
    dat=dat<<1;
    receive_bit1();
    if(bit_in==1)
    dat=dat+1;
    }
    send_bit1();
    return dat;
}

//----------接收一個位----------
void receive_bit(void)
{
    SDA=1;bit_in=1;
    SCL=1;
    _nop_();_nop_();_nop_();_nop_();
    _nop_();_nop_();_nop_();_nop_();
    bit_in=SDA;
    _nop_();
    SCL=0;
    _nop_();_nop_();_nop_();_nop_();
    _nop_();_nop_();_nop_();_nop_();
}
void receive_bit1(void)
{
    SDA1=1;bit_in=1;
    SCL1=1;
    _nop_();_nop_();_nop_();_nop_();
    _nop_();_nop_();_nop_();_nop_();
    bit_in=SDA1;
    _nop_();
    SCL1=0;
    _nop_();_nop_();_nop_();_nop_();
    _nop_();_nop_();_nop_();_nop_();
}

uint memread(void)
{
    start_bit();
    tx_byte(0x00); //Send SlaveAddress
    tx_byte(0x07); //Send Command

    start_bit();
    tx_byte(0x01);
    bit_out=0;
    DataL=rx_byte();
    bit_out=0;
    DataH=rx_byte();
    bit_out=1;
    Pecreg=rx_byte();
    stop_bit();
    return(DataH*256+DataL);
}
uint memread1(void)
{
    start_bit();
    tx_byte1(0x00); //Send SlaveAddress
    tx_byte1(0x07); //Send Command

    start_bit();
    tx_byte1(0x01);
    bit_out=0;
    DataL=rx_byte1();
    bit_out=0;
    DataH=rx_byte1();
    bit_out=1;
    Pecreg=rx_byte1();
    stop_bit();
    return(DataH*256+DataL);
}
void init()//12864初始化
{
    PSB=1;  
    writecom(0x30);
    writecom(0x0c);
    writecom(0x01);

}
void writecom(uchar com)//12864寫入命令
{
    rs = 0;
    rw = 0;
    LCD_EN = 0;
    P0 = com;
    delay(5);
    LCD_EN = 1;
    delay(5);
    LCD_EN = 0;
}

void writedat(uchar dat)//12864寫入數據
{
    rs = 1;
    rw = 0;
    LCD_EN=0;
    P0 = dat;
    delay(5);
    LCD_EN = 1;
    delay(5);
    LCD_EN = 0;
}
void delay(uint z)
{
    uint x,y;
    for(x=z;x>0;x--)
    for(y=10;y>0;y--);
}
void first()//12864開始顯示
{
    uchar num;
    init();
    writecom(0x80+0x42);
    for(num=0;num<8;num++)
    {      LED=0;
           writedat(dis1[num]);
        delay(1000);
    }
    writecom(0x90+0x41);
    for(num=0;num<13;num++)
    {      LED=0;
        writedat(dis2[num]);
        delay(1000);
    }
}
void Close()//12864顯示檢測結束
{      
    uchar num;
    init();
    writecom(0x80+0x42);
    for(num=0;num<10;num++)
    {    LED=0;
        writedat(dis5[num]);
        delay(1000);
    }
    writecom(0x90+0x42);
    for(num=0;num<8;num++)
    {    LED=0;
        writedat(dis6[num]);
        delay(1000);
    }
}
void Judge()
{
    last=condition;
    condition=condition1+condition2;
    if((condition>=last+2)||(condition<=last-2))
    {
        j=0;
        K=0;
    }
}




分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發(fā)
ID:1 發(fā)表于 2018-12-21 18:01 | 只看該作者
補全原理圖或者詳細說明一下電路連接即可獲得100+黑幣
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 成人精品毛片国产亚洲av十九禁 | 四虎影院美女 | 亚洲一区久久 | 日韩中文字幕在线播放 | 一区二区在线不卡 | 2020亚洲天堂 | 91视频免费观看 | www.操com| 在线视频一区二区 | 91看片网 | 成人午夜在线 | 日韩中文一区二区三区 | 国产一级特黄真人毛片 | 国产精品毛片一区二区在线看 | 欧美a在线| 国产高清精品一区二区三区 | 精品国产乱码久久久久久牛牛 | 日韩精品中文字幕一区二区三区 | 91在线播 | 国产精品国产 | 日韩三级电影在线看 | 日韩精品一区二区三区中文字幕 | 99久久精品免费看国产免费软件 | 中文字幕日韩一区 | 国产视频福利在线观看 | 久久久久国产一区二区三区 | 99热精品在线观看 | 亚洲一区二区电影网 | 婷婷国产一区 | 97伦理电影网 | 亚洲第一视频网站 | 亚洲a在线观看 | 久久福利电影 | 久视频在线观看 | 亚洲高清在线观看 | 在线观看视频一区二区三区 | 国产免费一二三区 | 亚洲天堂成人在线视频 | 在线看一区二区 | 成人午夜高清 | 精品www|