Custom Code: Difference between revisions
No edit summary |
No edit summary |
||
(One intermediate revision by the same user not shown) | |||
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 ( | * '''Defines''' – Preprocessor definitions and macros inserted at the very top of the generated Arduino sketch (before any `#include` statements). | ||
*'''Global Declarations''' – Global variable and function declarations ( | Useful for `#define` constants, conditional compilation flags, or macros that must be available globally. | ||
*'''Global Implementations''' – | * '''Includes''' – Header file inclusions and import statements placed near the top of the sketch. | ||
*''' | Use this to add `#include <LibraryName.h>` or other required headers. | ||
*''' | * '''Global Declarations''' – Global variable and function declarations generated outside of `setup()` and `loop()`. | ||
This is where you declare global variables, custom structs, `extern` references, and function prototypes. | |||
* '''Global Implementations''' – Full function implementations placed outside of `setup()` and `loop()`. | |||
Use this to define helper functions, utility routines, or class method implementations. | |||
* '''Libraries''' – External library dependencies and linkages. | |||
Automatically manages `#include` statements and library references so the Arduino IDE can compile your project with the required libraries. | |||
* '''Members''' – Class member variables and methods generated as part of the Custom Code component’s internal class. | |||
Ideal for encapsulating state or creating reusable, object-oriented code segments. | |||
* '''Name''' – Component identifier used as the instance name of the Custom Code component in the generated sketch. | |||
=== 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 67: | ||
** 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. | ||
=== 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 88: | ||
== 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 107: | ||
* [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. |
Latest revision as of 13:31, 11 September 2025
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 inserted at the very top of the generated Arduino sketch (before any `#include` statements).
Useful for `#define` constants, conditional compilation flags, or macros that must be available globally.
- Includes – Header file inclusions and import statements placed near the top of the sketch.
Use this to add `#include <LibraryName.h>` or other required headers.
- Global Declarations – Global variable and function declarations generated outside of `setup()` and `loop()`.
This is where you declare global variables, custom structs, `extern` references, and function prototypes.
- Global Implementations – Full function implementations placed outside of `setup()` and `loop()`.
Use this to define helper functions, utility routines, or class method implementations.
- Libraries – External library dependencies and linkages.
Automatically manages `#include` statements and library references so the Arduino IDE can compile your project with the required libraries.
- Members – Class member variables and methods generated as part of the Custom Code component’s internal class.
Ideal for encapsulating state or creating reusable, object-oriented code segments.
- Name – Component identifier used as the instance name of the Custom Code component in the generated sketch.
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
- Adafruit MPRLS Pressure Sensor Using Visuino Custom Code
- Control Stepper Motor Nema17 – How to Use Custom Code in Visuino PRO
- MFRC522 RFID Reader – How to Use Custom Code in Visuino PRO
- MAX30100 Heart Rate Sensor & Oximeter – How to Use Custom Code in Visuino PRO
Video Tutorials
- Visuino Custom Code Part 101 – OnData Element
- Visuino Custom Code Part 102 – On Execute VS On Data Loops
- Visuino Custom Code Part 103 – Working with and Outputting Data
- Visuino Custom Code Part 104 – Adding User Input and Multiple Loops
- Visuino Custom Code Part 105 – On Execute (System Loop)
- Visuino Custom Code Part 106 – Includes, Defines, Arrays, and Custom Library
- Visuino Custom Code Part 107 – Using the Clock Output Pins
- Visuino Custom Code Part 108 – Using Hardware Libraries and Pin Attachments
- Visuino Custom Code Part 109 – OnInit, OnStart, and Direct Pin Manipulation/Reading
Categories
- File:Programming.png – Code and programming components.
- File:Custom.png – User-customizable components.
- File:Interface.png – Data interface and conversion components.
- File:DataProcessing.png – Data manipulation and processing components.
- File:Advanced.png – Advanced programming components.