Skip to content

cdjq/DFRobot_LTR308

Repository files navigation

DFRobot_LTR308

The LTR-308ALS-SYM is an integrated low voltage I2C ambient light sensor (ALS) in a single 2x2mm miniature chipled lead-free surface mount package. The ALS provides a linear response over a wide dynamic range, which is well suited to applications under very low or bright ambient brightness. The sensor has a programmable interrupt with hysteresis to response to events and that removes the need to poll the sensor for a reading which improves system efficiency. This CMOS design and factory-set one time trimming capability ensure minimal sensor-to-sensor variations for ease of manufacturability to the end customers.

Table of Contents

Summary

Obtain ambient light source data, which can be converted to lux according to the raw data obtained. To set the interrupt, you can set the upper and lower limit of the light source, and set the upper and lower value boundary to trigger several times, the interrupt is triggered.

Installation

First download the library file, paste it into the \Arduino\libraries directory, then open the examples folder and run the demo in that folder.

Methods

/**
 * @fn begin
 * @brief Initialize the function.
 * @return bool ,Indicates the initialization state.
 */
bool begin(void);

/**
 * @fn setPowerUp
 * @brief Set the Power Up LTR308.
 */
void setPowerUp(void);

/**
 * @fn setPowerDown
 * @brief Set the Power Down LTR308
 */
void setPowerDown(void);

/**
 * @fn getPower
 * @brief Get the Power value
 * @return uint8_t: content of LTR308_CONTR control register
 */
uint8_t getPower(void);

/**
 * @fn setGain
 * @brief Set the Gain of LTR308
 * @param gain eGain_t
 * @n eGain_1X        device is set to 1X gain
 * @n eGain_3X        device is set to 3X gain (Sensor default)
 * @n eGain_6X        device is set to 6X gain
 * @n eGain_9X        device is set to 9X gain
 * @n eGain_18X       device is set to 18X gain
 */
void setGain(eGain_t gain);

/**
 * @fn getGain
 * @brief Get the Gain of LTR308
 * @return uint8_t: the control register values
 * @retval 0      device is set to 1X gain
 * @retval 1      device is set to 3X gain (Sensor default)
 * @retval 2      device is set to 6X gain
 * @retval 3      device is set to 9X gain
 * @retval 4      device is set to 18X gain
 */
uint8_t getGain(void);

/**
 * @fn setMeasurementRate
 * @brief Set the Measurement Rate and resolution
 * @param measRate: (sMeasRate_t)  Measurement Rate and resolution
 * @n measRate.resolution (eResolution_t)
 * @n eConversion_400ms_20b     20 Bit result, Conversion time = 400ms.
 * @n eConversion_200ms_19b     19 Bit result, Conversion time = 200ms.
 * @n eConversion_100ms_18b     18 Bit result, Conversion time = 100ms.(Sensor default)
 * @n eConversion_50ms_17b      17 Bit result, Conversion time = 50ms.
 * @n eConversion_25ms_16b      16 Bit result, Conversion time = 25ms.
 * @n -------------------------------------------------------------------------------------------
 * @n measRate.measurementRate (eMeasurementRate_t)
 * @n eRate_25ms       Measurement Rate will be 25ms.
 * @n eRate_50ms       Measurement Rate will be 50ms.
 * @n eRate_100ms      Measurement Rate will be 100ms.(Sensor default)
 * @n eRate_500ms      Measurement Rate will be 500ms.
 * @n eRate_1000ms     Measurement Rate will be 1000ms.
 * @n eRate_2000ms     Measurement Rate will be 2000ms.
 * @n eRate_2000ms_2   Measurement Rate will be 2000ms.
 */
void setMeasurementRate(sMeasRate_t measRate);

