shutter 2.1.0.0
Main Page

Shutter click

‍Shutter Click is an adapter Click board™ used to implement an automated capturing feature. This Click board™ features one 3.5mm jack connector suitable for a camera connection with which the frame is captured. By combining two mikroBUS™ pins and the VO617A, a high-reliability phototransistor from Vishay Semiconductors used as a camera activation switch, activating the camera's Auto-Focus and the action of taking pictures is realized. This Click board™ allows you to expressly capture frames in a simple way for various types of photographic and security applications to capture those parts you need.

click Product page


Click library

  • Author : Stefan Filipovic
  • Date : Dec 2022.
  • Type : GPIO type

Software Support

We provide a library for the Shutter 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 from NECTO Studio Package Manager(recommended way), downloaded from our LibStock™ or found on Mikroe github account.

Library Description

‍This library contains API for Shutter Click driver.

Standard key functions :

Example key functions :

  • shutter_set_auto_focus This function sets the auto focus ON/OFF by setting the AF pin to desired logic state.
    void shutter_set_auto_focus ( shutter_t *ctx, uint8_t state );
    void shutter_set_auto_focus(shutter_t *ctx, uint8_t state)
    Shutter set auto focus function.
  • shutter_set_shutter This function sets the shutter ON/OFF by setting the SHT pin to desired logic state.
    void shutter_set_shutter ( shutter_t *ctx, uint8_t state );
    void shutter_set_shutter(shutter_t *ctx, uint8_t state)
    Shutter set shutter function.
  • shutter_take_picture This function sets AF and SHT pins to desired states for taking pictures with or without auto focus function.
    void shutter_take_picture ( shutter_t *ctx, uint8_t auto_focus );
    void shutter_take_picture(shutter_t *ctx, uint8_t auto_focus)
    Shutter take picture function.

Example Description

‍This example demonstrates the use of Shutter click board by taking pictures with and without auto focus function.

The demo application is composed of two sections :

Application Init

‍Initializes the driver and logger.

void application_init ( void )
{
log_cfg_t log_cfg;
shutter_cfg_t shutter_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, " Application Init " );
// Click initialization.
shutter_cfg_setup( &shutter_cfg );
SHUTTER_MAP_MIKROBUS( shutter_cfg, MIKROBUS_1 );
if ( DIGITAL_OUT_UNSUPPORTED_PIN == shutter_init( &shutter, &shutter_cfg ) )
{
log_error( &logger, " Communication init." );
for ( ; ; );
}
log_info( &logger, " Application Task " );
}
#define SHUTTER_MAP_MIKROBUS(cfg, mikrobus)
MikroBUS pin mapping.
Definition shutter.h:91
void application_init(void)
Definition main.c:30

Application Task

‍Swithes ON the auto focus function and triggers the shutter to take the picture, then

swithes OFF the auto focus and triggers the shutter. The shutter is triggered every 13 seconds approximately. All data is being logged on the USB UART where you can track the program flow.

void application_task ( void )
{
log_printf( &logger, " Take picture with auto focus\r\n\n" );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
log_printf( &logger, " Take picture without auto focus\r\n\n" );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
}
#define SHUTTER_STATE_OFF
Shutter state setting.
Definition shutter.h:72
#define SHUTTER_STATE_ON
Definition shutter.h:73
void application_task(void)
Definition main.c:60

The full application code, and ready to use projects can be installed directly from NECTO Studio Package Manager(recommended way), downloaded from our LibStock™ or found on Mikroe github account.

Other Mikroe Libraries used in the example:

  • MikroSDK.Board
  • MikroSDK.Log
  • Click.Shutter

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. UART terminal is available in all MikroElektronika compilers.