PIC18F8722模拟I2c总线读取SHT15数据程序
//模拟I2C总线与sht15传感器通信
//将测得数据通过串口输出(成功)
//未加 CRC校验
#include
#define SCL RG0//时钟总线
#define DATA RG1//数据总线
#define SCL_DR TRISG0//时钟方向
#define DATA_DR TRISG1//数据方向
#define out 0
#define in 1
#define MT 0x03//Measure Temperature
#define MH 0x05//Measure Humidity
#define RR 0x07//Read Status Register
#define WR 0x06//Write Status Register
/**********全局变量***************/
bit ack=0;
unsigned int measureresult=0; //存储测量结果
float temperature=0; //温度值
float humidity=0;//湿度值
/*********delay function**********/
void nops()
{
asm("nop");
asm("nop");
}
void nopss()
{
asm("nop");
asm("nop");
asm("nop");
asm("nop");
}
void i2c_wait()
{
unsigned char j;
for(j=0;j<10;j++)
asm("nop");
}
void delay(unsigned int n) //带参数延时函数
{
unsigned int i,j;
for(j=0;jfor(i=0;i<100;i++);
}
/********************************/
void SHT15_start()
{
DATA_DR=out;
SCL_DR=out;
DATA=http://www.dg8.com.cn/tool/1;
SCL=1;
nopss();
DATA=http://www.dg8.com.cn/tool/0;
nopss();
SCL=0;
nopss();
SCL=1;
nopss();
DATA=http://www.dg8.com.cn/tool/1;
nopss();
SCL=0;
}
void SHT15_reset()
{unsigned char i;
DATA_DR=out;
SCL_DR=out;
DATA=http://www.dg8.com.cn/tool/1;SCL=0;///reset the sensor
for(i=0;i<9;i++)
{
SCL=1;
nops();
SCL=0;
}
SHT15_start();
}
char command(unsigned char temp)
{
ack=0;
unsigned char i;
unsigned int j;
for(i=0x80;i>0;i/=2)
{
if(temp&i) DATA=http://www.dg8.com.cn/tool/1;
else DATA=http://www.dg8.com.cn/tool/0;
SCL=1;
nops();
SCL=0;
}
DATA_DR=in;
SCL=1;
nops();
SCL=0;
ack=DATA;
//DATA=http://www.dg8.com.cn/tool/1;
while(DATA);
return ack;
}
unsigned int read_data()
{
unsigned char a,data1=0,data2=0,checksum=0;
unsigned int data=http://www.dg8.com.cn/tool/0;
for(a=0x80;a>0;a/=2) ////前八位
{SCL=1;
if(DATA) data1=data1|a;
SCL=0;
nops();
}
DATA_DR=0;
DATA=http://www.dg8.com.cn/tool/0; ////应答
SCL=1;
nopss();
SCL=0;
DATA_DR=1;
for(a=0x80;a>0;a/=2)//////后八位
{
SCL=1;
if(DATA) data2=data2|a;
SCL=0;
nops();
}
DATA_DR=0;
DATA=http://www.dg8.com.cn/tool/0; ////应答
SCL=1;
nopss();
SCL=0;
DATA_DR=1;
for(a=0x80;a>0;a/=2) /////校验和
{
SCL=1;
if(DATA) checksum=checksum|a;
SCL=0;
}
DATA=http://www.dg8.com.cn/tool/1;////应答 , 传输结束 。
SCL=1;
nopss();
SCL=0;
/////校验
data=http://www.dg8.com.cn/tool/data1*256+data2;
return data;
}
float calculate(unsigned char temp,unsigned int data)
{
float result=0;
if(temp==MH)
{
result= -4 + 0.0405*data - 2.8*0.000001*data*data;
}
if(temp==MT)
{
result=-40 + 0.01 * data;
}
return result;
}
void USART_init()//带形参的USART发送函数
{
//GIE=0;
//PEIE=0;
//TRISC7=1;
//TRISC6=0;
TXIE=0;//关闭中断
TXSTA=0x06; //发送状态寄存器设置
SPBRG=0x19; //波特率设为38400bps
}
void USART_tx(unsigned char byte)
{
SPEN=1;
while(!TRMT); //检测TSR寄存器是否为空
TXREG=byte; //将待发数据给发送寄存器
TXEN=1; //启动发送使能
while(!TRMT); //等待发关完一字节数据
TXEN=0; //关闭发送使能
}
/*主函数*/
void main()
{
//SHT15_start();
USART_init();
for(;;)
{
SHT15_reset();
command(MH);
measureresult=read_data();
humidity=calculate(MH,measureresult);
//USART_tx((unsigned char)humidity);
//delay(10);
//USART_tx('a');
delay(100);
}
}
/***************************************/
/*****Interrupt ServiceRoutine**********/
/***************************************/
void interrupt isr() //不能去掉 , 否则无法正常发送数据
{
【PIC18F8722模拟I2c总线读取SHT15数据程序】}
推荐阅读
- 数字电源和模拟电源那个好?
- 在PCB设计中数字电源、模拟电源、数字地、模拟地的处理方法
- 基于运算放大器的各项模拟积分器电路应用
- 你知道PWM信号转换为模拟量信号的过程吗?
- 瑞萨电子推出领先业界的RX系列首款内置模拟前端的微控制器 RX23E-A产品组,用于高精度传感及测量设备
- 8051单片机的I2C接口并行扩展及接口设计
- 基于I2C串行总线的单片机应用系统的设计方法和程序
- 单片机 I2C 寻址模式
- 什么是模拟信号「模拟信号和数字信号的本质区别」
- proteus仿真:I2c总线和EEPROM2404的读写