标题:
STM8 SHT30库函数(温湿度传感器)
[打印本页]
作者:
piaqi001
时间:
2017-6-20 11:05
标题:
STM8 SHT30库函数(温湿度传感器)
SHT30是盛世瑞最新出品的低端低价温湿度传感器,在精度和尺寸上都优于SHT20.
附件是SHT30的STM8驱动,用的是库函数,自己写的,可行。
0.png
(36.85 KB, 下载次数: 152)
下载附件
2017-6-20 16:25 上传
单片机源程序如下:
//==============================================================================
// S E N S I R I O N AG, Laubisruetistr. 44, CH-8712 Staefa, Switzerland
//==============================================================================
// Project : SHT3x Sample Code (V1.0)
// File : sht3x.c (V1.0)
// Author : RFU
// Date : 16-Jun-2014
// Controller: STM32F100RB
// IDE : 礦ision V4.71.2.0
// Compiler : Armcc
// Brief : Sensor Layer: Implementation of functions for sensor access.
//==============================================================================
//-- Includes ------------------------------------------------------------------
#include "sht3x.h"
#include "iic.h"
//-- Defines -------------------------------------------------------------------
// CRC
#define POLYNOMIAL 0x131 // P(x) = x^8 + x^5 + x^4 + 1 = 100110001
//------------------------------------------------------------------------------
// IO-Pins /* -- adapt the defines for your uC -- */
//------------------------------------------------------------------------------
// Reset on port B, bit 12
#define RESET_LOW() (GPIOB->BSRR = 0x10000000) // set Reset to low
#define RESET_HIGH() (GPIOB->BSRR = 0x00001000) // set Reset to high
// Alert on port B, bit 10
#define ALERT_READ (GPIOB->IDR & 0x0400) // read Alert
//------------------------------------------------------------------------------
//-- Global variables ----------------------------------------------------------
u8t _i2cWriteHeader=0x88;
u8t _i2cReadHeader=0x89;
//==============================================================================
void SHT3X_Init(u8t i2cAdr){ /* -- adapt the init for your uC -- */
//==============================================================================
/*
// init I/O-pins
RCC->APB2ENR |= 0x00000008; // I/O port B clock enabled
// Alert on port B, bit 10
GPIOB->CRH &= 0xFFFFF0FF; // set floating input for Alert-Pin
GPIOB->CRH |= 0x00000400; //
// Reset on port B, bit 12
GPIOB->CRH &= 0xFFF0FFFF; // set push-pull output for Reset pin
GPIOB->CRH |= 0x00010000; //
RESET_LOW();
*/
// I2c_Init(); // init I2C
SHT3X_SetI2cAdr(i2cAdr); //
// release reset
// RESET_HIGH();
}
//==============================================================================
void SHT3X_SetI2cAdr(u8t i2cAdr){
//==============================================================================
_i2cWriteHeader = i2cAdr << 1;
_i2cReadHeader = _i2cWriteHeader | 0x01;
}
//==============================================================================
u8t SHT3x_ReadSerialNumber(u32t *serialNbr){
//==============================================================================
u8t error; // error code
u16t serialNumWords[2];
error = SHT3X_StartWriteAccess();
// write "read serial number" command
error |= SHT3X_WriteCommand(CMD_READ_SERIALNBR);
// if no error, start read access
if(error == NO_ERROR) error = SHT3X_StartReadAccess();
// if no error, read first serial number word
if(error == NO_ERROR) error = SHT3X_Read2BytesAndCrc(&serialNumWords[0], ACK, 100);
// if no error, read second serial number word
if(error == NO_ERROR) error = SHT3X_Read2BytesAndCrc(&serialNumWords[1], NACK, 0);
SHT3X_StopAccess();
// if no error, calc serial number as 32-bit integer
if(error == NO_ERROR)
{
*serialNbr = (serialNumWords[0] << 16) | serialNumWords[1];
}
return error;
}
//==============================================================================
u8t SHT3X_ReadStatus(u16t *status){
//==============================================================================
u8t error; // error code
error = SHT3X_StartWriteAccess();
// if no error, write "read status" command
if(error == NO_ERROR) error = SHT3X_WriteCommand(CMD_READ_STATUS);
// if no error, start read access
if(error == NO_ERROR) error = SHT3X_StartReadAccess();
// if no error, read status
if(error == NO_ERROR) error = SHT3X_Read2BytesAndCrc(status, NACK, 0);
SHT3X_StopAccess();
return error;
}
//==============================================================================
u8t SHT3X_ClearAllAlertFlags(void){
//==============================================================================
u8t error; // error code
error = SHT3X_StartWriteAccess();
// if no error, write clear status register command
if(error == NO_ERROR) error = SHT3X_WriteCommand(CMD_CLEAR_STATUS);
SHT3X_StopAccess();
return error;
}
//==============================================================================
u8t SHT3X_GetTempAndHumi(ft *temp,
ft *humi,
etRepeatab repeatab,
etMode mode,
u8t timeout){
//==============================================================================
u8t error;
switch(mode)
{
case MODE_CLKSTRETCH: // get temperature with clock stretching mode
error = SHT3X_GetTempAndHumiClkStretch(temp, humi, repeatab, timeout); break;
case MODE_POLLING: // get temperature with polling mode
error = SHT3X_GetTempAndHumiPolling(temp, humi, repeatab, timeout); break;
default:
error = PARM_ERROR; break;
}
return error;
}
//==============================================================================
u8t SHT3X_GetTempAndHumiClkStretch(ft *temp,
ft *humi,
etRepeatab repeatab,
u8t timeout){
//==============================================================================
u8t error; // error code
u16t rawValueTemp; // temperature raw value from sensor
u16t rawValueHumi; // humidity raw value from sensor
error = SHT3X_StartWriteAccess();
// if no error ...
if(error == NO_ERROR)
{
// start measurement in clock stretching mode
// use depending on the required repeatability, the corresponding command
switch(repeatab)
{
case REPEATAB_LOW: error = SHT3X_WriteCommand(CMD_MEAS_CLOCKSTR_L); break;
case REPEATAB_MEDIUM: error = SHT3X_WriteCommand(CMD_MEAS_CLOCKSTR_M); break;
case REPEATAB_HIGH: error = SHT3X_WriteCommand(CMD_MEAS_CLOCKSTR_H); break;
default: error = PARM_ERROR; break;
}
}
// if no error, start read access
if(error == NO_ERROR) error = SHT3X_StartReadAccess();
// if no error, read temperature raw values
if(error == NO_ERROR) error = SHT3X_Read2BytesAndCrc(&rawValueTemp, ACK, timeout);
// if no error, read humidity raw values
if(error == NO_ERROR) error = SHT3X_Read2BytesAndCrc(&rawValueHumi, NACK, 0);
SHT3X_StopAccess();
// if no error, calculate temperature in 癈 and humidity in %RH
if(error == NO_ERROR)
{
*temp = SHT3X_CalcTemperature(rawValueTemp);
*humi = SHT3X_CalcHumidity(rawValueHumi);
}
return error;
}
//==============================================================================
u8t SHT3X_GetTempAndHumiPolling(ft *temp,
ft *humi,
etRepeatab repeatab,
u8t timeout){
//==============================================================================
u8t error; // error code
u16t rawValueTemp; // temperature raw value from sensor
u16t rawValueHumi; // humidity raw value from sensor
error = SHT3X_StartWriteAccess();
// if no error ...
if(error == NO_ERROR)
{
// start measurement in polling mode
// use depending on the required repeatability, the corresponding command
switch(repeatab)
{
case REPEATAB_LOW: error = SHT3X_WriteCommand(CMD_MEAS_POLLING_L); break;
case REPEATAB_MEDIUM: error = SHT3X_WriteCommand(CMD_MEAS_POLLING_M); break;
case REPEATAB_HIGH: error = SHT3X_WriteCommand(CMD_MEAS_POLLING_H); break;
default: error = PARM_ERROR; break;
}
}
// if no error, wait until measurement ready
if(error == NO_ERROR)
{
// poll every 1ms for measurement ready until timeout
while(timeout--)
{
// check if the measurement has finished
error = SHT3X_StartReadAccess();
// if measurement has finished -> exit loop
if(error == NO_ERROR) break;
// delay 1ms
DelayMicroSeconds(1000);
}
// check for timeout error
if(timeout == 0) error = TIMEOUT_ERROR;
}
// if no error, read temperature and humidity raw values
if(error == NO_ERROR)
{
error |= SHT3X_Read2BytesAndCrc(&rawValueTemp, ACK, 0);
error |= SHT3X_Read2BytesAndCrc(&rawValueHumi, NACK, 0);
}
SHT3X_StopAccess();
// if no error, calculate temperature in 癈 and humidity in %RH
if(error == NO_ERROR)
{
*temp = SHT3X_CalcTemperature(rawValueTemp);
*humi = SHT3X_CalcHumidity(rawValueHumi);
}
return error;
}
//==============================================================================
u8t SHT3X_StartPeriodicMeasurment(etRepeatab repeatab,
etFrequency freq){
//==============================================================================
u8t error; // error code
error = SHT3X_StartWriteAccess();
// if no error, start periodic measurement
if(error == NO_ERROR)
{
// use depending on the required repeatability and frequency,
// the corresponding command
switch(repeatab)
{
case REPEATAB_LOW: // low repeatability
switch(freq)
{
case FREQUENCY_HZ5: // low repeatability, 0.5 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_05_L); break;
case FREQUENCY_1HZ: // low repeatability, 1.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_1_L); break;
case FREQUENCY_2HZ: // low repeatability, 2.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_2_L); break;
case FREQUENCY_4HZ: // low repeatability, 4.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_4_L); break;
case FREQUENCY_10HZ: // low repeatability, 10.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_10_L); break;
default:
error |= PARM_ERROR; break;
}
break;
case REPEATAB_MEDIUM: // medium repeatability
switch(freq)
{
case FREQUENCY_HZ5: // medium repeatability, 0.5 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_05_M); break;
case FREQUENCY_1HZ: // medium repeatability, 1.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_1_M); break;
case FREQUENCY_2HZ: // medium repeatability, 2.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_2_M); break;
case FREQUENCY_4HZ: // medium repeatability, 4.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_4_M); break;
case FREQUENCY_10HZ: // medium repeatability, 10.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_10_M); break;
default:
error |= PARM_ERROR; break;
}
break;
case REPEATAB_HIGH: // high repeatability
switch(freq)
{
case FREQUENCY_HZ5: // high repeatability, 0.5 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_05_H); break;
case FREQUENCY_1HZ: // high repeatability, 1.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_1_H); break;
case FREQUENCY_2HZ: // high repeatability, 2.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_2_H); break;
case FREQUENCY_4HZ: // high repeatability, 4.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_4_H); break;
case FREQUENCY_10HZ: // high repeatability, 10.0 Hz
error |= SHT3X_WriteCommand(CMD_MEAS_PERI_10_H); break;
default:
error |= PARM_ERROR; break;
}
break;
default:
error |= PARM_ERROR; break;
}
}
SHT3X_StopAccess();
return error;
}
//==============================================================================
u8t SHT3X_ReadMeasurementBuffer(ft *temp, ft *humi){
//==============================================================================
u8t error; // error code
u16t rawValueTemp; // temperature raw value from sensor
u16t rawValueHumi; // humidity raw value from sensor
error = SHT3X_StartWriteAccess();
// if no error, read measurements
if(error == NO_ERROR) error = SHT3X_WriteCommand(CMD_FETCH_DATA);
if(error == NO_ERROR) error = SHT3X_StartReadAccess();
if(error == NO_ERROR) error = SHT3X_Read2BytesAndCrc(&rawValueTemp, ACK, 0);
if(1) error = SHT3X_Read2BytesAndCrc(&rawValueHumi, NACK, 0);
// if no error, calculate temperature in 癈 and humidity in %RH
//if(error == NO_ERROR)
//{
*temp = SHT3X_CalcTemperature(rawValueTemp);
*humi = SHT3X_CalcHumidity(rawValueHumi);
//}
SHT3X_StopAccess();
return error;
}
//==============================================================================
u8t SHT3X_EnableHeater(void){
//==============================================================================
u8t error; // error code
error = SHT3X_StartWriteAccess();
// if no error, write heater enable command
if(error == NO_ERROR) error = SHT3X_WriteCommand(CMD_HEATER_ENABLE);
SHT3X_StopAccess();
return error;
}
//==============================================================================
u8t SHT3X_DisbaleHeater(void){
//==============================================================================
u8t error; // error code
error = SHT3X_StartWriteAccess();
// if no error, write heater disable command
if(error == NO_ERROR) error = SHT3X_WriteCommand(CMD_HEATER_DISABLE);
SHT3X_StopAccess();
return error;
}
//==============================================================================
u8t SHT3X_SoftReset(void){
//==============================================================================
u8t error; // error code
error = SHT3X_StartWriteAccess();
// write reset command
error |= SHT3X_WriteCommand(CMD_SOFT_RESET);
SHT3X_StopAccess();
// if no error, wait 50 ms after reset
if(error == NO_ERROR) DelayMicroSeconds(50000);
return error;
}
//==============================================================================
void SHT3X_HardReset(void){
//==============================================================================
// set reset low
//RESET_LOW();
// wait 100 ms
DelayMicroSeconds(100000);
// release reset
//RESET_HIGH();
// wait 50 ms after reset
DelayMicroSeconds(50000);
}
//==============================================================================
u8t SHT3X_StartWriteAccess(void){
//==============================================================================
u8t error; // error code
// write a start condition
I2C_START();
// write the sensor I2C address with the write flag
error = I2C_TX(_i2cWriteHeader);
return error;
}
//==============================================================================
u8t SHT3X_StartReadAccess(void){
//==============================================================================
u8t error; // error code
// write a start condition
I2C_START();
// write the sensor I2C address with the read flag
error = I2C_TX(_i2cReadHeader);
return error;
}
//==============================================================================
void SHT3X_StopAccess(void){
//==============================================================================
// write a stop condition
I2C2_Stop();
}
//==============================================================================
u8t SHT3X_WriteCommand(etCommands cmd){
//==============================================================================
u8t error; // error code
// write the upper 8 bits of the command to the sensor
error = I2C_TX(cmd >> 8);
// write the lower 8 bits of the command to the sensor
error |= I2C_TX(cmd & 0xFF);
return error;
}
//==============================================================================
u8t SHT3X_Read2BytesAndCrc(u16t *data, etI2cAck finaleAckNack, u8t timeout){
//==============================================================================
u8t error; // error code
u8t bytes[2]; // read data array
u8t checksum; // checksum byte
// read two data bytes and one checksum byte
/*
error = I2c_ReadByte(&bytes[0], ACK, timeout);
if(error == NO_ERROR) error = I2c_ReadByte(&bytes[1], ACK, 0);
if(error == NO_ERROR) error = I2c_ReadByte(&checksum, finaleAckNack, 0);
*/
bytes[0]=I2C_RX(ACK);
bytes[1]=I2C_RX(ACK);
checksum=I2C_RX(finaleAckNack);
// verify checksum
if(error == NO_ERROR) error = SHT3X_CheckCrc(bytes, 2, checksum);
// combine the two bytes to a 16-bit value
*data = (bytes[0] << 8) | bytes[1];
return error;
}
//==============================================================================
u8t SHT3X_Write2BytesAndCrc(u16t data){
//==============================================================================
u8t error; // error code
u8t bytes[2]; // read data array
u8t checksum; // checksum byte
bytes[0] = data >> 8;
bytes[1] = data & 0xFF;
checksum = SHT3X_CalcCrc(bytes, 2);
// write two data bytes and one checksum byte
error = I2C_TX(bytes[0]); // write data MSB
if(error == NO_ERROR) error = I2C_TX(bytes[1]); // write data LSB
if(error == NO_ERROR) error = I2C_TX(checksum); // write checksum
return error;
}
//==============================================================================
u8t SHT3X_CalcCrc(u8t data[], u8t nbrOfBytes){
//==============================================================================
u8t bit; // bit mask
u8t crc = 0xFF; // calculated checksum
u8t byteCtr; // byte counter
// calculates 8-Bit checksum with given polynomial
for(byteCtr = 0; byteCtr < nbrOfBytes; byteCtr++)
{
crc ^= (data[byteCtr]);
for(bit = 8; bit > 0; --bit)
……………………
…………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码
所有资料51hei提供下载:
SHT3X.zip
(6.78 KB, 下载次数: 338)
2017-6-20 11:05 上传
点击文件名下载附件
下载积分: 黑币 -5
作者:
tt18tt
时间:
2017-10-23 11:49
感谢分享,就是黑币不够 下载不了
作者:
359184567
时间:
2017-10-31 14:07
扣除了我5个 然后服务器内部错误 再下载就没币了!
作者:
359184567
时间:
2017-10-31 14:08
啥情况 没回复上!!!
作者:
sanming
时间:
2017-11-22 15:32
感谢分享,然而没有黑币下不了
作者:
rkchenjh
时间:
2017-11-23 10:12
感谢分享,就是黑币不够 下载不了
作者:
I_am
时间:
2017-12-25 14:50
同样的,没有黑币下载不了。
作者:
幻影幻舞
时间:
2018-1-4 19:26
感谢分享
作者:
51hei2018
时间:
2018-1-16 10:48
感谢分享,可惜黑币不够 下载不了
作者:
warning
时间:
2018-2-6 13:14
感谢分享
作者:
warning
时间:
2018-2-6 13:14
感谢分享可惜没法下载
作者:
warning
时间:
2018-2-8 17:01
感谢分享可惜没法下载
作者:
sungang1021
时间:
2018-2-28 14:26
正在找,感谢分享
作者:
LF-STUDIO
时间:
2018-3-14 14:05
谢谢分享
作者:
netbeetle
时间:
2018-4-25 18:11
谢谢分享,谢谢
作者:
xiaowu1716
时间:
2018-5-7 10:41
谢谢分享,谢谢
作者:
fly_confidence
时间:
2018-5-13 00:24
谢谢分享,谢谢
作者:
沂蒙为阿曼
时间:
2018-7-15 14:33
十分感谢分享。
作者:
qcbt4321
时间:
2018-8-28 11:23
谢谢分享,谢谢
作者:
我好菜呀
时间:
2018-10-8 18:31
感谢分享科学没有黑币下载
作者:
ziyan0302
时间:
2018-11-1 16:33
为啥只扣分,下载不了呀?都扣了2次了,就是显示下载人数太多,要等待2分钟才能下载?
作者:
ziyan0302
时间:
2018-11-1 16:43
这程序代码就是官网发的。如果用在stm32L151低功耗系列上是没办法用的。
作者:
wdp1123
时间:
2018-11-29 13:07
好东西要学习
作者:
abao66669999
时间:
2018-12-11 08:37
好东西,值得分享,谢谢啦
作者:
loadstar2006
时间:
2019-1-4 18:19
刚好用到 拿来参考 感谢!!!
作者:
TaoAlan
时间:
2019-2-25 16:53
多谢,给力,不错
作者:
niexiaohui
时间:
2019-12-29 16:18
不错,谢谢!!!!!!!!
作者:
yxdz1358
时间:
2020-3-2 16:05
看了一下,感觉好复杂呢,有点蒙了。
作者:
Wting136
时间:
2020-3-15 22:16
这个资料很好 谢谢楼主分享
作者:
hds1988_xjtu
时间:
2021-4-19 10:15
我也一样,扣除了5个币,就没有然后了
欢迎光临 (http://www.51hei.com/bbs/)
Powered by Discuz! X3.1