Library to handle the X-NUCLEO-6180XA1 Proximity and ambient light sensor expansion board based on VL6180X.

Dependencies:   X_NUCLEO_COMMON ST_INTERFACES

Dependents:   HelloWorld_6180XA1 SunTracker_BLE Servo_6180XA1 BLE_HR_Light ... more

Fork of X_NUCLEO_6180XA1 by ST Expansion SW Team

X-NUCLEO-6180XA1 Proximity and Ambient Light Sensor Expansion Board Firmware Package

Introduction

This firmware package includes Components Device Drivers and Board Support Package for STMicroelectronics' X-NUCLEO-6180XA1 Proximity and ambient light sensor expansion board based on VL6180X.

Firmware Library

Class X_NUCLEO_6180XA1 is intended to represent the Proximity and ambient light sensor expansion board with the same name.

The expansion board is providing the support of the following components:

  1. on-board VL6180X proximity and ambient light sensor,
  2. up to three additional VL6180X Satellites,
  3. on-board 4-digit display

It is intentionally implemented as a singleton because only one X-NUCLEO-VL6180XA1 at a time might be deployed in a HW component stack. In order to get the singleton instance you have to call class method `Instance()`, e.g.:

// Sensors expansion board singleton instance
static X_NUCLEO_6180XA1 *6180X_expansion_board = X_NUCLEO_6180XA1::Instance();

Arduino Connector Compatibility Warning

Using the X-NUCLEO-6180XA1 expansion board with the NUCLEO-F429ZI requires adopting the following patch:

  • to remove R46 resistor connected to A3 pin;
  • to solder R47 resistor connected to A5 pin.

Alternatively, you can route the Nucleo board’s A5 pin directly to the expansion board’s A3 pin with a wire. In case you patch your expansion board or route the pin, the interrupt signal for the front sensor will be driven on A5 pin rather than on A3 pin.


Example Applications

History

Make compatible with non-copyable version of I2C. default tip

2017-08-21, by nikapov [Mon, 21 Aug 2017 15:44:34 +0000] rev 58

Make compatible with non-copyable version of I2C.


Aligned to ARM mbed coding style.

2017-03-13, by Davidroid [Mon, 13 Mar 2017 19:08:10 +0000] rev 57

Aligned to ARM mbed coding style.


Aligning to ARM mbed coding style.

2017-03-13, by davide.aliprandi@st.com [Mon, 13 Mar 2017 17:57:03 +0100] rev 56

Aligning to ARM mbed coding style.


Some modifications to fit mbed coding style.

2017-03-03, by Davidroid [Fri, 03 Mar 2017 15:06:18 +0000] rev 55

Some modifications to fit mbed coding style.


Aligned GetLux and GetDistance API with ST_INTERFACES, added isSensorxxPresentAPI, other minor fix.

2016-11-30, by mapellil [Wed, 30 Nov 2016 08:25:04 +0000] rev 54

Aligned GetLux and GetDistance API with ST_INTERFACES, added isSensorxxPresentAPI, other minor fix.


ST_INTERFACES added.

2016-09-27, by Davidroid [Tue, 27 Sep 2016 12:18:09 +0000] rev 53

ST_INTERFACES added.


ST_INTERFACES added.

2016-09-27, by Davidroid [Tue, 27 Sep 2016 12:03:25 +0000] rev 52

ST_INTERFACES added.


Disabled INT generation on 6180 GPIO1 pin in case of als or range single shot polling measures.

2016-09-12, by mapellil [Mon, 12 Sep 2016 09:10:29 +0000] rev 51

Disabled INT generation on 6180 GPIO1 pin in case of als or range single shot polling measures.


Added the GetDistance and GetLux API doing respectively a synchronous range_single_shot_polling and als_single_shot_polling measure in blocking mode

2016-09-09, by mapellil [Fri, 09 Sep 2016 09:50:12 +0000] rev 50

Added the GetDistance and GetLux API doing respectively a synchronous range_single_shot_polling and als_single_shot_polling measure in blocking mode


Removed board destructor (because of singleton object)

2016-06-15, by mapellil [Wed, 15 Jun 2016 11:55:18 +0000] rev 49

Removed board destructor (because of singleton object)