I2C总线通信(温湿度实验)

1.使能GPIOF时钟

2.将PF14设置为输出,PF15也可以先设置为输出

3.设置输出速度最高档位速度

4.SI7006的初始化

5.读取温度、湿度

6.将读取到的温度湿度数据通过计算公式进行转换

7.将结果输出 

main.c

#include "si7006.h"

extern void printf(const char *fmt,...);

void delay(int ms)

{

  int i,j;

  for(i=0;i<ms;i++)

  {
      for(j=0;j<2000;j++);
  }

}

int main()

{

    unsigned short tem;//用于保存 温度数据和湿度数据

    unsigned short hum;

    //进行SI7e06的初始化

    si7006_init();

    while(1)

    {

        //读取温度

        tem=si7006_read_data( 0x40,0XE0);

        hum=si7006_read_data(0x40,0XE5);//读取湿度

         //数据转换

        tem=tem*175.72/65536-46.85;

        hum=hum*125/65536-6;

        //数据输出

        printf("tem:%d\n",tem);

        printf("hum:%d\n",hum);

        delay(1000);

    }

    return 0;

}

iic.c

#include "iic.h"

extern void printf(const char* fmt, ...);
/*
 * 函数名 : delay_us
 * 函数功能:延时函数
 * 函数参数:无
 * 函数返回值:无
 * */
void delay_us(void)
{
	unsigned int i = 2000;
	while(i--);
}
/*
 * 函数名 : i2c_init
 * 函数功能: i2C总线引脚的初始化, 通用输出,推挽输出,输出速度,
 * 函数参数:无
 * 函数返回值:无
 * */
void i2c_init(void)
{
 	// 使能GPIOF端口的时钟
	RCC->MP_AHB4ENSETR |= (0x1 << 5);
	// 设置PF14,PF15引脚为通用的输出功能
	GPIOF->MODER &= (~(0xF << 28));
	GPIOF->MODER |= (0x5 << 28);
	// 设置PF14, PF15引脚为推挽输出
	GPIOF->OTYPER &= (~(0x3 << 14));
	// 设置PF14, PF15引脚为高速输出
	GPIOF->OSPEEDR |= (0xF << 28);
	// 设置PF14, PF15引脚的禁止上拉和下拉
	GPIOF->PUPDR &= (~(0xF << 28));
	// 空闲状态SDA和SCL拉高 
	I2C_SCL_H;
	I2C_SDA_H;
}



/*
 * 函数名:i2c_start
 * 函数功能:模拟i2c开始信号的时序
 * 函数参数:无
 * 函数返回值:无
 * */
void i2c_start(void)
{
	/*
	 * 开始信号:时钟在高电平期间&#x
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值