基于STM32CUBEMX驱动TOF模块VL6180与VL6180X(5)----驱动多个VL6180X

发布者:心灵舞者最新更新时间:2024-06-21 来源: elecfans关键字:STM32CUBEMX  VL6180X 手机看文章 扫描二维码
随时随地手机看文章

概述

在本章中,我们将探讨如何同时驱动多个VL6180传感器进行距离测量。我们将介绍如何有效地管理多个传感器之间的通信和控制,以确保它们能够同时进行准确的距离测量。此外,还将扩展我们的教程,展示如何同时驱动多个VL6180X传感器进行距离测量和光强测量。VL6180X传感器在VL6180的基础上增加了光强测量功能,这使得它们能够提供关于环境光强度的有用信息。对于那些需要考虑光照条件的应用场景,这将非常重要。我们将讨论如何使用适当的命令和配置设置,同时利用两个传感器的功能,以获取准确的距离和光强度数据。通过本章的学习,将能够了解如何利用多个VL6180X传感器的优势,为应用程序提供更全面的环境感知能力。
在这里插入图片描述

样品申请

https://www.wjx.top/vm/OhcKxJk.aspx#](https://www.wjx.top/vm/OhcKxJk.aspx#)

视频教程

https://www.bilibili.com/video/BV1mW4y1o7yY/

完整代码下载

https://download.csdn.net/download/qq_24312945/88051751

修改设备地址

在修改设备地址方面,VL6180X传感器使用I²C总线进行通信。默认情况下,每个VL6180X传感器的7位地址为0x29。然而,为了避免地址冲突并允许多个传感器共享相同的I2C总线,用户可以通过向特定寄存器写入自定义的7位地址来修改传感器的地址。
要修改传感器的地址,您需要访问寄存器I2C_SLAVE__DEVICE_ADDRESS,其地址为0x212。通过向该寄存器写入新的7位地址,您可以成功修改传感器的地址。请注意,每个传感器都需要具有唯一的地址,以确保正确的通信和识别。
在这里插入图片描述

需要注意的是,通过修改寄存器I2C_SLAVE__DEVICE_ADDRESS(地址为0x212)来修改VL6180X传感器的地址是一种临时性的设置。每次传感器上电后,地址会恢复为初始值(默认为0x29)。这意味着在每次上电后,需要重新设置传感器的地址,以确保正确的通信和操作。
在这里插入图片描述

首先,打开VL6180.h文件,该文件包含了VL6180X传感器的相关定义和配置。在该文件中,您可以找到定义设备地址的部分,并进行以下方式的地址常量定义:

#define VL6180X_DEFAULT_I2C_ADDR1 0x29  ///< The fixed I2C addres

#define VL6180X_DEFAULT_I2C_ADDR2 0x2A  ///< The fixed I2C addres

#define VL6180X_DEFAULT_I2C_ADDR3 0x2B  ///< The fixed I2C addres

#define VL6180X_DEFAULT_I2C_ADDR4 0x2C  ///< The fixed I2C addres


以上示例展示了四个设备地址常量的定义,分别表示不同的传感器。可以根据您实际使用的传感器数量和配置需求,增加或减少设备地址常量的定义。
在代码中,可以使用这些设备地址常量来指定不同传感器的地址。例如,如果想要使用第一个传感器的地址,可以使用DEVICE_ADDRESS_1来表示该地址。请注意,需要根据实际情况将这些地址常量与传感器的物理连接和配置相对应。确保将正确的地址常量分配给相应的传感器,以确保正确的通信和操作。
在进行地址常量定义时,建议参考VL6180X传感器的数据手册和相关文档,以了解更多关于传感器地址和配置的详细信息。
这里的地址值是根据实际需求和硬件连接情况选择的,确保每个设备具有唯一的地址是非常重要的。通过使用定义的设备地址常量,可以轻松地管理和操作多个VL6180X传感器。通过为每个传感器分配唯一的设备地址常量,可以在代码中使用这些常量来指定与每个传感器对应的地址。这样,可以轻松地区分不同的传感器,并发送适当的命令和配置来与每个传感器进行通信和操作。通过使用定义的设备地址常量,可以轻松管理和操作多个传感器,无需手动跟踪和设置每个传感器的地址。这提供了方便和灵活性,特别适用于需要同时使用多个VL6180X传感器的应用场景。


