bme280 环境传感器开发板_STM32Cube14 | 使用硬件I2C读写环境光强度传感器

f04571f84a6ad99f1937fc906d1d4184.png更多精彩~点击上面蓝字关注我们呀!  a964d67b0dd927f436899035b31cf0ab.png

寻求更好的阅读体验,请点击阅读原文移步:Mculover666的个人博客。

本篇详细的记录了如何使用STM32CubeMX配置STM32L431RCT6的硬件I2C外设读取环境光强度传感器数据(BH1750)。

1. 准备工作

硬件准备

  • 开发板
    首先需要准备一个开发板,这里我准备的是STM32L4的开发板(BearPi):

1c6c8e406057ca76447605c639c68821.png
  • BH1750模块
    BH1750FV1是两线式串行总线接口(IIC)的16位数字输出型环境光强度传感器,利用它的高分辨率可以探测较大范围内的光照强度变化(1lx - 65535lx)。

ebba1435658351a3a101083e3abbafe3.png

BH1750的原理图如下:

53f5bed508a2032d1b05331261f46b1f.png

软件准备

  • 需要安装好Keil - MDK及芯片对应的包,以便编译和下载生成的代码;

Keil MDK和串口助手Serial Port Utility 的安装包都可以在文末关注公众号获取,回复关键字获取相应的安装包:

0abbad6683a2acc4c3e3111164ab61fe.png

2.生成MDK工程

选择芯片型号

打开STM32CubeMX,打开MCU选择器:

84c99cdde50e8003d81908a4f24bcea6.png

搜索并选中芯片STM32L431RCT6:

879bb717df458edef518e335b2a0b0e3.png

配置时钟源

  • 如果选择使用外部高速时钟(HSE),则需要在System Core中配置RCC;

  • 如果使用默认内部时钟(HSI),这一步可以略过;

这里我都使用外部时钟:

0a635ef85f0e4f7b66c71413464fbe69.png

配置串口

小熊派开发板板载ST-Link并且虚拟了一个串口,原理图如下:

c6129a034722255b1c8deefe85d7d7f1.png

这里我将开关拨到AT-MCU模式,使PC的串口与USART1之间连接。

接下来开始配置USART1

a01c40b9ad5bf469b6d73216c98fa72f.png

配置硬件I2C

首先查看小熊派开发板的原理图,确定EEPROM接在哪个I2C接口上,如图:

c6cb6cd10105213ae881c74b3c9f383d.png

接下来开始配置I2C接口1:

3cdad87e7139dacd8b905bbf1ee0f511.png

配置时钟树

STM32L4的最高主频到80M,所以配置PLL,最后使HCLK = 80Mhz即可:

ced2e7a95862984976f9dd3086122877.png

生成工程设置

5b05bbd8be387a04e3d38024df6249b0.png

代码生成设置

最后设置生成独立的初始化文件:

b0559743fb74d2c7ba189a7ea0069001.png

生成代码

点击GENERATE CODE即可生成MDK-V5工程:

f9ae055b08cd79db86f34241527926a4.png

3. 在MDK中编写、编译、下载用户代码

修改I2C初始化代码的小BUG

0e0a1533341f5973759080c8f29f32ea.png

重定向printf( )函数

参考:【STM32Cube_09】重定向printf函数到串口输出的多种方法。

4. 编写BH1750驱动程序

参考『bh1750FVI Datasheet』进行编程。

宏定义BH1750器件地址

BH1750的器件地址由ADDR端口的高低电平决定:

5d6ddd16e62720b6fe170d146f8fcdb7.png

结合原理图,在 bh1750_i2c_drv.h 头文件中可以定义如下:

#define    BH1750_ADDR_WRITE   0x46    //01000110
#define    BH1750_ADDR_READ    0x47    //01000111

枚举BH1750工作模式

参考数据手册在 bh1750_i2c_drv.h 头文件中进行如下枚举定义:

typedef enum
{
    POWER_OFF_CMD   =   0x00,   //断电:无激活状态
    POWER_ON_CMD    =   0x01,   //通电:等待测量指令
    RESET_REGISTER  =   0x07,   //重置数字寄存器(在断电状态下不起作用)
    CONT_H_MODE     =   0x10,   //连续H分辨率模式:在11x分辨率下开始测量,测量时间120ms
    CONT_H_MODE2    =   0x11,   //连续H分辨率模式2:在0.51x分辨率下开始测量,测量时间120ms
    CONT_L_MODE     =   0x13,   //连续L分辨率模式:在411分辨率下开始测量,测量时间16ms
    ONCE_H_MODE     =   0x20,   //一次高分辨率模式:在11x分辨率下开始测量,测量时间120ms,测量后自动设置为断电模式
    ONCE_H_MODE2    =   0x21,   //一次高分辨率模式2:在0.51x分辨率下开始测量,测量时间120ms,测量后自动设置为断电模式
    ONCE_L_MODE     =   0x23    //一次低分辨率模式:在411x分辨率下开始测量,测量时间16ms,测量后自动设置为断电模式
} BH1750_MODE;

发送命令和读取数据

接下来编写bh1750_i2c_drv.c驱动文件,参考数据手册中的这部分:

dabf7020257e5658148f3c380d1b2c9e.png

本驱动程序底层使用 HAL 库的 IIC 初始化文件,所以包含如下头文件:

#include "bh1750_i2c_drv.h"
#include "i2c.h"

根据上图,发送命令的函数如下:

/**
 * @brief    向BH1750发送一条指令
 * @param    cmd —— BH1750工作模式指令(在BH1750_MODE中枚举定义)
 * @retval    成功返回HAL_OK
*/
uint8_t    BH1750_Send_Cmd(BH1750_MODE cmd)
{
    return HAL_I2C_Master_Transmit(&hi2c1, BH1750_ADDR_WRITE, (uint8_t*)&cmd, 1, 0xFFFF);
}

接收光照强度数据的函数如下:

/**
 * @brief    从BH1750接收一次光强数据
 * @param    dat —— 存储光照强度的地址(两个字节数组)
 * @retval    成功 —— 返回HAL_OK
*/
uint8_t BH1750_Read_Dat(uint8_t* dat)
{
    return HAL_I2C_Master_Receive(&hi2c1, BH1750_ADDR_READ, dat, 2, 0xFFFF);
}

数据转换函数

根据数据手册中给出的公式,编写将从BH1750读出的两个字节数据转换为对应强度值的函数:

/**
 * @brief    将BH1750的两个字节数据转换为光照强度值(0-65535)
 * @param    dat  —— 存储光照强度的地址(两个字节数组)
 * @retval    成功 —— 返回光照强度值
*/
uint16_t BH1750_Dat_To_Lux(uint8_t* dat)
{
    uint16_t lux = 0;
    lux = dat[0];
    lux <<= 8;
    lux += dat[1];
    lux = (int)(lux / 1.2);

    return lux;
}

5. 测试驱动程序

在main.c中测试驱动程序是否正常:

int main(void){
    uint8_t dat[2] = {0};        //dat[0]是高字节,dat[1]是低字节

    HAL_Init();
    SystemClock_Config();
    MX_GPIO_Init();
    MX_I2C1_Init();
    MX_USART1_UART_Init();

    while (1)
    {
        if(HAL_OK == BH1750_Send_Cmd(ONCE_H_MODE))
        {
            //printf("send ok\n");
        }
        else
        {
            //printf("send fail\n");
        }

        HAL_Delay(200);
        if(HAL_OK == BH1750_Read_Dat(dat))
        {
            //printf("recv ok\n");
            printf("current: %5d lux\n", BH1750_Dat_To_Lux(dat));

        }
        else
        {
            //printf("recv fail");
        }

        HAL_Delay(1000);
    }
}

编译下载运行,测试结果如下:

39f3140ae982611f410cc6db977ec679.png

至此,我们已经学会如何使用硬件IIC接口读取环境光强度传感器数据(BH1750),下一节将讲述如何使用硬件IIC接口读取温湿度传感器数据并使用软件CRC校验(SHT30)。

更多精彩文章及资源,请关注我的微信公众号:『mculover666』。

34c3a4d27bbcb60a071400edfde5a02b.png

历史好文集合(点击标题可跳转):

四轴学习课程连接、资料分享、交流群汇总

PCB设计就别再用AD了,有更好的选择!

[飞控]从零开始建模(一)-牛顿欧拉方程

开源STM32F1小四轴完整资料发布一(源代码、原理图、3D库、PCB)

如何制作炫酷的PCB板3D效果图

基于面向对象思维的STM32开发基本思路--以GPIO口的操作为例

灵动微MM32F103C8T6使用初体验

原来飞机还可以这样玩——手拋飞机改无刷背推

宇宙最强编辑器VS Code(十)(完结)

b1290247b400b22a5eb7d7d272717300.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/564777.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

平稳序列的拟合和预测之序列的预测

目录 1.线性预测函数 2.预测方差最小原则 3.线性最小方差预测的性质 AR(p)序列的预测 例题 R语言预测举例 MA(q)序列的预测 例题 ARMA(p,q)序列预测 例题 小结 序列只有为非白噪声时才可以进行预测哦&#xff01;&#xff01; 1.线性预测函数 根据平稳性和可逆性&…

vue 浏览器调试 样式如何定位样式_浏览器断点调试-程序员的必修课

一、源码调试/debugger方法1.1控制台调试按钮介绍Resume script execution恢复断点调试、常用在一个方法调用多个js文件(适用冗长js代码使用)、点击这个会直接跳转到下一个断点(逐过程执行)Pause script execution停止断点调试step over next function call逐语句执行&#xff…

https open api_Web上的分享(Share)API

我认为Web Share API非常酷&#xff0c;简而言之&#xff0c;它会利用您所使用的平台上的原生共享功能(如果该平台支持的话)。我喜欢这个&#xff1a;远远不止这些东西&#xff1a;为什么&#xff1f;Web Share API只是几行代码。简单&#xff01;没有图像&#xff0c;没有重量…

无季节效应的非平稳序列分析(一)

目录 Cramer分解定理&#xff08;1961年提出&#xff09; 差分 R语言函数 diff 例题&#xff1a; 过差分&#xff1a; 小结 Cramer分解定理&#xff08;1961年提出&#xff09; 任何一个时间序列 都可以分解为两部分的叠加:其中一部分是由多项式决定的确定性趋势成分&a…

求一个任意实数c的算术平方根g的算法设计思想_算法复习第四篇——贪心法

公元2020年5月5日&#xff0c;距离算法考试仅剩4天。一、知识归纳1.设计思想只根据当前已有的信息就做出选择&#xff0c;而且一旦做出了选择&#xff0c;将来无论如何都不能更改不从整体最优考虑&#xff0c;所做的选择只是在某种意义上的局部最优这种选择并不总能获得整体最优…

安装百分之80卡住_关注丨男子翻越高铁站台丢命,家属向铁路部门索赔80万!法院这样判...

去年3月&#xff0c;一名男子翻越高铁站台被卡住致死引发广泛关注。事发后&#xff0c;其家属将铁路部门告上法庭&#xff0c;索赔80余万元。日前&#xff0c;法院宣判&#xff1a;死者杨某擅自闯入危险区域负全责&#xff0c;其父母要求铁路部门赔偿的诉请被驳回。事件还原201…

ARIMA模型的介绍

目录 ARIMA模型结构 随机游走模型(random walk) 举例&#xff1a; ARIMA模型的性质 小结 ARIMA模型结构 使用场合&#xff1a;差分平稳序列拟合 模型结构 则有&#xff1a; 随机游走模型(random walk) 模型结构&#xff1a; Karl Pearson(1905)在《自然》杂志上提问:假…

java斗地主游戏

使用java实现斗地主小游戏。 程序分析&#xff1a; 1、创建扑克牌的实体类Poker&#xff0c;设置四个参数&#xff1a;花色、数字、牌值&#xff08;判断大小&#xff09;、是否地主牌&#xff0c;实现getset方法和构造方法&#xff1b; 2、创建玩家的实体类Player&#xff0…

为什么总是封板又打开涨停_警惕!如果股票涨停板反复打开说明了什么?

股市禁忌“三进三出”&#xff1a;“三进”为&#xff1a;一是“高位进”&#xff0c;这就是我们常说的追涨。犯有这种错误的投资者&#xff0c;喜欢在股票已经有了很大的涨幅后买进&#xff0c;其买进的依据往往是股票已经放量突破了历史高点或突破了某个高点阻力位等&#xf…

动态背景登录

前端动态背景登录 效果演示 完整代码 首先我们要导入jquery.js包 html代码 <!doctype html> <html lang"zh"> <head> <meta charset"UTF-8"> <meta http-equiv"X-UA-Compatible" content"IEedge,chrome1&qu…

ARIMA模型的建模和预测

目录 基本过程&#xff1a; 1.Green 函数递推公式 2.ARIMA模型的预测 例题 小结 基本过程&#xff1a; 1.Green 函数递推公式 ARIMA模型 也可写成 确定 设 则可得Green函数递推公式 2.ARIMA模型的预测 原则&#xff1a;最小均方误差预测原理 传递形式&#xff1a; 预测…

jsp论坛网站模版_网站被降权了?看看这些解决方法,或许有帮助哦

点击标题下「蓝色微信名」可快速关注在前面的文章中&#xff0c;笔者已经给大家介绍了网站被降权的因素。那么当遇到降权的问题该怎么办呢&#xff1f;接下来&#xff0c;笔者就结合本身经历过的网站降权来给大家介绍一下补救措施。1、造成网站首页降权的原因&#xff1a;服务器…

ARIMA模型之疏系数模型

目录 1.疏系数模型的定义 2.拟合ARIMA疏系数模型函数 例题&#xff1a; 小结 1.疏系数模型的定义 ARIMA(p,d,q)模型是指d阶差分后自相关最高阶数为p&#xff0c;移动平均最高阶数为q的模型&#xff0c;通常它包含pq个独立的未知系数: 如果该模型中部分自相关系数 ,1≤j<…

动画分享菜单

制作一个动画分享的菜单 效果演示 注意&#xff1a;在我们的程序开始之前我们一定要导入jquery.js架包并且找到如图所示的矢量图标。 完整代码 html代码 <!DOCTYPE html> <html> <head> <meta http-equiv"Content-Type" content"text/…

java 双向链表_23张图!万字详解「链表」,从小白到大佬

链表和数组是数据类型中两个重要又常用地基础数据类型&#xff0c;数组是连续存储在内存中的数据结构&#xff0c;因此它的优势是可以通过下标迅速的找到元素的位置&#xff0c;而它的缺点则是在插入和删除元素时会导致大量元素的被迫移动&#xff0c;为了解决和平衡此问题于是…

有季节效应的非平稳序列分析之因素分解

目录 6.1 因素分解理论 6.2因素分解模型 6.2.1因素分解模型的选择 6.2.2趋势效应的提取 简单中心移动平均的良好属性 R语言中&#xff0c;使用filter函数可以做简单移动平均 6.2.3 季节效应的提取 6.2.4 X11季节调节模型 X11模型分析步骤&#xff1a; ​ 确定性…

指数平滑预测模型

目录 1.分类 2.简单指数平滑 简单指数平滑预测&#xff1a; 平滑系数的确定 R中实现&#xff1a; 3. Holt两参数指数平滑 4. Holt-Winters三参数指数平滑 5.ARIMA加法季节模型 R实现 例题&#xff1a; 1.分类 2.简单指数平滑 简单移动平均法向前预测1期&#xff1a; …

ARIMA乘法季节模型

目录 ARIMA乘法季节模型 例题1 例题 2 例题3 ARIMA乘法季节模型 序列的季节效应、长期趋势效应和随机波动之间有着复杂的相互关联性,简单的季节模型不能充分地提取其中的相关关系&#xff0c;这时常采用乘积季节模型。 例题1 我国1949-2008年年末人口总数&#xff08;单…

机器学习之二分类LDA线性判别(最大特征值法)

目录 一、实验数学原理 二、算法实现步骤 三、实例分析 四、实验结果及分析 一、实验数学原理 线性判别分析((Linear Discriminant Analysis &#xff0c;简称 LDA)是一种经典的线性学习方法&#xff0c;在二分类问题上因为最早由 [Fisher,1936] 提出&#xff0c;亦称 ”Fi…

在布局空间标注的尺寸量不对_卫生间最佳布局尺寸,合理布局做到1毫米都不浪费!...

房子不论大小里面都会配置一个卫生间&#xff0c;卫生间分为大致三个区域&#xff0c;一个是洗涮区&#xff0c;可以在这里每天洗脸刷牙&#xff0c;还有就是淋浴区我们可以每天在这里洗澡&#xff0c;洗掉一天的疲惫。最后就是如厕区。这三大区域各个设计尺寸不同&#xff0c;…