Custom Code: Difference between revisions

From Visuino
Jump to navigation Jump to search
No edit summary
No edit summary
Line 2: Line 2:


== Summary ==
== Summary ==
Custom Code component in '''Visuino Professional''' lets you inject arbitrary C/C++/Arduino code into your visual program.   
The '''Custom Code''' component in '''Visuino Professional''' lets you inject arbitrary C/C++/Arduino code directly into your visual program.   
It removes limitations of built-in components and allows integration of unsupported sensors, libraries, hardware modules, or protocols — providing nearly unlimited flexibility in what can be created.
It removes the limitations of built-in components and allows integration of unsupported sensors, libraries, hardware modules, or protocols — providing nearly unlimited flexibility in what can be created.


== Description ==
== Description ==
The '''Custom Code''' component is one of the most powerful features of ''Visuino Professional''.   
The '''Custom Code''' component is one of the most powerful features of ''Visuino Professional''.   
It is designed to fill gaps whenever a sensor, module, protocol, or function is not natively supported by Visuino.   
It is designed to fill gaps whenever a sensor, module, protocol, or function is not natively supported by Visuino.   
With this component you can embed your own C++/Arduino code to extend Visuino’s capabilities with minimal restrictions.
With this component, you can embed your own C++/Arduino code to extend Visuino’s capabilities with minimal restrictions.


'''Key Features:'''
'''Key Features:'''
Line 15: Line 15:
* Ability to implement any hardware communication protocol (e.g. Modbus, CANBus, MQTT, REST).
* Ability to implement any hardware communication protocol (e.g. Modbus, CANBus, MQTT, REST).
* '''Live Code''' view lets you inspect and debug the generated code in real time.
* '''Live Code''' view lets you inspect and debug the generated code in real time.
* Works seamlessly with professional features such as '''SubDiagrams''', industrial protocols, and device  
* Works seamlessly with professional features such as '''SubDiagrams''', industrial protocols, and device-specific customization.


<b>Diagram:</b>
<b>Diagram:</b>
Line 22: Line 22:


== Properties ==
== Properties ==
*'''Defines''' – Preprocessor definitions and macros (Default: 0 items).
* '''Defines''' – Preprocessor definitions and macros (Default: 0 items).
*'''Global Declarations''' – Global variable and function declarations (Default: 0 items).
* '''Includes''' – Header file inclusions and import statements (Default: 0 items).
*'''Global Implementations''' – Global function implementations (Default: 0 items).
* '''Global Declarations''' – Global variable and function declarations (Default: 0 items).
*'''Includes''' – Header file inclusions and import statements (Default: 0 items).
* '''Global Implementations''' – Global function implementations (Default: 0 items).
*'''Inputs''' – Opens a window where you can add input pins of various data types:   
* '''Libraries''' – External library dependencies and linkages (Default: 0 items).
* '''Members''' – Class member variables and methods (Default: 0 items).
* '''Name''' – Component identifier (Default: CustomCode).
 
=== Execution Hooks ===
* '''On Init''' – Code executed during the initialization phase of the Arduino program. 
Typically used for hardware initialization. Here you place `begin()` calls or other setup logic that prepares devices before use. 
This code is generated inside the `setup()` function.
* '''On Start''' – Code executed immediately after initialization. 
Useful for sending initial values, printing startup information, or communicating with components right after initialization. 
This code is also generated inside the `setup()` function, but runs after `On Init`.
* '''On Execute''' – Code executed in the main program loop. 
By default, this runs continuously like `loop()`. 
If a Clock input pin is connected, the code is executed only when a clock event occurs.
* '''On Update Hardware''' – Code executed at the very end of the loop cycle. 
Typically used to update hardware that requires pre-calculated values or last-moment synchronization.
 
=== Inputs ===
Opens a window where you can add input pins of various data types:   
** Clock (digital) – timing and synchronization trigger.   
** Clock (digital) – timing and synchronization trigger.   
** Date/Time (complex) – date and time data input.   
** Date/Time (complex) – date and time data input.   
Line 43: Line 61:
** Unsigned Array (unsigned array) – array of unsigned integers input.   
** Unsigned Array (unsigned array) – array of unsigned integers input.   
** Unsigned 64 (unsigned 64) – 64-bit unsigned integer input.
** Unsigned 64 (unsigned 64) – 64-bit unsigned integer input.
*'''Libraries''' – External library dependencies and linkages (Default: 0 items).
 
*'''Members''' – Class member variables and methods (Default: 0 items).
=== Outputs ===
*'''Name''' – Component identifier (Default: CustomCode).
Opens a window where you can add output pins of various data types:   
*'''On Execute''' – Code executed during main execution cycle.
*'''On Init''' – Code executed during initialization phase.
*'''On Start''' – Code executed at program start.
*'''On Update Hardware''' – Code executed during hardware update cycles.
*'''Outputs''' – Opens a window where you can add output pins of various data types:   
** Clock Out (digital) – processed timing signal output.   
** Clock Out (digital) – processed timing signal output.   
** Data Out (complex) – processed data output.   
** Data Out (complex) – processed data output.   
Line 69: Line 82:


== Pins ==
== Pins ==
*'''Clock''' (digital) – The only direct input pin. When triggered, it executes the code in the component.
* '''Clock''' (digital) – The only direct input pin. When triggered, it executes the code in the component.


== Resources ==
== Resources ==
Line 88: Line 101:
* [https://youtu.be/O_BJRXq6QuM Visuino Custom Code Part 108 – Using Hardware Libraries and Pin Attachments]
* [https://youtu.be/O_BJRXq6QuM Visuino Custom Code Part 108 – Using Hardware Libraries and Pin Attachments]
* [https://youtu.be/JNphV3EHzyI Visuino Custom Code Part 109 – OnInit, OnStart, and Direct Pin Manipulation/Reading]
* [https://youtu.be/JNphV3EHzyI Visuino Custom Code Part 109 – OnInit, OnStart, and Direct Pin Manipulation/Reading]


== Categories ==
== Categories ==
*[[Image:Programming.png]] [[Category:Programming]] – Code and programming components.
* [[Image:Programming.png]] [[Category:Programming]] – Code and programming components.
*[[Image:Custom.png]] [[Category:Custom Components]] – User-customizable components.
* [[Image:Custom.png]] [[Category:Custom Components]] – User-customizable components.
*[[Image:Interface.png]] [[Category:Interface]] – Data interface and conversion components.
* [[Image:Interface.png]] [[Category:Interface]] – Data interface and conversion components.
*[[Image:DataProcessing.png]] [[Category:Data Processing]] – Data manipulation and processing components.
* [[Image:DataProcessing.png]] [[Category:Data Processing]] – Data manipulation and processing components.
*[[Image:Advanced.png]] [[Category:Advanced]] – Advanced programming components.
* [[Image:Advanced.png]] [[Category:Advanced]] – Advanced programming components.

Revision as of 13:25, 11 September 2025

File:TArduinoCustomCode.png

Summary

The Custom Code component in Visuino Professional lets you inject arbitrary C/C++/Arduino code directly into your visual program. It removes the limitations of built-in components and allows integration of unsupported sensors, libraries, hardware modules, or protocols — providing nearly unlimited flexibility in what can be created.

Description

The Custom Code component is one of the most powerful features of Visuino Professional. It is designed to fill gaps whenever a sensor, module, protocol, or function is not natively supported by Visuino. With this component, you can embed your own C++/Arduino code to extend Visuino’s capabilities with minimal restrictions.

Key Features:

  • Full support for external Arduino or C++ libraries, custom modules, and additional functionality.
  • Mechanisms for code customization: Defines, Includes, Global Declarations/Implementations, and logic hooks (OnInit, OnStart, OnExecute, OnUpdate Hardware).
  • Ability to implement any hardware communication protocol (e.g. Modbus, CANBus, MQTT, REST).
  • Live Code view lets you inspect and debug the generated code in real time.
  • Works seamlessly with professional features such as SubDiagrams, industrial protocols, and device-specific customization.

Diagram:

Properties

  • Defines – Preprocessor definitions and macros (Default: 0 items).
  • Includes – Header file inclusions and import statements (Default: 0 items).
  • Global Declarations – Global variable and function declarations (Default: 0 items).
  • Global Implementations – Global function implementations (Default: 0 items).
  • Libraries – External library dependencies and linkages (Default: 0 items).
  • Members – Class member variables and methods (Default: 0 items).
  • Name – Component identifier (Default: CustomCode).

Execution Hooks

  • On Init – Code executed during the initialization phase of the Arduino program.

Typically used for hardware initialization. Here you place `begin()` calls or other setup logic that prepares devices before use. This code is generated inside the `setup()` function.

  • On Start – Code executed immediately after initialization.

Useful for sending initial values, printing startup information, or communicating with components right after initialization. This code is also generated inside the `setup()` function, but runs after `On Init`.

  • On Execute – Code executed in the main program loop.

By default, this runs continuously like `loop()`. If a Clock input pin is connected, the code is executed only when a clock event occurs.

  • On Update Hardware – Code executed at the very end of the loop cycle.

Typically used to update hardware that requires pre-calculated values or last-moment synchronization.

Inputs

Opens a window where you can add input pins of various data types:

    • Clock (digital) – timing and synchronization trigger.
    • Date/Time (complex) – date and time data input.
    • Analog Array (analog array) – array of analog values input.
    • Complex Array (complex array) – array of complex data structures input.
    • Binary (binary) – binary data input.
    • Color (color) – RGB color data input.
    • Alpha Color (alpha color) – RGBA color input with alpha channel.
    • RGBW Color (rgbw color) – RGBW color data input.
    • RGBW Alpha Color (rgbw alpha color) – RGBWA color data input with alpha channel.
    • Orientation 2D (orientation 2d) – 2D orientation and position input.
    • Orientation 3D (orientation 3d) – 3D orientation and position input.
    • Image (image) – image data input.
    • Audio (audio) – audio signal input.
    • CAN bus (can bus) – CAN bus communication data input.
    • Unsigned Array (unsigned array) – array of unsigned integers input.
    • Unsigned 64 (unsigned 64) – 64-bit unsigned integer input.

Outputs

Opens a window where you can add output pins of various data types:

    • Clock Out (digital) – processed timing signal output.
    • Data Out (complex) – processed data output.
    • Analog Array Out (analog array) – processed analog array output.
    • Complex Array Out (complex array) – processed complex array output.
    • Binary Out (binary) – processed binary data output.
    • Color Out (color) – processed color data output.
    • Alpha Color Out (alpha color) – processed alpha color output.
    • RGBW Color Out (rgbw color) – processed RGBW color output.
    • RGBW Alpha Color Out (rgbw alpha color) – processed RGBWA color output.
    • Orientation 2D Out (orientation 2d) – processed 2D orientation output.
    • Orientation 3D Out (orientation 3d) – processed 3D orientation output.
    • Image Out (image) – processed image output.
    • Audio Out (audio) – processed audio output.
    • CAN bus Out (can bus) – processed CAN bus data output.
    • Unsigned Array Out (unsigned array) – processed unsigned array output.
    • Unsigned 64 Out (unsigned 64) – processed 64-bit unsigned integer output.

Pins

  • Clock (digital) – The only direct input pin. When triggered, it executes the code in the component.

Resources

Tutorials & Guides

Video Tutorials

Categories