配置vl6180x

在对应的demo板子中,管脚图如下所示。
在这里插入图片描述
在下面代码中,展示了对多个VL6180X传感器进行初始化和配置的过程。每个传感器通过不同的管脚连接到主板上,并通过控制GPIO引脚的电平来选择对应的传感器进行操作。
以下是对代码的扩展说明:

  1. 首先,通过控制GPIO引脚的电平,将相应的引脚设置为RESET状态,以准备初始化对应的传感器。具体来说,对于每个传感器,通过控制两个GPIO引脚,即片选,将它们设置为RESET状态。

  2. 然后,通过控制GPIO引脚的电平,将相应的引脚设置为SET状态,以选择对应的传感器进行操作。对于每个传感器,通过控制两个GPIO引脚,即片选,将它们设置为SET状态。

  3. 在每次切换传感器之后,添加了一段延时,以确保引脚状态的切换稳定。这段延时的长度可以根据实际需求进行调整。
    对每个传感器执行以下操作:
    a. 初始化传感器,使用VL6180X_Init函数,将传感器的地址作为参数传递。
    b. 通过VL6180X_WriteByte函数,修改传感器的地址,使用VL6180X_DEFAULT_I2C_ADDR1作为源地址,将自定义地址写入0x0212寄存器。
    c. 使用VL6180X_ReadByte函数读取修改后的地址,并进行打印输出,以确认地址修改成功。
    d. 使用VL6180x_UpscaleSetScaling函数设置传感器的缩放因子。
    e. 使用VL6180X_Read_ID函数读取传感器的ID,并进行打印输出,以确认传感器正常工作。
    通过代码,可以初始化和配置多个VL6180X传感器,并根据需要选择不同的传感器进行操作。请注意,以上代码示例仅为参考,您需要根据自己的硬件连接和需求进行相应的修改和调整。确保参考VL6180X传感器的文档和数据手册,以了解更多关于初始化、配置和操作传感器的详细信息。


/* USER CODE BEGIN 2 */

//VL6180_1

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_1, GPIO_PIN_RESET);

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_2, GPIO_PIN_RESET);

//VL6180_3

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_8, GPIO_PIN_RESET);

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_9, GPIO_PIN_RESET);

//VL6180_2

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_13, GPIO_PIN_RESET);

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_14, GPIO_PIN_RESET);

//VL6180_4

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_4, GPIO_PIN_SET);

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_5, GPIO_PIN_SET);

uint8_t ii;

uint8_t id;

HAL_Delay(1);


/************修改VL6180_4地址为VL6180X_DEFAULT_I2C_ADDR4(0x2C)*********************/

VL6180X_Init(VL6180X_DEFAULT_I2C_ADDR1);

VL6180X_WriteByte(VL6180X_DEFAULT_I2C_ADDR1,0x0212,VL6180X_DEFAULT_I2C_ADDR4);

// HAL_Delay(100);

ii=VL6180X_ReadByte(VL6180X_DEFAULT_I2C_ADDR4,0x0212);

printf('VL6180_4地址为=0x%Xn',ii);

VL6180x_UpscaleSetScaling(VL6180X_DEFAULT_I2C_ADDR4,3);//缩放x3

id=VL6180X_Read_ID(VL6180X_DEFAULT_I2C_ADDR4);

printf('VL6180_4 id=%dn',id);


/************修改VL6180_3地址为VL6180X_DEFAULT_I2C_ADDR3(0x2B)*********************/

//VL6180_3

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_8, GPIO_PIN_SET);

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_9, GPIO_PIN_SET);

HAL_Delay(1);

VL6180X_Init(VL6180X_DEFAULT_I2C_ADDR1);

VL6180X_WriteByte(VL6180X_DEFAULT_I2C_ADDR1,0x0212,VL6180X_DEFAULT_I2C_ADDR3);

ii=VL6180X_ReadByte(VL6180X_DEFAULT_I2C_ADDR3,0x0212);