/**
 * @fn setMeasurementRate
 * @brief Set the Measurement Rate and resolution
 * @param resolution: (eResolution_t)  The measurement time for each ALs cycle
 * @n eConversion_400ms_20b     20 Bit result, Conversion time = 400ms.
 * @n eConversion_200ms_19b     19 Bit result, Conversion time = 200ms.
 * @n eConversion_100ms_18b     18 Bit result, Conversion time = 100ms.(Sensor default)
 * @n eConversion_50ms_17b      17 Bit result, Conversion time = 50ms.
 * @n eConversion_25ms_16b      16 Bit result, Conversion time = 25ms.
 * @param measurementRate: (eMeasurementRate_t)  The interval between DATA_REGISTERS update
 * @n eRate_25ms       Measurement Rate will be 25ms.
 * @n eRate_50ms       Measurement Rate will be 50ms.
 * @n eRate_100ms      Measurement Rate will be 100ms.(Sensor default)
 * @n eRate_500ms      Measurement Rate will be 500ms.
 * @n eRate_1000ms     Measurement Rate will be 1000ms.
 * @n eRate_2000ms     Measurement Rate will be 2000ms.
 * @n eRate_2000ms_2   Measurement Rate will be 2000ms.
 */
void setMeasurementRate(eResolution_t resolution, eMeasurementRate_t measurementRate);

/**
 * @fn getMeasurementRate
 * @brief Get the Measurement Rate and resolution
 * @return sMeasRate_t: Measurement Rate and resolution
 * @retval sMeasRate_t.resolution (eResolution_t)
 * @retval 0      20 Bit result, Conversion time = 400ms.
 * @retval 1      19 Bit result, Conversion time = 200ms.
 * @retval 2      18 Bit result, Conversion time = 100ms.(Sensor default)
 * @retval 3      17 Bit result, Conversion time = 50ms.
 * @retval 4      16 Bit result, Conversion time = 25ms.
 * @retval -------------------------------------------------------------------------------------------
 * @retval sMeasRate_t.measurementRate (eMeasurementRate_t)
 * @retval 0      Measurement Rate will be 25ms.
 * @retval 1      Measurement Rate will be 50ms.
 * @retval 2      Measurement Rate will be 100ms.(Sensor default)
 * @retval 3      Measurement Rate will be 500ms.
 * @retval 5      Measurement Rate will be 1000ms.
 * @retval 6      Measurement Rate will be 2000ms.
 * @retval 7      Measurement Rate will be 2000ms.
 */
sMeasRate_t getMeasurementRate(void);

/**
 * @fn getPartID
 * @brief Gets the part number ID and revision ID of the chip
 * @return uint8_t: Default value is 0xB1, part number ID = 0xB, revision ID = 0x1.
 */
uint8_t getPartID(void);

/**
 * @fn getStatus
 * @brief Get the Status of LTR308
 * @return sMainStatus_t: The status information of LTR308.
 * @retval If sMainStatus_t.ponStatus = false(0), power on event (default)
 * @retval If sMainStatus_t.ponStatus = true(1), not specified in datasheet
 * @retval -------------------------------------------------------------------------------------------
 * @retval If sMainStatus_t.intrStatus = false(0), Interrupt is NOT triggered (default)
 * @retval If sMainStatus_t.intrStatus = true(1), Interrupt is triggered and will be cleared after read
 * @retval -------------------------------------------------------------------------------------------
 * @retval If sMainStatus_t.dataStatus = false(0), ALS data is old (Data has been read)
 * @retval If sMainStatus_t.dataStatus = true(1), ALS data is new data (Data has not been read and will be cleared after read)
 */
sMainStatus_t getStatus(void);

/**
 * @fn getData
 * @brief Get the ALS channel data
 * @return uint32_t: ALS data, Default value is 0
 */
uint32_t getData(void);

/**
 * @fn setInterruptControl
 * @brief Set the Interrupt Control of LTR308
 * @param mode: interrupt mode
 * @n If mode = false(0), ALS interrupt disabled (default)
 * @n If mdoe = true(1), ALS interrupt enabled
 */
void setInterruptControl(bool mode);

/**
 * @fn getInterruptControl
 * @brief Get the Interrupt Control of LTR308
 * @return bool: interrupt mode
 * @retval true: ALS interrupt enabled
 * @retval false: ALS interrupt disabled
 */
bool getInterruptControl(void);

/**
 * @fn setIntrPersist
 * @brief Set the Intr Persist of LTR308
 * @param persist: controls the N number of times the measurement data is outside the range defined by upper and lower threshold
 * @n eInterruptTrigger_1     Every ALS value out of threshold range asserts an interrupt (default)
 * @n eInterruptTrigger_2     2 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_3     3 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_4     4 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_5     5 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_6     6 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_7     7 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_8     8 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_9     9 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_10    10 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_11    11 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_12    12 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_13    13 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_14    14 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_15    15 consecutive ALS values out of threshold range assert an interrupt
 * @n eInterruptTrigger_16    16 consecutive ALS values out of threshold range assert an interrupt
 */
void setIntrPersist(eIntrPersist_t persist);

/**
 * @fn getIntrPersist
 * @brief Get the Intr Persist of LTR308
 * @return uint8_t: controls the N number of times the measurement data is outside the range defined by upper and lower threshold
 * @retval 0      Every ALS value out of threshold range asserts an interrupt (default)
 * @retval 1      2 consecutive ALS values out of threshold range assert an interrupt
 * @retval 2      3 consecutive ALS values out of threshold range assert an interrupt
 * @retval 3      4 consecutive ALS values out of threshold range assert an interrupt
 * @retval 4      5 consecutive ALS values out of threshold range assert an interrupt
 * @retval 5      6 consecutive ALS values out of threshold range assert an interrupt
 * @retval 6      7 consecutive ALS values out of threshold range assert an interrupt
 * @retval 7      8 consecutive ALS values out of threshold range assert an interrupt
 * @retval 8      9 consecutive ALS values out of threshold range assert an interrupt
 * @retval 9      10 consecutive ALS values out of threshold range assert an interrupt
 * @retval 10     11 consecutive ALS values out of threshold range assert an interrupt
 * @retval 11     12 consecutive ALS values out of threshold range assert an interrupt
 * @retval 12     13 consecutive ALS values out of threshold range assert an interrupt
 * @retval 13     14 consecutive ALS values out of threshold range assert an interrupt
 * @retval 14     15 consecutive ALS values out of threshold range assert an interrupt
 * @retval 15     16 consecutive ALS values out of threshold range assert an interrupt
 */
uint8_t getIntrPersist(void);

/**
 * @fn setThreshold
 * @brief Sets the upper limit and lower limit of the threshold
 * @param thres: upperLimit and lowerLimit
 * @n thres.upperLimit (up to 20-bits) (default 0x0FFFFF)
 * @n thres.lowerLimit (up to 20-bits) (default 0x000000)
 */
void setThreshold(sThres_t thres);

/**
 * @fn setThreshold
 * @brief Sets the upper limit and lower limit of the threshold
 * @param upperLimit: (up to 20-bits) (default 0x0FFFFF)
 * @param lowerLimit: (up to 20-bits) (default 0x000000)
 */
void setThreshold(uint32_t upperLimit, uint32_t lowerLimit);

/**
 * @fn getThreshold
 * @brief Gets the upper limit and lower limit of the threshold
 * @return sThres_t: upperLimit and lowerLimit
 * @retval sThres_t.upperLimit (up to 20-bits) (default 0x0FFFFF)
 * @retval sThres_t.lowerLimit (up to 20-bits) (default 0x000000)
 */
sThres_t getThreshold();

/**
 * @fn getLux
 * @brief Convert raw data to lux  (Lux = (0.6 * ALSDATA) / (GAIN * INT))
 * @param gain: The gain of this sensor
 * @param resolution: The resolution of this sensor
 * @param alsData: The ALS Data of this sensor
 * @return double: The converted lux value
 */
double getLux(eGain_t gain, eResolution_t resolution, uint32_t alsData);

/**
 * @fn getLux
 * @brief Convert raw data to lux   (Lux = (0.6 * ALSDATA) / (GAIN * INT))
 * @param alsData: The ALS Data of this sensor
 * @return double: The converted lux value
 */
double getLux(uint32_t alsData);

Compatibility

MCU Work Well Work Wrong Untested Remarks
Arduino Uno
Arduino MEGA2560
Arduino Leonardo
ESP8266
ESP32
FireBeetle-M0
Micro:bit

History

  • 2024/07/30 - V0.1 version

Credits

Written by thdyyl(yuanlong.yu@dfrobot.com), 2024. (Welcome to our website)

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages