Skip to content

MikroElektronika/LightRanger_4_click

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MikroE


LightRanger4 Click

  • CIC Prefix : LIGHTRANGER4
  • Author : Katarina Perendic
  • Verison : 1.0.0
  • Date : sep 2018.

Software Support

We provide a library for the LightRanger4 Click on our LibStock page, as well as a demo application (example), developed using MikroElektronika compilers. The demo can run on all the main MikroElektronika development boards.

Library Description

The library initializes and defines the I2C bus driver and drivers that offer a choice for writing data in registers and reading data from registers. The library includes functions for full Configuration chip, sets measurement distance mode, inter measurement period, timing budget and user Roi. The user has the functions available for softReset, power on procedure, read distance of the object in front of the sensor.

Key functions :

  • uint8_t lightranger4_deviceConfiguration() - Functions for device configuration
  • void lightranger4_startMeasurement(uint32_t period_ms) - Functions for start measurement
  • uint16_t lightranger4_getDistance() - Function reads distance of the object in front of the sensor

Examples Description

The application is composed of three sections :

  • System Initialization - Initializes I2C module and set INT pin as INPUT and RST pin as OUTPUT
  • Application Initialization - Initializes the driver init, chip configuration, adjusts the LONG mode (distance measurement up to 4 meters), sets the time budget and start measurement with the adjustment of inter measurements period.
  • Application Task - (code snippet) - Reads the distance of the object in front of the sensor and logs distance to USBUART every 500 ms.
void applicationTask()
{
    while(lightranger4_newDataReady() != 0)
    {
        Delay_1ms();
    }

    distance = lightranger4_getDistance();
    IntToStr(distance, demoText);
    mikrobus_logWrite(" - Distance : ", _LOG_TEXT);
    mikrobus_logWrite(demoText, _LOG_TEXT);
    mikrobus_logWrite(" mm ", _LOG_LINE);

    measurementStatus = lightranger4_getRangeStatus();
    switch (measurementStatus)
    {
        case _LR4_MRESP_SIGNAL_FAIL:
        {
            mikrobus_logWrite( "Signal fail.", _LOG_LINE);
            break;
        }
        case _LR4_MRESP_PHASE_OUT_OF_VALID_LIMITS:
        {
            mikrobus_logWrite( "Phase out of valid limits", _LOG_LINE);
            break;
        }
        case _LR4_MRESP_SIGMA_FAIL:
        {
            mikrobus_logWrite( "Sigma Fail. ", _LOG_LINE);
            break;
        }
        case _LR4_MRESP_WRAP_TARGET_FAIL:
        {
            mikrobus_logWrite( "Wrap target fail.", _LOG_LINE);
            break;
        }
        case _LR4_MRESP_MINIMUM_DETECTION_THRESHOLD:
        {
            mikrobus_logWrite( "Target is below minimum detection threshold. ", _LOG_LINE);
            break;
        }
        default:
        {
            break;
        }
    }

    Delay_ms( 500 );
}

The full application code, and ready to use projects can be found on our LibStock page.

Other mikroE Libraries used in the example:

  • I2C

Additional notes and informations

Depending on the development board you are using, you may need USB UART click, USB UART 2 Click or RS232 Click to connect to your PC, for development systems with no UART to USB interface available on the board. The terminal available in all Mikroelektronika compilers, or any other terminal application of your choice, can be used to read the message.