亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mysht10.c

?? sht10溫濕度傳感器采集顯示程序包含proteus仿真電路圖
?? C
字號:
/*********************************************************************************** 
;功能說明:SHT10-LED溫濕度顯示KeilC程序
;文件名稱:mysht10.c     
;微處理器:AT89C52
;編譯環境:Keil uVision V3.53 、uv2.38a均通過,proteus7.4sp3仿真正常。
;作    者:Huang qianjiang
;創建日期:2009.04.15    
;版    本:V1.0  
;修改日期:
;修改說明:
;***********************************************************************************/

/*************定義接口********************
         P0------ (高位led段)     
         P2------ (低位led段) 
         P1.1------SCK     (SHT10時鐘線)
         P1.0------DATA    (SHT10數據線)
         P1.6------(溫度顯示片選)
         P1.7------(濕度顯示片選)
         P1.5-------(蜂鳴器控制)
         P1.4-------(控制繼電器開關)
         P3.0、P3.1-------(串行口)
 
*****************************************/

#include <reg52.h> 
#include <intrins.h> 
#include <math.h>    //Keil library   
#include <stdio.h>   //Keil library 

//*********************第一部分LED設置****************************************

unsigned int wendu,shidu;

unsigned char code table_h[20]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,
                                 0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};
unsigned char code table_l[10]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};

sbit Tc = P1^7;  //溫度顯示控制,1=關,0=開
sbit Hc = P1^6;  //濕度顯示控制,1=關,0=開
/*sbit Yc = P1^5;  //蜂鳴器控制
sbit Jc = P1.4    //開關輸出
static unsigned char bdata StateREG;//可位尋址的輸出狀態寄存器
sbit YC1 = StateREG^0;           //是否有告警1
sbit YC2 = StateREG^1;           //是否告警2
sbit YC3 = StateREG^2;           //是否告警3
sbit JC1 = StateREG^3;         //是否開關
sbit QM = StateREG^4;     //P1.4輸出一定時間后(5分鐘),溫度上升小于3度告警4(缺煤)
*/
/******定義函數****************/
#define uchar unsigned char
#define uint unsigned int
void LED_init(void);           //LED初始化函數
void LED_xianshi(void);        //LED顯示函數
void delay_n10us(uint n);      //延時10uS函數
//void shuchu_kz(void);   //輸出控制函數
                          //中斷函數
                          //串口初始化函數
//void com_data(void);    //串口發送數據函數
//void GJ_sheng(void);    //告警聲音函數
/*-------------------------------------- 
;模塊名稱:LED_init(); 
;功    能:初始化LED、及端口 
;參數說明: 
;創建日期: 
;版    本:
;修改日期: 
;修改說明: 
;-------------------------------------*/ 
void LED_init(void)
{
  Tc = 1;
  Hc = 1;
  //Yc = 1;
  //  Jc = 1;
  //bdata StateREG = 0x00;
  P0=0xff ;//data_h = 0x80;
  P2=0xff ;//data_l = 0x00;
}

/*-------------------------------------- 
;模塊名稱:LED_xianshi(); 
;功    能:LED 顯示溫度、濕度
;參數說明:
;創建日期: 
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/
void LED_xianshi(void)
{
  uint i;
  uchar a,b,c,v,w; 
  for(i=0;i<51;i++)
  {
    Hc = 1;
    P0 = 0xff;
    P2 = 0xff;
    delay_n10us(200);
    Tc = 0;
    
    a = (wendu/1000);              //溫度百位
     b=((wendu%1000)/100);        //溫度十位
      c=((wendu%100)/10);        //溫度個位
         a = a*10+b;
         P0 = table_h[a];
         P2 = table_l[c];
  
          delay_n10us(1000);//延時10ms
          Tc = 1; 
          P0 = 0xff;
          P2 = 0xff;
          delay_n10us(200);
           Hc = 0;
           v=((shidu%1000)/100);  //濕度十位
           w=((shidu%100)/10);    //濕度個位
                 P0 = table_h[v];  
                 P2 = table_l[w];
                 delay_n10us(1000);
                 Hc = 1;
        }
}

/*-------------------------------------- 
;模塊名稱:delay_n10us(uint n); 
;功    能:延時10uS函數
;參數說明:延時n個10us
;創建日期: 
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/
void delay_n10us(uint n)  //延時n個10us@12M晶振
{       
        uint i;           
        for(i=n;i>0;i--)    
        {
        _nop_();_nop_();_nop_();_nop_();_nop_();_nop_(); 
  }
}  

/*-------------------------------------- 
;模塊名稱:shuchu_kz(void);    
;功    能:輸出控制函數
;參數說明:
;創建日期: 
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/
//void shuchu_kz(void)




/*-------------------------------------- 
;模塊名稱:com_data(void);  
;功    能:通過232向PC發送當前溫度、濕度、輸出控制狀態寄存器值等數據函數
;參數說明:固定地址01,波特率9600
;創建日期: 
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/
//void com_data(void)








//*********************第二部分SHT10設置  **************************************** 
sbit SCK  = P1^1;      //定義通訊時鐘端口
sbit DATA = P1^0;      //定義通訊數據端口

typedef union  
{ unsigned int i;      //定義了兩個共用體
  float f; 
} value; 

enum {TEMP,HUMI};      //TEMP=0,HUMI=1

#define noACK 0             //用于判斷是否結束SHT10通訊
#define ACK   1             //結束數據傳輸
                            //adr  command  r/w 
#define STATUS_REG_W 0x06   //000   0011    0 
#define STATUS_REG_R 0x07   //000   0011    1 
#define MEASURE_TEMP 0x03   //000   0001    1 
#define MEASURE_HUMI 0x05   //000   0010    1 
#define RESET        0x1e   //000   1111    0 

/****************定義函數****************/
void s_transstart(void);               //啟動傳輸函數
void s_connectionreset(void);          //連接復位函數
char s_write_byte(unsigned char value);//SHT10寫函數
char s_read_byte(unsigned char ack);   //SHT10讀函數
char s_measure(unsigned char *p_value, unsigned char *p_checksum, unsigned char mode);//測量溫濕度函數
void calc_dht10(float *p_humidity ,float *p_temperature);//溫濕度補償

/*-------------------------------------- 
;模塊名稱:s_transstart(); 
;功    能:啟動傳輸函數
;參數說明:
;創建日期: 
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/  
void s_transstart(void) 
  
//       _____         ________ 
// DATA:      |_______| 
//           ___     ___ 
// SCK : ___|   |___|   |______ 
{   
   DATA=1;     //初始狀態
    SCK=0;           
   _nop_(); 
   SCK=1; 
   _nop_(); 
   DATA=0; 
   _nop_(); 
   SCK=0;   
   _nop_();_nop_();_nop_(); 
   SCK=1; 
   _nop_(); 
   DATA=1;        
   _nop_(); 
   SCK=0;        
} 

/*-------------------------------------- 
;模塊名稱:s_connectionreset(); 
;功    能:連接復位函數
;參數說明:
;創建日期:
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/ 
void s_connectionreset(void) 
// 通訊復位: DATA-line=1 and at least 9 SCK cycles followed by transstart 
//       _____________________________________________________         ________ 
// DATA:                                                      |_______| 
//          _    _    _    _    _    _    _    _    _        ___     ___ 
// SCK : __| |__| |__| |__| |__| |__| |__| |__| |__| |______|   |___|   |______ 
{   
  unsigned char i;  //初始狀態
  DATA=1;
   SCK=0;                    
  for(i=0;i<9;i++)                  //9 SCK cycles 
  { 
    SCK=1;
    SCK=0; 
  } 
  s_transstart();                   //啟動傳輸
} 

/*-------------------------------------- 
;模塊名稱:s_write_byte(); 
;功    能:SHT10寫函數
;參數說明:
;創建日期: 
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/ 
char s_write_byte(unsigned char value) 
//---------------------------------------------------------------------------------- 
// writes a byte on the Sensibus and checks the acknowledge  
{  
  unsigned char i,error=0;   
  for (i=0x80;i>0;i/=2)             //shift bit for masking 
  {  
    if (i & value) DATA=1;          //masking value with i , write to SENSI-BUS 
    else DATA=0;                         
    SCK=1;                          //clk for SENSI-BUS 
    _nop_();_nop_();_nop_();        //pulswith approx. 3 us     
    SCK=0; 
  } 
  DATA=1;                           //release DATA-line 
  SCK=1;                            //clk #9 for ack  
  error=DATA;                       //check ack (DATA will be pulled down by SHT10),DATA在第9個上升沿將被SHT10自動下拉為低電平。 
  _nop_();_nop_();_nop_();
  SCK=0;
  DATA=1;                           //release DATA-line 
  return error;                     //error=1 in case of no acknowledge //返回:0成功,1失敗
} 

/*-------------------------------------- 
;模塊名稱:s_read_byte(); 
;功    能:SHT10讀函數
;參數說明:
;創建日期:
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/ 
char s_read_byte(unsigned char ack)  
// reads a byte form the Sensibus and gives an acknowledge in case of "ack=1"  
{  
  unsigned char i,val=0; 
  DATA=1;                           //release DATA-line 
  for (i=0x80;i>0;i/=2)             //shift bit for masking 
  { SCK=1;                          //clk for SENSI-BUS 
    if (DATA) val=(val | i);        //read bit   
 _nop_();_nop_();_nop_();        //pulswith approx. 3 us
    SCK=0;              
  } 
  if(ack==1)DATA=0;                 //in case of "ack==1" pull down DATA-Line 
  else DATA=1;                      //如果是校驗(ack==0),讀取完后結束通訊
  _nop_();_nop_();_nop_();          //pulswith approx. 3 us 
  SCK=1;                            //clk #9 for ack 
  _nop_();_nop_();_nop_();          //pulswith approx. 3 us  
  SCK=0;                 
  _nop_();_nop_();_nop_();          //pulswith approx. 3 us 
  DATA=1;                           //release DATA-line 
  return val; 
} 

/*-------------------------------------- 
;模塊名稱:s_measure(); 
;功    能:測量溫濕度函數
;參數說明:
;創建日期:
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/ 
char s_measure(unsigned char *p_value, unsigned char *p_checksum, unsigned char mode) 
// makes a measurement (humidity/temperature) with checksum 
{  
  unsigned error=0; 
  unsigned int i; 
 
  s_transstart();                   //啟動傳輸 
  switch(mode){                     //發送命令 
    case TEMP  : error+=s_write_byte(MEASURE_TEMP); break; 
    case HUMI  : error+=s_write_byte(MEASURE_HUMI); break; 
    default     : break;    
  } 
  for (i=0;i<65535;i++) if(DATA==0) break; //等待完成測量 
  if(DATA) error+=1;                // 或超時 (約2 sec.)
  *(p_value)  =s_read_byte(ACK);    //讀首字節 (MSB) 
  *(p_value+1)=s_read_byte(ACK);    //讀第二字節 (LSB) 
  *p_checksum =s_read_byte(noACK);  //讀檢查和 
  return error; 
} 

/*-------------------------------------- 
;模塊名稱:calc_dht10(); 
;功    能:溫濕度補償計算函數
;參數說明:
;創建日期:
;版    本:
;修改日期:
;修改說明:
;-------------------------------------*/ 
void calc_dht10(float *p_humidity ,float *p_temperature)
// calculates temperature [C] and humidity [%RH] 
// input :  humi [Ticks] (12 bit) 
//          temp [Ticks] (14 bit)
// output:  humi [%RH]
//          temp [C]
{ const float C1=-4.0;              // for 12 Bit (-4.0)
  const float C2=+0.0405;           // for 12 Bit
  const float C3=-0.0000028;        // for 12 Bit(-0.0000028)
  const float T1=+0.01;             // for 14 Bit @ 5V
  const float T2=+0.00008;           // for 14 Bit @ 5V 

  float rh=*p_humidity;             // rh:      Humidity [Ticks] 12 Bit 
  float t=*p_temperature;           // t:       Temperature [Ticks] 14 Bit
  float rh_lin;                     // rh_lin:  Humidity linear
  float rh_true;                    // rh_true: Temperature compensated humidity
  float t_C;                        // t_C   :  Temperature [C]

  t_C=t*0.01 - 40;                  //calc. temperature from ticks to [C]
  rh_lin=C3*rh*rh + C2*rh + C1;     //calc. humidity from ticks to [%RH]
  rh_true=(t_C-25)*(T1+T2*rh)+rh_lin;   //calc. temperature compensated humidity [%RH]
  if(rh_true>99)rh_true=99;       //cut if the value is outside of//100
  if(rh_true<0.1)rh_true=0.1;       //the physical possible range

  *p_temperature=t_C;               //return temperature [C]
  *p_humidity=rh_true;              //return humidity[%RH]
}

//*********主函數*****************
void main(void)
{
        value humi_val,temp_val;
        unsigned char error,checksum; 
        
        LED_init(); //LED初始化
        s_connectionreset(); //連接復位SHT10
        
        while(1) 
        { 
          error=0; 
          error+=s_measure((unsigned char*) &humi_val.i,&checksum,HUMI);  //measure humidity 
          error+=s_measure((unsigned char*) &temp_val.i,&checksum,TEMP);  //measure temperature 
          if(error!=0)
		   {
		     P0 = 0x86;           //如果出錯,溫度LED顯示“E0”
		     P2 = 0xc0;                    
		     Tc = 0;
		     s_connectionreset();
			 }        //重新連接復位
            else 
              { 
                humi_val.f=(float)humi_val.i;         //轉換濕度為浮點
                 temp_val.f=(float)temp_val.i;         //轉換溫度為浮點
                   calc_dht10(&humi_val.f,&temp_val.f);    //計算濕度、溫度
                 wendu=10*temp_val.f + 5;             //+5為小數位4舍5入
                 shidu=10*humi_val.f;
              
               /*if(wendu>70 || shidu<40)
                  {
                    YC3 = 1;
                   }
                  else if(wendu>60 || shidu<30)
                   {
                     YC2 = 1;
                    }
                  else if(wendu>50 || shidu<20)
                   {
                     YC1 = 1;
                    }
                  else if(wendu<70 || shidu>50)
                   {
                     JC1 = 1;
                    }
                  else if(bdata StateREG != 0)
                   {
                     shuchu_kz();   //輸出控制函數
                    else    //bdata StateREG = 0x00;
                    com_data();   //232發送數據函數
                        */
            
                LED_xianshi();     //LED顯示
                      
               } 
                
         delay_n10us(100000);                     //延時約1s
         }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区在线视频观看| 欧美日韩精品电影| 国产乱国产乱300精品| 青青草国产成人av片免费| 亚洲1区2区3区4区| 婷婷综合另类小说色区| 午夜国产不卡在线观看视频| 亚洲综合在线第一页| 亚洲电影一区二区三区| 亚洲电影一区二区三区| 免费高清视频精品| 国产精品自在在线| 成人免费毛片a| 91在线观看高清| 在线视频国内一区二区| 欧美日产在线观看| 精品少妇一区二区三区在线视频| 亚洲精品一区二区三区香蕉| 久久精品人人做人人综合 | 国产一区欧美日韩| 国产传媒欧美日韩成人| 菠萝蜜视频在线观看一区| 色综合久久88色综合天天免费| 欧美性xxxxx极品少妇| 欧美日韩国产影片| 欧美极品美女视频| 一区二区三区欧美视频| 日韩电影免费一区| jlzzjlzz国产精品久久| 欧美日韩国产首页在线观看| 欧美成人精品3d动漫h| 国产精品国产三级国产普通话蜜臀| 亚洲一区在线观看免费观看电影高清| 午夜精品影院在线观看| 国产精品18久久久久久久久| 色婷婷久久久久swag精品| 日韩精品专区在线影院重磅| 亚洲人成人一区二区在线观看| 爽好多水快深点欧美视频| 丰满少妇在线播放bd日韩电影| 欧美日韩一区国产| 中文字幕成人av| 青青青爽久久午夜综合久久午夜| 99久久国产免费看| 日韩免费高清av| 亚洲香肠在线观看| 成人精品在线视频观看| 精品久久久久一区二区国产| 亚洲一区在线观看免费观看电影高清| 国产制服丝袜一区| 欧美福利电影网| 亚洲欧美视频在线观看视频| 国产一区二区久久| 日韩一区二区免费视频| 亚洲精品福利视频网站| 成人黄色片在线观看| 91麻豆精品国产自产在线观看一区 | 欧美色倩网站大全免费| 国产亚洲婷婷免费| 图片区小说区国产精品视频| 99精品视频一区| 国产人成亚洲第一网站在线播放| 麻豆精品一区二区综合av| 欧美午夜精品久久久久久超碰| 中日韩免费视频中文字幕| 国内精品伊人久久久久av影院 | 色婷婷综合中文久久一本| 久久五月婷婷丁香社区| 日本麻豆一区二区三区视频| 一本色道久久综合亚洲精品按摩| 欧美韩日一区二区三区| 国产a视频精品免费观看| 亚洲精品一区二区三区蜜桃下载| 天天综合色天天综合| 欧美午夜免费电影| 一区二区三区四区激情| 99精品国产99久久久久久白柏| 国产亚洲欧美日韩日本| 国产激情精品久久久第一区二区| 精品三级在线看| 男人的j进女人的j一区| 91精品国产综合久久久久| 午夜精品一区在线观看| 欧美一区二区三区免费在线看 | 国产日韩欧美综合一区| 国产乱码精品一品二品| 国产欧美日韩三区| av午夜精品一区二区三区| 国产精品国产三级国产aⅴ中文 | 精品一区二区影视| 精品捆绑美女sm三区| 国产一区二区在线视频| 国产午夜精品久久久久久久| 国产精品自拍一区| 自拍偷拍欧美激情| 欧洲精品中文字幕| 免费人成黄页网站在线一区二区 | 91小视频免费观看| 亚洲精品视频免费看| 欧美日韩精品二区第二页| 久久精工是国产品牌吗| 国产色婷婷亚洲99精品小说| 99久久精品国产网站| 亚洲高清三级视频| 久久精品视频一区二区| 91视频国产资源| 紧缚捆绑精品一区二区| 国产精品久久久久久亚洲伦| 欧美日韩成人综合| 国产成人亚洲综合a∨婷婷| 亚洲精品视频在线观看免费| 欧美一级免费大片| 99精品视频在线播放观看| 日产精品久久久久久久性色| 国产精品三级视频| 91精品国产乱| 成人精品亚洲人成在线| 天天综合色天天综合| 亚洲欧洲日本在线| 日韩欧美国产综合| 在线免费视频一区二区| 国产一区三区三区| 爽好多水快深点欧美视频| 亚洲欧美在线aaa| 在线这里只有精品| 高清国产午夜精品久久久久久| 亚洲风情在线资源站| 日本一区二区三区dvd视频在线| 欧洲中文字幕精品| 成人av小说网| 国内不卡的二区三区中文字幕| 亚洲一卡二卡三卡四卡无卡久久 | 欧美日韩精品一区二区| 99久久免费精品高清特色大片| 日本网站在线观看一区二区三区 | 欧美久久久久久蜜桃| 成人美女在线观看| 精品一区二区三区免费毛片爱| 亚洲一区二区三区影院| 亚洲欧洲精品一区二区三区| 精品盗摄一区二区三区| 欧美久久高跟鞋激| 欧美在线观看视频在线| 97精品电影院| 99麻豆久久久国产精品免费 | 蜜臀久久久久久久| 一区二区三区在线播| 中文文精品字幕一区二区| 久久久蜜桃精品| 久久久天堂av| 欧美经典一区二区| 国产精品高潮呻吟| 中文字幕欧美区| 国产精品久久久久久久久果冻传媒 | 欧美男女性生活在线直播观看| 色婷婷狠狠综合| 91久久一区二区| 在线一区二区三区四区| 在线观看欧美黄色| 色就色 综合激情| 91豆麻精品91久久久久久| 欧美性受xxxx黑人xyx| 91激情在线视频| 欧美在线播放高清精品| 欧美中文字幕亚洲一区二区va在线| 91在线小视频| 欧洲一区二区三区在线| 欧美午夜电影在线播放| 91精品欧美久久久久久动漫| 日韩精品一区二区三区中文不卡| 在线播放91灌醉迷j高跟美女 | ...av二区三区久久精品| 亚洲男人天堂av| 日日摸夜夜添夜夜添国产精品| 日本最新不卡在线| 国产精品77777| 99久久夜色精品国产网站| 一本色道综合亚洲| 欧美一区二区免费视频| 国产亚洲一二三区| 亚洲一区av在线| 国产一区二区在线观看免费| 99久久国产综合精品色伊| 欧美人xxxx| 国产午夜精品一区二区三区视频| **欧美大码日韩| 日日骚欧美日韩| www.视频一区| 日韩小视频在线观看专区| 亚洲国产精品成人综合| 亚洲欧美国产毛片在线| 奇米四色…亚洲| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 欧美成人欧美edvon| 一区二区中文视频| 久久精品国产色蜜蜜麻豆| 一本久道中文字幕精品亚洲嫩| 91精品免费在线观看| 亚洲免费色视频| 国产成人无遮挡在线视频|