printf('VL6180_3地址为=0x%Xn',ii);

VL6180x_UpscaleSetScaling(VL6180X_DEFAULT_I2C_ADDR3,3);//缩放x3

id=VL6180X_Read_ID(VL6180X_DEFAULT_I2C_ADDR3);

printf('VL6180_3 id=%dn',id);


/************修改VL6180_2地址为VL6180X_DEFAULT_I2C_ADDR2(0x2A)*********************/

//VL6180_2

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_13, GPIO_PIN_SET);

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_14, GPIO_PIN_SET);

HAL_Delay(1);

VL6180X_Init(VL6180X_DEFAULT_I2C_ADDR1);

VL6180X_WriteByte(VL6180X_DEFAULT_I2C_ADDR1,0x0212,VL6180X_DEFAULT_I2C_ADDR2);

// HAL_Delay(100);

ii=VL6180X_ReadByte(VL6180X_DEFAULT_I2C_ADDR2,0x0212);

printf('VL6180_2地址为=0x%Xn',ii);

VL6180x_UpscaleSetScaling(VL6180X_DEFAULT_I2C_ADDR2,3);//缩放x3

id=VL6180X_Read_ID(VL6180X_DEFAULT_I2C_ADDR2);

printf('VL6180_2 id=%dn',id);

/************修改VL6180_1地址为VL6180X_DEFAULT_I2C_ADDR3(0x29)*********************/

//VL6180_1

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_1, GPIO_PIN_SET);

HAL_GPIO_WritePin(GPIOB, GPIO_PIN_2, GPIO_PIN_SET);

HAL_Delay(1);

VL6180X_Init(VL6180X_DEFAULT_I2C_ADDR1);

// VL6180X_WriteByte(VL6180X_DEFAULT_I2C_ADDR1,0x0212,VL6180X_DEFAULT_I2C_ADDR1);

ii=VL6180X_ReadByte(VL6180X_DEFAULT_I2C_ADDR1,0x0212);

printf('VL6180_1地址为=0x%Xn',ii);

VL6180x_UpscaleSetScaling(VL6180X_DEFAULT_I2C_ADDR1,3);//缩放x3

id=VL6180X_Read_ID(VL6180X_DEFAULT_I2C_ADDR1);

printf('VL6180_1 id=%dn',id);


  /* USER CODE END 2 */

主程序

在代码中,展示了如何在主程序中循环读取4个VL6180X传感器的数据。以下是代码的扩展说明:


在主程序的while循环中,首先使用VL6180X_Read_Range函数从VL6180X传感器4(设备地址为VL6180X_DEFAULT_I2C_ADDR4)读取距离数据,并将其乘以3(根据缩放因子)以得到准确的距离值。然后,使用printf函数打印输出距离值。

接下来,使用VL6180X_Read_Lux函数从VL6180X传感器3(设备地址为VL6180X_DEFAULT_I2C_ADDR3)读取光强度数据,并使用printf函数打印输出光强度值。请注意,此处使用了指定的增益参数(VL6180X_ALS_GAIN_40),您可以根据实际需求选择适当的增益值。

然后,使用VL6180X_Read_Range函数从VL6180X传感器2(设备地址为VL6180X_DEFAULT_I2C_ADDR2)读取距离数据,并将其乘以3(根据缩放因子)以得到准确的距离值。然后,使用printf函数打印输出距离值。

接下来,使用VL6180X_Read_Lux函数从VL6180X传感器1(设备地址为VL6180X_DEFAULT_I2C_ADDR1)读取光强度数据,并使用printf函数打印输出光强度值。同样地,使用指定的增益参数(VL6180X_ALS_GAIN_40),您可以根据实际需求选择适当的增益值。

最后,在每次循环迭代之间添加适当的延时,例如使用HAL_Delay函数延时1秒。

请注意,代码示例仅为参考,您需要根据您的实际硬件配置、VL6180X库和应用需求进行相应的修改和调整。确保参考VL6180X传感器的文档和数据手册,以了解更多关于数据读取和解析的详细信息。

/* USER CODE BEGIN WHILE */

  while (1)

  {

VL6180_L4=VL6180X_Read_Range(VL6180X_DEFAULT_I2C_ADDR4);

printf('VL6180_L4=%dmmn',VL6180_L4*3);

lux_L3=VL6180X_Read_Lux(VL6180X_DEFAULT_I2C_ADDR3,VL6180X_ALS_GAIN_40);

printf('lux=%lfn',lux_L3);

VL6180_L3=VL6180X_Read_Range(VL6180X_DEFAULT_I2C_ADDR3);

printf('VL6180_L3=%dmmn',VL6180_L3*3);

VL6180_L2=VL6180X_Read_Range(VL6180X_DEFAULT_I2C_ADDR2);

printf('VL6180_L2=%dmmn',VL6180_L2*3);

lux_L1=VL6180X_Read_Lux(VL6180X_DEFAULT_I2C_ADDR1,VL6180X_ALS_GAIN_40);

printf('lux=%lfn',lux_L1);

VL6180_L3=VL6180X_Read_Range(VL6180X_DEFAULT_I2C_ADDR1);

printf('VL6180_L1=%dmmn',VL6180_L1*3);

HAL_Delay(1000);

    /* USER CODE END WHILE */


    /* USER CODE BEGIN 3 */

  }

  /* USER CODE END 3 */


测试结果

测试结果如下所示。
在这里插入图片描述


关键字:STM32CUBEMX  VL6180X 引用地址:基于STM32CUBEMX驱动TOF模块VL6180与VL6180X(5)----驱动多个VL6180X

上一篇:工程师笔记|如何理解 RAMECC FAR 寄存器的值
下一篇:基于STM32CUBEMX驱动TOF模块VL6180与VL6180X(1)----单模块距离获取的最佳实践

推荐阅读最新更新时间:2024-11-02 15:50

使用HAL库、STM32CubeMX和Keil 5开发入门教程(二):GPIO
文转载自http://blog.csdn.net/charmingsun/article/details/52095563 有关软件的使用以及其它准备工作请参考: 使用HAL库、STM32CubeMX和Keil 5开发入门教程(一):点亮一盏LED灯(NUCLEO-F411RE) 一、API说明 HAL库一共包含如下6个IO操作函数: 1、读取某个引脚的电平状态: HAL_GPIO_ReadPin() 2、写入某个引脚的电平状态: HAL_GPIO_WritePin() 3、翻转某个引脚的电平状态: HAL_GPIO_TogglePin() 4、锁定某个引脚的配置状态(直到下次复位): HAL_GPIO_LockPin()
[单片机]
STM32CubeMX系列教程04_STM32CubeMX各窗口界面描述
一、写在前面 上一篇文章让你入门STM32CubeMX,你可能还是会觉得心里摸不到底。本文就从另外一个角度带你了解STM32CubeMX。 本文讲述STM32CubeMX各主要界面内容,让你对STM32CubeMX这个工具有一个比较直观的认识。 二、主界面 打开STM32CubeMX,呈现的界面大致如下图,界面比较简洁。我把它划分为六大板块。 1.菜单 STM32CubexMX V4版本(前面老版本)有很多功能做在菜单里面,但V5版本优化(删减)菜单,把一些常用功能做在相应界面里面了。 菜单内容后面会单独详细讲述。 2.社交链接 facebook(脸书)、youtube、twitter(推特)以及ST社区、官
[单片机]
<font color='red'>STM32CubeMX</font>系列教程04_STM32CubeMX各窗口界面描述
STM32CubeMX中文用户手册下载方法
STM32CubeMX是用于STM32微控制器的图形工具,可以用图形化的方式生成工程代码。现在官方也有了这个软件的中文手册,现在说一下STM32CubeMX的中文手册下载方法。 打开官网网站 https://www.st.com/en/development-tools/stm32-configurators-and-code-generators.html#documentation 然后在上面选中最后一项 Documentation,然后选中底下的 User Manual 在底下就会显示一个日文版和中文版的资料,直接点中国国旗这一项。 这时就会在网页中直接打开PDF文档,可以直接在网页上看,也可以点PDF文档右
[单片机]
<font color='red'>STM32CubeMX</font>中文用户手册下载方法
STM32CubeMX:UART操作
UART共有三种操作方式,轮询方式、中断方式以及DMA方式。 芯片:STM32F103C8T6 应用管脚: 输出:PA0、PA1 USART1 配置界面 添加中断配置 添加DMA配置 代码应用 1.实现printf函数 /* USER CODE BEGIN 0 */ #ifdef __GNUC__ /* With GCC/RAISONANCE, small printf (option LD Linker- Libraries- Small printf set to 'Yes') calls __io_putchar() */ #define PUTCHAR_PROTO
[单片机]
<font color='red'>STM32CubeMX</font>:UART操作
STM32CubeMx定时器编码器模式基本使用方法
前言: 增量式编码器在实际应用中还是很常见。 stm32的定时器带的也有编码器模式。 所用的编码器是有ABZ三相,其中ab相是用来计数,z相输出零点信号。 AB相根据旋转的方向不同,输出的波形如下图所示: 第一步:具体配置如下图: 重点说明: 一、如果编码模式设置为 Encoder Mode TI1 and TI2 则会默认检测AB相的上升沿与下降沿; 每一个上升沿和下降沿都触发计数,所以每转一格计数器就会+4;那么上图计数周期设置为400; 也就是编码器转100格,计数器就会置零,重新开始计数! 二、关于Polarity参数:这个参数的意思是在检测到上升沿的时候就触发encoder捕获AB相的值,而并不是这里设置的是上
[单片机]
<font color='red'>STM32CubeMx</font>定时器编码器模式基本使用方法
【STM32】HAL库 STM32CubeMX教程十二---IIC(读取AT24C02 )
前言: 本系列教程将HAL库与STM32CubeMX结合在一起讲解,使您可以更快速的学会各个模块的使用 在之前的标准库中,STM32的硬件IIC非常复杂,更重要的是它并不稳定,所以都不推荐使用。 但是在我们的HAL库中,对硬件IIC做了全新的优化,使得之前软件IIC几百行代码,在HAL库中,只需要寥寥几行就可以完成 那么这篇文章将带你去感受下它的优异之处 这可能是目前关于STM32CubeMX的硬件iic 讲的最全面和详细的一篇文章之一了 所用工具: 1、芯片: STM32F103ZET6 2、STM32CubeMx软件 3、IDE: MDK-Keil软件 4、STM32F1xx/STM32F4xxHAL库 5、II
[单片机]
【STM32】HAL库 <font color='red'>STM32CubeMX</font>教程十二---IIC(读取AT24C02 )
STM32CubeMX:ETH
芯片:STM32F107VCT6 应用管脚: MII、RMII STM32CubeMX使用ETH相当方便,软件自带LWIP及配置,本次使用STM32F107VCT6+DP83848CVV,MII应用采用DP83848CVV自带25M晶振,RMII应用采用PA8产生50M脉冲。 MII配置界面 LWIP配置IP(可选择DHCP功能) 应用函数 /* USER CODE BEGIN WHILE */ while (1) { /* USER CODE END WHILE */ /* USER CODE BEGIN 3 */ MX_LWIP_Process(); } /* USER C
[单片机]
STM32CubeMX系列教程 5.0版本环境开发——2.Uart串行通信功能
1.搭建一个基本工程: 具体请参考我的上一篇内容搭建:https://www.cnblogs.com/Engineer-Lai/p/10072673.html 2.Uart协议简要: 分为通俗描述和概念性描述 通俗描述: 1. 对于单片机入门的人来说,首先我们要明白 我们唯一可控的对象是IO口,IO有两种状态 0和1. 有两种操作读和写(请务必确认自己明白并可以操控,我们便可继续) 2.在确认第一点后,硬件协议存在的意义是什么:A对象 把N个数据遵照特定的规则传给 B对象.(这里数据的单位是字节,一个字节由8个位组成) 3.接下来就是如何传数据的问题了,我们只有0和1可以表示。所以我们必须制定一套双方都遵循的可行游戏规则。
[单片机]
<font color='red'>STM32CubeMX</font>系列教程 5.0版本环境开发——2.Uart串行通信功能
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved