color10 2.0.0.0
Main Page

Color 10 click

Color 10 Click is carrying VEML3328 sensor for RGB and IR light sensing as well as the RGB diode incorporated on the board which makes it good color detection device when its combined with a white LED. The VEML3328 sensor senses red, green, blue, clear and IR light by incorporating photodiodes, amplifiers, and analog / digital circuits into a single CMOS chip. With this sensor, the brightness and color temperature of a display backlight can be adjusted based on the ambient light source, and it can differentiate indoor from outdoor lighting environments.

click Product page


Click library

  • Author : MikroE Team
  • Date : Feb 2020.
  • Type : I2C type

Software Support

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

Package can be downloaded/installed directly form compilers IDE(recommended way), or downloaded from our LibStock, or found on mikroE github account.

Library Description

‍This library contains API for Color10 Click driver.

Standard key functions :

  • Config Object Initialization function.

    ‍void color10_cfg_setup ( color10_cfg_t *cfg );

    - Initialization function.

    ‍COLOR10_RETVAL color10_init ( color10_t *ctx, color10_cfg_t *cfg );

Example key functions :

  • This function reads data from the desired register.

    ‍uint16_t color10_generic_read ( color10_t *ctx, uint8_t cmd_addr );

  • This function calculates the color value.

    ‍float color10_get_color_value ( color10_t *ctx );

  • This function identifies the color using the color value.

    ‍uint8_t color10_get_color ( float color_value );

    Examples Description

‍Color 10 Click is carrying a sensor for RGB and IR light sensing as well as the RGB diode incorporated on the board which makes it good color detection device when its combined with a white LED.

The demo application is composed of two sections :

Application Init

‍Initialize I2C driver

void application_init ( void )
{
log_cfg_t log_cfg;
uint8_t id_data;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, "---- Application Init ----" );
// Click initialization.
COLOR10_MAP_MIKROBUS( cfg, MIKROBUS_1 );
color10_init( &color10, &cfg );
Delay_ms ( 500 );
if ( color10_get_id( &color10 ) == COLOR10_DEVICE_ID )
{
log_printf( &logger, " -DEVICE ID OK\r\n" );
}
else
{
log_printf( &logger, " -DEVICE ID ERROR\r\n" );
for( ; ; );
}
log_printf( &logger, "-----Init done------\r\n" );
Delay_ms ( 500 );
}
#define COLOR10_CFG_AUTO_MODE
Definition color10.h:109
#define COLOR10_CFG_POWER_ON
Definition color10.h:113
#define COLOR10_DEVICE_ID
Definition color10.h:91
#define COLOR10_CFG_INTEGRATION_TIME_SETT_50_MS
Definition color10.h:105
#define COLOR10_CFG_TRIGGER_NO
Definition color10.h:111
#define COLOR10_CFG_GAIN_2_X1
Definition color10.h:120
#define COLOR10_CFG_GAIN_1_X1
Definition color10.h:116
#define COLOR10_CFG_HIGH_DYNAMIC_RANGE_1
Definition color10.h:104
#define COLOR10_MAP_MIKROBUS(cfg, mikrobus)
Definition color10.h:66
void color10_cfg_setup(color10_cfg_t *cfg)
Config Object Initialization function.
COLOR10_RETVAL color10_init(color10_t *ctx, color10_cfg_t *cfg)
Initialization function.
uint8_t color10_get_id(color10_t *ctx)
ID retrieval function.
void color10_config(color10_t *ctx, uint16_t cfg_data)
Configuration function.
void application_init(void)
Definition main.c:104
Click configuration structure definition.
Definition color10.h:151

Application Task

‍This example senses orange, red, pink, purple, blue, cyan, green or yellow color and IR light and print it via UART terminal.

void application_task ( void )
{
uint16_t read_data;
float color_data;
read_data = color10_generic_read ( &color10, COLOR10_CMD_REG_IR );
log_printf( &logger, " -IR value: %d\r\n", read_data );
log_printf( &logger, " -Color: " );
log_printf( &logger, " ********************** \r\n" );
Delay_ms ( 1000 );
}
#define COLOR10_CMD_REG_IR
Definition color10.h:88
uint16_t color10_generic_read(color10_t *ctx, uint8_t cmd_addr)
Generic read function.
void write_color(void)
Definition main.c:36
void application_task(void)
Definition main.c:151

The full application code, and ready to use projects can be installed directly form compilers IDE(recommneded) or found on LibStock page or mikroE GitHub accaunt.

Other mikroE Libraries used in the example:

  • MikroSDK.Board
  • MikroSDK.Log
  • Click.Color10

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.