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

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

?? shtxx.c

?? 用單片機M8和傳感器H10來測量溫濕度
?? C
字號:
/******************************************************************************
**Name: 	SHTXX驅動程序
**note:		ATmega8@1.0Mhz
**compiler:	IccAVR
**Verson:	v1.0		
**Date:		2008.08.31
**By:		Eason

******************************************************************************/

#include		"main.h"

//外部全局變量,main函數中調用
//t_c:		實際溫度值放大100倍的結果
//rh_true:	相對濕度值
extern	uint16	t_c, rh_true;
/**************************************************************************************************
**Name: 	
**Function:	Sclk=1 DDR=1
**Input:	
**Output:	
**************************************************************************************************/	
void SHTXX_SCK_HIGH(void)
{
	DDRC	|=	(1<<SHTXX_SCK_BIT);
	PORTC	|=	(1<<SHTXX_SCK_BIT);
	Delay_nmillisecond(10);
}
/**************************************************************************************************
**Name: 	
**Function:	sclk=0 DDR=1
**Input:	
**Output:	
**************************************************************************************************/	
void SHTXX_SCK_LOW(void)
{
	DDRC	|=	(1<<SHTXX_SCK_BIT);
	PORTC	&=	~(1<<SHTXX_SCK_BIT);
	Delay_nmillisecond(10);
}
/**************************************************************************************************
**Name: 	
**Function:	DATA=1,	DDR=1
**Input:	
**Output:	
**************************************************************************************************/	
void SHTXX_DAT_1(void)
{
	DDRC	|=	(1<<SHTXX_DAT_BIT);
	Delay_nmillisecond(2);
	PORTC	|=	(1<<SHTXX_DAT_BIT);
	Delay_nmillisecond(5);
}
/**************************************************************************************************
**Name: 	
**Function:	DATA=0, DDR=1
**Input:	
**Output:	
**************************************************************************************************/
void SHTXX_DAT_0(void)
{
	DDRC	|=	(1<<SHTXX_DAT_BIT);
	Delay_nmillisecond(2);
	PORTC	&=	~(1<<SHTXX_DAT_BIT);
	Delay_nmillisecond(5);	
}
/**************************************************************************************************
**Name: 	
**Function:	SHTXX開始工作
**Input:	
**Output:	
**************************************************************************************************/
void SHTXX_START(void)
{
	SHTXX_DAT_1();
	SHTXX_SCK_LOW();
	SHTXX_SCK_HIGH();
	SHTXX_DAT_0();
	SHTXX_SCK_LOW();
	Delay_nmillisecond(5);
	SHTXX_SCK_HIGH();
	SHTXX_DAT_1();
	SHTXX_SCK_LOW();
}
/**************************************************************************************************
**Name: 	
**Function:	Not use
**Input:	
**Output:	
**************************************************************************************************/
void SHTXX_ACK(void)
{
	DDRC	&=	~(1<<SHTXX_DAT_BIT);
	
}
/**************************************************************************************************
**Name: 	
**Function:	初始化
**Input:	
**Output:	
**************************************************************************************************/
void shtxx_init(void)
{
	//shtxx_temp = shtxx_humi = 0;
	SHTXX_SCK_LOW();
	SHTXX_DAT_1();
	shtxx_reconnect();
}
/**************************************************************************************************
**Name: 	
**Function:	復位SHT串口
**Input:	
**Output:	
**************************************************************************************************/
void shtxx_reconnect(void)
{
 	uint8 i=0;
	SHTXX_DAT_1();
	SHTXX_SCK_LOW();
	for(i=0;i<9;i++)
	{
		SHTXX_SCK_HIGH(); SHTXX_SCK_LOW();
	}
	SHTXX_START();
}
/**************************************************************************************************
**Name: 	
**Function:	復位
**Input:	
**Output:	
**************************************************************************************************/
uint8 shtxx_softrst(void)
{
	uint8 error = 0;
	shtxx_reconnect();
	error += shtxx_write_byte(SHTXX_SOFT_RST);
	return error;
}
/**************************************************************************************************
**Name: 	
**Function:	
**Input:	
**Output:	
//寫命令函數
//參數:命令類型
//返回:0成功,1失敗
**************************************************************************************************/
uint8 shtxx_write_byte(uint8 cmd)
{
	uint8 i,ack;
	for (i=8;i>0;i--)
	{
		if(BITCHK(cmd,(i-1)))		//trans '1' 
		{
			SHTXX_DAT_1();	
			SHTXX_SCK_HIGH();
			SHTXX_SCK_LOW();
		}	
		else 						//trans '0'
		{
			SHTXX_DAT_0();						 
			SHTXX_SCK_HIGH(); 
			SHTXX_SCK_LOW();
		}
	}
	//SHTxx 會以下述方式表示已正確地接收到指令:
	//在第8 個SCK 時鐘的下降沿之后,將DATA 下拉為低電平(ACK 位)。
	//在第9 個SCK 時鐘的下降沿之后,釋放DATA(恢復高電平)。
	BITCLR(SHTXX_DAT_DDR, SHTXX_DAT_BIT);
	SHTXX_SCK_HIGH();
	ack = BITCHK(SHTXX_DAT_PIN,SHTXX_DAT_BIT);
	SHTXX_SCK_LOW();
	return ack;
}
/**************************************************************************************************
**Name: 	讀字節函數
**Function:	讀取一個字節,并根據參數1:繼續接收0:停止接收
**Input:		0,非0
**Output:	讀取字節
**************************************************************************************************/
uint8 shtxx_read_byte(uint8 dat_crc)
{
	uint8 i,dat8 = 0;
	for (i=8; i>0; i--)
	{
		BITCLR(SHTXX_DAT_DDR, SHTXX_DAT_BIT);
		SHTXX_SCK_HIGH();
		if (BITCHK(SHTXX_DAT_PIN, SHTXX_DAT_BIT)) 
			BITSET(dat8, (i-1));
		SHTXX_SCK_LOW();
	}
	
	if (dat_crc)
	{
		SHTXX_DAT_0();
		SHTXX_SCK_HIGH(); SHTXX_SCK_LOW();
	}
	else
	{
		SHTXX_DAT_1();
		SHTXX_SCK_HIGH(); SHTXX_SCK_LOW();
	}
	SHTXX_DAT_1();	
	
	return dat8;
}
/**************************************************************************************************
**Name: 	SHT 測量
**Function:	通過mode,選擇測量溫度濕度,結果shtxx_data,shtxx_crc
**Input:		shtxx_data 存放測量結果
			shtxx_crc 存放CRC校驗
			mode  SHTXX_MODE_TEMP	SHTXX_MODE_HUMI
			
**Output:	0;		成功,
			非0: 錯誤	
**************************************************************************************************/
uint8 shtxx_measure(uint16 * shtxx_data,uint8 *shtxx_crc,uint8 mode)
{
	uint8 error = 0;
	uint16 i;
	*shtxx_data=*shtxx_crc=0;
	SHTXX_START();	
	switch (mode)
	{
		case SHTXX_MODE_TEMP:
			error += shtxx_write_byte(SHTXX_CMD_TEMPTURE);
			for (i=0; i<50; i++)
			{	
				Delay_nmillisecond(5);
				BITCLR(SHTXX_DAT_DDR, SHTXX_DAT_BIT); 
				if (!(BITCHK(SHTXX_DAT_PIN, SHTXX_DAT_BIT))) break;
			}
			BITCLR(SHTXX_DAT_DDR, SHTXX_DAT_BIT); 
			if (BITCHK(SHTXX_DAT_PIN, SHTXX_DAT_BIT)) error += 1;
			*(shtxx_data) = shtxx_read_byte(1);
			*(shtxx_data) = ((*shtxx_data) << 8) + shtxx_read_byte(1);
			*(shtxx_crc)  = shtxx_read_byte(0);	
			break;
		case SHTXX_MODE_HUMI:
			error += shtxx_write_byte(SHTXX_CMD_HUMIDITY);
			for (i=0; i<50; i++)
			{	
				Delay_nmillisecond(5);
				BITCLR(SHTXX_DAT_DDR, SHTXX_DAT_BIT); 
				if (!(BITCHK(SHTXX_DAT_PIN, SHTXX_DAT_BIT))) break;
			}
			BITCLR(SHTXX_DAT_DDR, SHTXX_DAT_BIT); 
			if (BITCHK(SHTXX_DAT_PIN, SHTXX_DAT_BIT)) 
				error += 1;
			*(shtxx_data) = shtxx_read_byte(1);
			*(shtxx_data) = ((*shtxx_data) << 8) + shtxx_read_byte(1);
			*(shtxx_crc)  = shtxx_read_byte(0);			
			break;
		default:
			break;
	}

	return error;
}
/**************************************************************************************************
**Name: 	
**Function:	計算溫度
**Input:		shtxx_temp:	SHT 讀出16bits 溫度值
**Output:	SHT 讀出16bits 溫度值
**************************************************************************************************/
uint16 shtxx_calc_temp(uint16 *shtxx_temp)
{
 	 uint16		tc=0;
 //溫度常量放大100
	tc = (*shtxx_temp);	//結果除以100
	return (tc);
}
/**************************************************************************************************
**Name: 	
**Function:	計算溫度
**Input:		shtxx_humi:	SHT 讀出16bits 濕度值
**Output:	相對濕度*100
**************************************************************************************************/
uint16 shtxx_calc_humi(uint16 *shtxx_humi)
{
	uint32 rh_line = 0;
	//所有濕度常量放大10,000,000
	 uint32 C1 = 	40000000;
	 uint32 C2 = 	    405000;
	 uint32 C3 =   	     28;
	 uint32 T1 =       100000;
	 uint32 T2 =          8000;	
	
	//溫度常量放大100
	//t_c = (*shtxx_temp) - 4000;	//結果除以100
	
	rh_line = C2*(*shtxx_humi) - C3*(*shtxx_humi)*(*shtxx_humi) - C1;
	//rh_true = (t_c/100-25)*(T1+T2*(*shtxx_humi)) + rh_line;
	
	if (rh_line>1000000000) rh_line = 1000000000; //cut if the value is outside of
	if (rh_line<1000000) rh_line = 1000000; //the physical possible range
	return (rh_line/100000);
}
/**************************************************************************************************
**Name: 	
**Function:	16位二進制到十進制
**Input:		hex16:	想轉換的二進制數(無符號)
			bcd:		轉換后的BCD碼存放位置,加0x30后為ASCII碼
**Output:	
**************************************************************************************************/
void hex_bcd(uint16 hex16,uint8 * bcd)
{	uint8	i;
	for(i=0;i<5;i++)
		*(bcd+i)='\0';
	//memset(bcd32, '\0', 10);
	
	while (hex16 >= 10000)			//
	{
		(*(bcd+4))++;
		hex16 = hex16 - 10000;
	}	
	
	while (hex16 >= 1000)			//
	{
		(*(bcd+3))++;
		hex16 = hex16 - 1000;
	}	
	
	while (hex16 >= 100)			//
	{
		(*(bcd+2))++;
		hex16 = hex16 - 100;
	}	
	
	while (hex16 >= 10)				//
	{
		(*(bcd+1))++;
		hex16 = hex16 - 10;
	}
	
	*bcd = hex16;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产a区久久久| 久久精品国产99久久6| 久久久久久99精品| 日韩三级高清在线| 日韩免费高清av| 欧美电影免费提供在线观看| 欧美一区二区三区免费大片 | 青青草精品视频| 日精品一区二区| 蜜桃一区二区三区在线观看| 丝袜诱惑制服诱惑色一区在线观看| 亚洲成人精品影院| 麻豆精品新av中文字幕| 久久99精品久久久| 成人激情黄色小说| 色婷婷激情一区二区三区| 欧美色倩网站大全免费| 91精品国产综合久久久久久久 | 亚洲国产精品成人综合色在线婷婷| 久久久一区二区三区| 国产精品久久综合| 亚洲线精品一区二区三区| 视频一区国产视频| 国v精品久久久网| 91福利在线播放| 欧美不卡在线视频| 国产精品国模大尺度视频| 亚洲影院免费观看| 黑人巨大精品欧美一区| 99精品欧美一区二区三区小说| 色国产精品一区在线观看| 日韩一区二区电影在线| 中文无字幕一区二区三区| 亚洲国产综合91精品麻豆| 精品一区二区日韩| 欧美在线不卡一区| 久久色在线视频| 亚洲一卡二卡三卡四卡五卡| 韩国一区二区视频| 欧美视频在线播放| 日本一区二区动态图| 天天色综合天天| jizz一区二区| 欧美精品一区二区三区视频| 亚洲视频中文字幕| 国产乱妇无码大片在线观看| 欧美在线啊v一区| 国产精品久久久久久久久动漫| 视频在线观看国产精品| 99久久99久久精品免费看蜜桃| 日韩午夜av电影| 亚洲午夜av在线| 99视频一区二区| 欧美激情综合五月色丁香| 裸体健美xxxx欧美裸体表演| 在线视频国内一区二区| 国产精品嫩草影院av蜜臀| 乱一区二区av| 欧美一二三在线| 亚洲.国产.中文慕字在线| 99re这里只有精品视频首页| 精品国产一二三区| 蜜桃免费网站一区二区三区| 欧美裸体bbwbbwbbw| 亚洲欧美乱综合| 一本久久a久久免费精品不卡| 日本一区二区三区视频视频| 激情综合网激情| 日韩欧美国产一区二区在线播放| 性做久久久久久| 欧美三级电影在线观看| 亚洲一区二区美女| 在线视频一区二区免费| 亚洲一区在线视频观看| 日本精品一区二区三区高清 | 亚洲妇熟xx妇色黄| 在线免费不卡电影| 亚洲制服丝袜在线| 欧美日韩在线播放一区| 亚洲国产成人av好男人在线观看| 色呦呦国产精品| 亚洲午夜精品网| 678五月天丁香亚洲综合网| 视频在线在亚洲| 91精品免费观看| 国内精品不卡在线| 亚洲国产精品精华液ab| www.爱久久.com| 亚洲欧美视频在线观看视频| 在线视频观看一区| 蜜桃视频一区二区| 久久精品欧美一区二区三区麻豆| 国产福利精品一区| 一区二区三区中文在线| 91精品国产综合久久久久久 | 国产不卡在线一区| 亚洲男人天堂一区| 51精品国自产在线| 国产乱人伦偷精品视频不卡| 中文字幕亚洲一区二区va在线| 91色婷婷久久久久合中文| 香蕉乱码成人久久天堂爱免费| 欧美一区二区不卡视频| 国产精品1区2区3区在线观看| 亚洲欧洲99久久| 欧美一区二区三区在线视频 | 国产精品66部| 一二三区精品福利视频| 日韩一区二区三区av| 成人精品免费网站| 日韩经典中文字幕一区| 国产日产欧美一区| 欧美日韩在线精品一区二区三区激情 | 国产午夜精品久久| 欧美丝袜丝交足nylons图片| 麻豆成人综合网| 日韩伦理电影网| 日韩视频一区二区在线观看| 99国产精品国产精品久久| 蜜桃视频免费观看一区| 亚洲欧美日韩国产一区二区三区| 欧美一级淫片007| 99久久婷婷国产| 国产麻豆精品久久一二三| 亚洲一区在线视频| 国产精品国产三级国产有无不卡| 欧美日韩成人一区二区| 成人av在线网| 久久99久久精品| 日韩在线观看一区二区| 国产精品欧美一区二区三区| 欧美zozo另类异族| 欧美日高清视频| 在线亚洲高清视频| 99精品视频在线观看免费| 激情伊人五月天久久综合| 天堂成人免费av电影一区| 亚洲另类中文字| 亚洲国产高清在线观看视频| 日韩美女一区二区三区| 69精品人人人人| 欧美亚洲禁片免费| 欧美色精品在线视频| 91免费视频网| 在线观看免费成人| 一本久道中文字幕精品亚洲嫩| 波多野结衣亚洲一区| 国产精品综合一区二区| 国内不卡的二区三区中文字幕| 五月婷婷另类国产| 三级欧美在线一区| 婷婷丁香激情综合| 蜜臀av一级做a爰片久久| 日韩av不卡在线观看| 日韩av网站免费在线| 日本91福利区| 激情成人综合网| 国产精品一区二区无线| 成人一级黄色片| av在线不卡电影| 日本高清无吗v一区| 在线观看国产91| 欧美日本一区二区在线观看| 欧美日韩精品欧美日韩精品| 欧美日韩成人在线| 精品国产乱码久久久久久免费| 2023国产精品视频| 中文字幕一区在线| 一区二区三区在线免费视频| 香蕉av福利精品导航| 免费一级片91| 国产精品99精品久久免费| a亚洲天堂av| 欧美日韩国产免费| 欧美成人女星排名| 欧美激情综合在线| 午夜伦欧美伦电影理论片| 男人的天堂亚洲一区| 成人一级片在线观看| 精品视频一区三区九区| 亚洲精品在线观看网站| 亚洲欧美一区二区在线观看| 五月天婷婷综合| 国产福利视频一区二区三区| 91丨porny丨首页| 日韩欧美电影一二三| 成人免费在线视频| 美女久久久精品| 91色视频在线| 久久久久免费观看| 亚洲一区在线视频观看| 国产成人亚洲综合a∨猫咪| 色欧美片视频在线观看| 久久综合成人精品亚洲另类欧美| 亚洲欧美一区二区三区国产精品| 久久激五月天综合精品| 一本色道**综合亚洲精品蜜桃冫| 欧美一区二区日韩| 一区二区三区四区在线播放| 激情成人午夜视频|