Difference between revisions of "Examples and Tutorials"
| (128 intermediate revisions by 8 users not shown) | |||
| Line 1: | Line 1: | ||
| − | This page  | + | This page provides a comprehensive set of resources to help users get started with Flowcode across multiple platforms, including ESP32, PIC, and Arduino Uno. The page features a variety of beginner-level examples that guide users through controlling sensors, displays, motors, and communication protocols, allowing for a hands-on introduction to embedded systems development. | 
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | + | In addition to microcontroller-focused examples, the page also offers tutorials for web development, PC applications, and Raspberry Pi integration. Projects range from simple flashing patterns and motor control to advanced topics like signal processing, temperature monitoring, and graphical display interfaces. | |
| + | |||
| + | These examples make it easy for beginners to explore Flowcode's capabilities while also providing the flexibility for advanced users to delve into specific hardware and software integrations. Real-world scenarios such as traffic light control, CNC machines, and MQTT communication further illustrate Flowcode’s application in practical projects. | ||
| + | |||
| + | Flowcode’s platform-agnostic approach ensures users can seamlessly work across ESP, PIC16, and Arduino, with support for Matrix's EBlocks programmers for each platform. | ||
| + | |||
| + | =Beginner Examples= | ||
| + | ==ESP32== | ||
| + | These ESP32 Flowcode example projects provide a hands-on introduction to working with various sensors, displays, and control mechanisms using the ESP32 platform.<br>  | ||
| + | From testing motor functionality to interacting with I2C components and creating simple flashing patterns, these examples are ideal for beginners looking to explore embedded systems development with ESP32.<br> | ||
| + | |||
| + | These will also work with Matrix's [https://www.matrixtsl.com/webshop/esp32-programmer-board.html EBlocks ESP32 Programmer]. | ||
| + | ====Flasher - ESP32==== | ||
| + | This example creates a basic flashing LED pattern, controlled by the ESP32.<br> | ||
| + | {{Fcfile|Flasher - ESP.fcfx|Flasher - ESP}}<br> | ||
| + | |||
| + | ====Counter - ESP32==== | ||
| + | A simple counter program that increments values based on input signals using the ESP32.<br> | ||
| + | {{Fcfile|Counter - ESP.fcfx|Counter - ESP}}<br> | ||
| + | |||
| + | ====Potentiometer ESP32==== | ||
| + | This example shows how to read analog values from a potentiometer and display them on the ESP32.<br> | ||
| + | {{Fcfile|Potentiometer ESP.fcfx|Potentiometer ESP}}<br> | ||
| + | |||
| + | ====Macros ESP32==== | ||
| + | Learn how to create and use macros to simplify repetitive tasks in Flowcode projects with ESP32.<br> | ||
| + | {{Fcfile|Macros ESP.fcfx|Macros ESP}}<br> | ||
| + | |||
| + | ====LCDs ESP32==== | ||
| + | This example explores how to control and display information on an LCD using the ESP32.<br> | ||
| + | {{Fcfile|LCDs ESP.fcfx|LCDs ESP}}<br> | ||
| + | |||
| + | ====Motor Test - ESP32==== | ||
| + | This project tests motor control functionality using the ESP32 as the controller.<br> | ||
| + | {{Fcfile|motor test - ESP32.fcfx|motor test - ESP32}}<br> | ||
| + | |||
| + | ====Grove I2C Temperature and Humidity ESP32==== | ||
| + | This program shows how to read temperature and humidity data from a Grove I2C sensor with the ESP32.<br> | ||
| + | {{Fcfile|Grove I2C temp and hum ESP.fcfx|Grove I2C temp and hum ESP}}<br> | ||
| + | |||
| + | ====Grove I2C Quad 7-Segment ESP32==== | ||
| + | This example demonstrates how to interface with a Grove I2C quad 7-segment display using the ESP32.<br> | ||
| + | {{Fcfile|Grove I2C quad 7-seg ESP.fcfx|Grove I2C quad 7-seg ESP}}<br> | ||
| + | |||
| + | ==PIC== | ||
| + | These PIC16F18877 Flowcode example projects provide a hands-on introduction to working with various sensors, displays, and control mechanisms using the PIC16F18877 platform. <br> | ||
| + | From testing motor functionality to interacting with I2C components and creating simple flashing patterns, these examples are ideal for beginners looking to explore embedded systems development with PIC microcontrollers. | ||
| + | |||
| + | These will also work with Matrix's [https://www.matrixtsl.com/webshop/e-blocks2-pic-programmer.html EBlocks PIC Programmer]. | ||
| + | |||
| + | ====Flasher - PIC==== | ||
| + | This example creates a basic flashing LED pattern, controlled by a PIC microcontroller.<br> | ||
| + | {{Fcfile|Flasher - PIC.fcfx|Flasher - PIC}}<br> | ||
| + | |||
| + | ====Counter - PIC==== | ||
| + | A simple counter program that increments values based on input signals using a PIC microcontroller.<br> | ||
| + | {{Fcfile|Counter - PIC.fcfx|Counter - PIC}}<br> | ||
| + | |||
| + | ====Potentiometer PIC==== | ||
| + | This example shows how to read analog values from a potentiometer and display them on a PIC microcontroller.<br> | ||
| + | {{Fcfile|Potentiometer PIC.fcfx|Potentiometer PIC}}<br> | ||
| + | |||
| + | ====Macros PIC==== | ||
| + | Learn how to create and use macros to simplify repetitive tasks in Flowcode projects with a PIC microcontroller.<br> | ||
| + | {{Fcfile|Macros PIC.fcfx|Macros PIC}}<br> | ||
| + | |||
| + | ====LCDs PIC==== | ||
| + | This example explores how to control and display information on an LCD using a PIC microcontroller.<br> | ||
| + | {{Fcfile|LCDs PIC.fcfx|LCDs PIC}}<br> | ||
| + | |||
| + | ====Motor Test - PIC==== | ||
| + | This project tests motor control functionality using a PIC microcontroller as the controller.<br> | ||
| + | {{Fcfile|motor test - PIC.fcfx|motor test - PIC}}<br> | ||
| + | |||
| + | ====Grove I2C Temperature and Humidity PIC==== | ||
| + | This program shows how to read temperature and humidity data from a Grove I2C sensor with a PIC microcontroller.<br> | ||
| + | {{Fcfile|Grove I2C temp and hum PIC.fcfx|Grove I2C temp and hum PIC}}<br> | ||
| + | |||
| + | ====Grove I2C Quad 7-Segment PIC==== | ||
| + | This example demonstrates how to interface with a Grove I2C quad 7-segment display using a PIC microcontroller.<br> | ||
| + | {{Fcfile|Grove I2C quad 7-seg PIC.fcfx|Grove I2C quad 7-seg PIC}}<br> | ||
| + | |||
| + | ==Arduino== | ||
| + | Arduino Uno | ||
| + | These Arduino Uno Flowcode example projects provide a hands-on introduction to working with various sensors, motors, and control mechanisms using the Arduino Uno platform.<br> | ||
| + | From controlling DC motors to interacting with I2C components and creating flashing patterns, these examples are perfect for beginners looking to explore embedded systems development with the Arduino Uno. | ||
| + | |||
| + | These will also work with Matrix's [https://www.matrixtsl.com/webshop/e-blocks2-arduino-shield.html EBlocks Arduino Programmer]. | ||
| + | |||
| + | ====Flasher - Uno==== | ||
| + | This example creates a basic flashing LED pattern, controlled by the Arduino Uno.<br> | ||
| + | {{Fcfile|Flasher - Uno.fcfx|Flasher - Uno}}<br> | ||
| + | |||
| + | ====Counter - Uno==== | ||
| + | A simple counter program that increments values based on input signals using the Arduino Uno.<br> | ||
| + | {{Fcfile|Counter - Uno.fcfx|Counter - Uno}}<br> | ||
| + | |||
| + | ====Potentiometer Uno==== | ||
| + | This example shows how to read analog values from a potentiometer and display them on the Arduino Uno.<br> | ||
| + | {{Fcfile|Potentiometer Uno.fcfx|Potentiometer Uno}}<br> | ||
| + | |||
| + | ====Macros Uno==== | ||
| + | Learn how to create and use macros to simplify repetitive tasks in Flowcode projects with the Arduino Uno.<br> | ||
| + | {{Fcfile|Macros Uno.fcfx|Macros Uno}}<br> | ||
| + | |||
| + | ====LCDs Uno==== | ||
| + | This example explores how to control and display information on an LCD using the Arduino Uno.<br> | ||
| + | {{Fcfile|LCDs Uno.fcfx|LCDs Uno}}<br> | ||
| + | |||
| + | ====DC Motor Test - Uno==== | ||
| + | This project tests DC motor control functionality using the Arduino Uno.<br> | ||
| + | {{Fcfile|DC motor test - Uno.fcfx|DC motor test - Uno}}<br> | ||
| + | |||
| + | ====Grove Temperature and Humidity Sensor - Uno==== | ||
| + | This program shows how to read temperature and humidity data from a Grove sensor with the Arduino Uno.<br> | ||
| + | {{Fcfile|Grove temp hum sensor - Uno.fcfx|Grove temp hum sensor - Uno}}<br> | ||
| + | |||
| + | ====Grove I2C Quad 7-Segment - Uno==== | ||
| + | This example demonstrates how to interface with a Grove I2C quad 7-segment display using the Arduino Uno.<br> | ||
| + | {{Fcfile|Grove I2C quad 7-seg - Uno.fcfx|Grove I2C quad 7-seg - Uno}}<br> | ||
| + | |||
| + | ==Introduction to Microcontrollers Course== | ||
| + | |||
| + | We recommend going through the Flowcode section (section 3 page 28-38) of the [https://www.flowcode.co.uk/resources/datasheets/Microcontroller%20compete%20course.pdf Free Introduction to Microcontroller Programming Course]. | ||
| + | |||
| + | This section of the course teaches the following basic concepts about Flowcode: | ||
| + | |||
| + | * '''How to Design a Flowchart:''' Learn how to create flowcharts by dragging and dropping icons, which represent commands and functions, to develop microcontroller applications. | ||
| + | *  | ||
| + | * '''How to Add and Configure Components:''' Understand how to include and manage external devices, such as LEDs, switches, and displays, by using Flowcode’s extensive component libraries. You will also learn to configure the properties and connections of these components to the microcontroller. | ||
| + | *  | ||
| + | * '''How to Simulate Programs:''' Explore how to run simulations of your flowchart, allowing you to check the behavior of your application before transferring it to the microcontroller. Flowcode offers real-time variable and macro tracking during simulations. | ||
| + | *  | ||
| + | * '''How to Compile and Transfer Flowcharts:''' Once your flowchart is complete, you will learn how to compile it into C code and transfer it to the microcontroller for real-world testing and implementation. | ||
| + | *  | ||
| + | * '''How to Use the Flowcode Interface:''' Gain familiarity with the key panels and toolbars in Flowcode, such as the main workspace for building flowcharts, the 2D Dashboard and 3D System panels for managing components, and the Project Explorer for organizing variables, macros, and components. | ||
| + | |||
| + | By the end of this section of the course, you will have learned how to use Flowcode to create and simulate embedded applications, manage microcontroller interactions, and troubleshoot your programs effectively. | ||
| + | |||
| + | ==Embedded Getting Started Guide== | ||
| + | |||
| + | The [[Embedded_Getting_Started_Guide|Embedded Getting Started Guide]] introduces you to the Flowcode environment and take you though to programming a microcontroller. | ||
| + | |||
| + | |||
| + | ==Web Developer getting started== | ||
| + | |||
| + | New with the release of Flowcode v10.1 is Web Developer which allows the development of interactive web pages using the Flowcode IDE environment on any platform that supports HTML browsers. | ||
| + | |||
| + | The [[Web_Developer_Getting_Started_Guide|Web Developer Getting Started Guide]] takes you through your first experience of Web Developer and demonstrates how to generate interactive HTML files. | ||
| + | |||
| + | |||
| + | ==PC Developer Getting Started Guide== | ||
| + | |||
| + | The [[PC_Developer_Getting_Started_Guide|PC Developer Getting Started Guide]] takes you through the various stages of creating PC developer code that includes switches, timer and graph logging.  | ||
| + | |||
| + | |||
| + | ==Using PC_Developer APIs to Control an Arduino== | ||
| + | |||
| + | The [[Using_PC_Developer_APIs_to_Control_an_Arduino|Using PC Developer APIs to Control an Arduino]] Takes you through creating HMI (Human machine Interface) Windows-based applications. that can control ESP32, and Arduino hardware in real time. | ||
| + | |||
| + | |||
| + | ==Raspberry Pi_Getting Started Guide== | ||
| + | |||
| + | The [[Raspberry_Pi_Getting_Started_Guide|Raspberry Pi Getting Started Guide]] shows you how to set up the Raspberry Pi to enable it to be programmed via Flowcode. | ||
| + | |||
| + | |||
| + | ==Sysblocks Getting Started Guide== | ||
| + | |||
| + | The [[Sysblocks_Getting_Started_Guide|Sysblocks Getting Started Guide]] take you through signal processing for Music Technology, DSP, Communications and Software Defined Radio. | ||
| + | |||
| + | Sysblocks is an exciting piece of hardware for use with education in mind. | ||
| + | |||
| + | ===Examples=== | ||
| + | |||
| + | There are loads of examples available. | ||
| + | To find an example of a component you are interested in. | ||
| + | Search for the component by selecting the magnifying glass on the left Components Libraries ribbon.      | ||
| + | Right-click on the component you would like to look at an example for,  then select help. | ||
| + | If there are no examples available then you can request an example on the [https://flowcode.co.uk/forums/index.php forums]. | ||
| + | |||
| + | ==Embedded== | ||
| + | |||
| + | ===Heat Control - Coarse=== | ||
| + | |||
| + | Many modern electronic systems include some form of simple closed loop heat control to function. Some examples include a kitchen oven, a microwave oven, an iron, hair straighteners, electric heater, etc. | ||
| + | |||
| + | These devices typically work by monitoring the temperature and then switching on a heating element when the temperature is less then the required temperature. The element is then switched off again when the required temperature is reached.  | ||
| + | |||
| + | The electronics involved could be a microcontroller digital output pin connected to a simple transistor, diode and relay to control the heater element and a thermistor to measure the heat. | ||
| + | |||
| + | {{Fcfile|DSP_Heater_Coarse_Control.fcfx|DSP Heater Coarse Control}} | ||
| + | |||
| + | |||
| + | ===Heat Control - Fine=== | ||
| + | |||
| + | More advanced electronic systems may require a bit more fine control of the temperature to avoid overshoot and improve response to load changes. Some examples include a SMD reflow oven, 3D printer hotend, soldering iron, etc. | ||
| + | |||
| + | These devices typically work by monitoring the temperature and then providing an analogue output to a heating element. The analogue value is calculated using a transfer function in this case we are using PID control. | ||
| + | |||
| + | The electronics involved could be a microcontroller PWM output pin connected to logic level FET or TRIAC to control the heater element and a thermocouple to measure the heat. | ||
| + | |||
| + | {{Fcfile|DSP_Heater_Fine_Control.fcfx|DSP Heater Fine Control}} | ||
| + | |||
| + | |||
| + | === Multi-function AC Power Monitor===  | ||
| + | |||
| + | The PZEM-004T is Multifunction AC Power Monitor which uses MODBUS to communicate with the microcontroller. | ||
| + | |||
| + | It can measure Voltage, Current, Frequency Power, Power Factor & Energy used (Resettable). | ||
| + | |||
| + | The power level threshold can be set to give OVERPOWER warning. | ||
| + | |||
| + | Before programming, check LCD address and Power Level Threshold are correct within the 2D Panel Properties. | ||
| + | |||
| + | As the MODBUS uses UART channel on the Arduino Uno, the UART software timer is used to send all the power values. | ||
| + | Therefore you will require a TTL to USB converter or an analyser that can decode UART.  | ||
| + | |||
| + | {{Fcfile|Arduino_Uno_Mains_PM_LCDv1.2.fcfx|Arduino Uno AC Multi-function Monitor v1.2}} | ||
| + | |||
| + | ===Current Sensor (ACS7xx) component=== | ||
| + | ACS7XX range of unidirectional and bidirectional  5, 20, 30, 50, 100, 150 & 200A current sensors | ||
| + | |||
| + | A simple example shows how to use a ASC712 component to measure a current range of +/- 5A. | ||
| + | The component type can be changed within its properties.  | ||
| + | |||
| + | {{Fcfile|Current_measure_ACS7xx.fcfx|ACS712 example}} | ||
| + | |||
| + | |||
| + | |||
| + | ===Circular Buffer - Reliable Communications Data=== | ||
| + | |||
| + | This example takes bytes received from the Serial UART and uses the circular buffer to store the bytes as they come in using an interrupt. The main routine then forwards the bytes through to a PC using a USB serial connection.  | ||
| + | |||
| + | This example would work equally well for creating a bridge between several UARTs or translating Serial to SPI or I2C etc. | ||
| + | |||
| + | {{Fcfile|CommsBuffer.fcfx|UART to USB Serial Data Bridge}} | ||
| + | |||
| + | The LCD will retain the contents of the display, for high speed data we only want to have to write to the portion of the display that can change. | ||
| + | |||
| + | {{Fcfile|LCDDemo.fcfx|LCD Demo}} | ||
| + | |||
| + | {{Fcfile|BME280 Barometer plus Altitude v1.0.fcfx|BME280 Barometer plus Altitude v1.0}} | ||
| + | This example reads and displays the pressure, temperature & humidity. | ||
| + | If the pressure is increasing then Rise will be displayed. | ||
| + | |||
| + | Alternatively if the pressure is falling, then Fall will be displayed. | ||
| + | |||
| + | The altitude displayed is calculated based on the current pressure reading. | ||
| + | |||
| + | What makes the altitude useful is the ability to tare it,  | ||
| + | then after going up or downstairs for example the feet & meters are displayed. | ||
| + | |||
| + | Note since the altitude is calculated based on pressure, then if the sensor is left at the same height, | ||
| + | the height displayed can be different each day. | ||
| + | |||
| + | |||
| + | |||
| + | ===Programming Touch and Graphical Displays=== | ||
| + | These programs are used in the Youtube video Touch and graphical displays parts [https://www.youtube.com/watch?v=AZhRtxvC_uY 1] and [https://www.youtube.com/watch?v=oCxMetjco4k 2] | ||
| + | |||
| + | {{Fcfile|Test_card_7_for_HGY_480_320_display_spi.fcfx|gLCD Demo for SPI HGY 480 x 320 Display}} | ||
| + | |||
| + | {{Fcfile|Test_card_6_for_Rowland.fcfx|gLCD Demo for Cap Touch Display on Rowland Technology PCB}} | ||
| + | |||
| + | {{Zip|Testcard_6_Demo_Image.zip|Image for Test_card_6_for_Rowland}} | ||
| + | |||
| + | {{Zip|Testcard_7_Demo_Images.zip|Images for Test_card_7_for_HGY_480_320}} | ||
| + | |||
| + | {{Fcfile|Menu_system_02_10_24.fcfx|Menu system example for a gLCD}} | ||
| + | |||
| + | {{Zip|Menu_system_images.zip|Images for Menu system example}} | ||
| + | |||
| + | Place the bitmap files in the same folder as the project file for the simulation to work. | ||
| + | |||
| + | |||
| + | ===M5stack Dial=== | ||
| + | |||
| + | {{Fcfile|M5stack_Dial_Simple.fcfx|M5stack demo shows you how you can develop a simple test card for the M5 stack dial using Flowcode}} | ||
| + | |||
| + | {{Fcfile|M5Stack_Dial_Safe.fcfx|M5stack demo shows you how you can make an electronic safe project for the M5stack Dial}} | ||
| + | |||
| + | {{Zip|M5stack_Dial_simple_Demo_Image.zip|Image for M5stack_Dial_simple}} | ||
| + | |||
| + | {{Zip|M5stack_Dial_Safe_Demo_Image.zip|Image for M5stack_Dial_Safe}} | ||
| + | |||
| + | Place the bitmap file in the same folder as the project file for the simulation to work. | ||
| + | |||
| + | |||
| + | ===M5Stack Dial workshops with Espressif=== | ||
| + | |||
| + | [https://developer.espressif.com/workshops/ Link to the full article on Espressif]. | ||
| + | |||
| + | {{Fcfile|2 - Using the display.fcfx|Example 2 - Using the display}} | ||
| + | |||
| + | {{Fcfile|3 - Using the IO.fcfx|Example 3 - Using the I/O}} | ||
| + | |||
| + | {{Fcfile|4 - Using the encoder.fcfx|Example 4 - Using the encoder}} | ||
| + | |||
| + | {{Fcfile|5 - Expanding with I2C.fcfx|Example 5 - Expanding with I2C}} | ||
| + | |||
| + | {{Fcfile|6 - Driving a menu.fcfx|Example 6 - Driving a menu}} | ||
| + | |||
| + | {{Fcfile|7 - Connecting to web FE.fcfx|Example 7 - Connecting to web (Embedded)}} | ||
| + | |||
| + | {{Fcfile|7 - Connecting to web FWD.fcsx|Example 7 - Connecting to web (Web Developer)}} | ||
| + | |||
| + | {{Fcfile|Full project - FE.fcfx|Full project (Embedded)}} | ||
| + | |||
| + | {{Fcfile|Full project - FWD.fcsx|Full project (Web Developer)}} | ||
| + | |||
| + | |||
| + | |||
| + | {{Zip|M5Stack Lock Test Purple.zip|Image for M5stack_Dial_Workshops}} | ||
| + | |||
| + | {{Zip|Image_for_Full_project_and_Connecting_to_the_Web_embedded.zip|Image for_Full project and Connecting to_the Web -  | ||
| + |  embedded}} | ||
| + | |||
| + | Place the bitmap file in the same folder as the project file for the simulation and embedded download to work. | ||
| + | |||
| + | ==App Developer== | ||
| + | |||
| + | [[File:freeapp-io-monitor2.png]] | ||
| + | |||
| + | A range of example App Developer projects are available from here: https://www.flowcode.co.uk/app-developer/free-apps/ | ||
| + | |||
| + | A simple example that shows how to use some common functions of the potentiometer in conjunction with an LCD. | ||
| + | |||
| + | {{Fcfile|Potentiometer Example.fcfx|Potentiometer Example}} | ||
| + | |||
| + | |||
| + | |||
| + | A basic worked example showing how to use Flowcode to create an embedded project that is controlled via a web app using HTTP. | ||
| + | |||
| + | This set of 6 projects provides a detailed look at simple communications between an ESP32 device and a web browser using Flowcode to construct both the embedded app and the web app. | ||
| + | |||
| + | [https://www.flowcode.co.uk/resources/software/Worked%20Example%20-%20HTTP%20Comms%20v1.0.zip HTTP Comms Worked Example - Web Developer] | ||
| + | |||
| + | |||
| + | |||
| + | |||
| + | A worked example showing how to create an embedded project that communicates with a PC via the serial port. | ||
| + | |||
| + | This simple example shows two projects - an embedded app and a PC-based app - that communicate with each other using the serial port, exchanging text messages between the embedded device and the PC. | ||
| + | |||
| + | [https://www.flowcode.co.uk/resources/software/Worked%20Example%20-%20Serial%20Comms%20v1.0.zip Serial Comms Worked Example - PC Developer] | ||
| + | |||
| + | |||
| + | |||
| + | |||
| + | A worked example showing how to develop Flowcode MQTT apps. | ||
| + | |||
| + | This project details a simple application for exchanging messages between embedded and non-embedded devices using the popular MQTT protocol. Flowcode is used to create three apps - an embedded app running on an ESP32 device, a PC app running on Windows and a web app running in a browser. | ||
| + | |||
| + | [https://www.flowcode.co.uk/resources/software/Worked%20Example%20-%20MQTT%20Comms%20v1.0.zip MQTT Worked Example - Web & PC Developer] | ||
| + | |||
| + | ==Scenarios== | ||
| + | This page contains a list of the scenarios included with Flowcode. | ||
| + | |||
| + | The corresponding components can be found in the '''Runtime''' section of the component toolbar. | ||
| + | |||
| + | *[[Traffic Light 1-Way]] | ||
| + | *[[Pedestrian Crossing]] | ||
| + | *[[Airplane Landing Gear]] | ||
| + | *[[CNC Machine]] | ||
| + | *[[Car Seat]] | ||
Latest revision as of 13:21, 20 December 2024
This page provides a comprehensive set of resources to help users get started with Flowcode across multiple platforms, including ESP32, PIC, and Arduino Uno. The page features a variety of beginner-level examples that guide users through controlling sensors, displays, motors, and communication protocols, allowing for a hands-on introduction to embedded systems development.
In addition to microcontroller-focused examples, the page also offers tutorials for web development, PC applications, and Raspberry Pi integration. Projects range from simple flashing patterns and motor control to advanced topics like signal processing, temperature monitoring, and graphical display interfaces.
These examples make it easy for beginners to explore Flowcode's capabilities while also providing the flexibility for advanced users to delve into specific hardware and software integrations. Real-world scenarios such as traffic light control, CNC machines, and MQTT communication further illustrate Flowcode’s application in practical projects.
Flowcode’s platform-agnostic approach ensures users can seamlessly work across ESP, PIC16, and Arduino, with support for Matrix's EBlocks programmers for each platform.
Contents
- 1 Beginner Examples
- 1.1 ESP32
- 1.2 PIC
- 1.3 Arduino
- 1.4 Introduction to Microcontrollers Course
- 1.5 Embedded Getting Started Guide
- 1.6 Web Developer getting started
- 1.7 PC Developer Getting Started Guide
- 1.8 Using PC_Developer APIs to Control an Arduino
- 1.9 Raspberry Pi_Getting Started Guide
- 1.10 Sysblocks Getting Started Guide
- 1.11 Embedded
- 1.11.1 Heat Control - Coarse
- 1.11.2 Heat Control - Fine
- 1.11.3 Multi-function AC Power Monitor
- 1.11.4 Current Sensor (ACS7xx) component
- 1.11.5 Circular Buffer - Reliable Communications Data
- 1.11.6 Programming Touch and Graphical Displays
- 1.11.7 M5stack Dial
- 1.11.8 M5Stack Dial workshops with Espressif
 
- 1.12 App Developer
- 1.13 Scenarios
 
Beginner Examples
ESP32
These ESP32 Flowcode example projects provide a hands-on introduction to working with various sensors, displays, and control mechanisms using the ESP32 platform.
 
From testing motor functionality to interacting with I2C components and creating simple flashing patterns, these examples are ideal for beginners looking to explore embedded systems development with ESP32.
These will also work with Matrix's EBlocks ESP32 Programmer.
Flasher - ESP32
This example creates a basic flashing LED pattern, controlled by the ESP32.
 Flasher - ESP
Flasher - ESP
Counter - ESP32
A simple counter program that increments values based on input signals using the ESP32.
 Counter - ESP
Counter - ESP
Potentiometer ESP32
This example shows how to read analog values from a potentiometer and display them on the ESP32.
 Potentiometer ESP
Potentiometer ESP
Macros ESP32
Learn how to create and use macros to simplify repetitive tasks in Flowcode projects with ESP32.
 Macros ESP
Macros ESP
LCDs ESP32
This example explores how to control and display information on an LCD using the ESP32.
 LCDs ESP
LCDs ESP
Motor Test - ESP32
This project tests motor control functionality using the ESP32 as the controller.
 motor test - ESP32
motor test - ESP32
Grove I2C Temperature and Humidity ESP32
This program shows how to read temperature and humidity data from a Grove I2C sensor with the ESP32.
 Grove I2C temp and hum ESP
Grove I2C temp and hum ESP
Grove I2C Quad 7-Segment ESP32
This example demonstrates how to interface with a Grove I2C quad 7-segment display using the ESP32.
 Grove I2C quad 7-seg ESP
Grove I2C quad 7-seg ESP
PIC
These PIC16F18877 Flowcode example projects provide a hands-on introduction to working with various sensors, displays, and control mechanisms using the PIC16F18877 platform. 
From testing motor functionality to interacting with I2C components and creating simple flashing patterns, these examples are ideal for beginners looking to explore embedded systems development with PIC microcontrollers.
These will also work with Matrix's EBlocks PIC Programmer.
Flasher - PIC
This example creates a basic flashing LED pattern, controlled by a PIC microcontroller.
 Flasher - PIC
Flasher - PIC
Counter - PIC
A simple counter program that increments values based on input signals using a PIC microcontroller.
 Counter - PIC
Counter - PIC
Potentiometer PIC
This example shows how to read analog values from a potentiometer and display them on a PIC microcontroller.
 Potentiometer PIC
Potentiometer PIC
Macros PIC
Learn how to create and use macros to simplify repetitive tasks in Flowcode projects with a PIC microcontroller.
 Macros PIC
Macros PIC
LCDs PIC
This example explores how to control and display information on an LCD using a PIC microcontroller.
 LCDs PIC
LCDs PIC
Motor Test - PIC
This project tests motor control functionality using a PIC microcontroller as the controller.
 motor test - PIC
motor test - PIC
Grove I2C Temperature and Humidity PIC
This program shows how to read temperature and humidity data from a Grove I2C sensor with a PIC microcontroller.
 Grove I2C temp and hum PIC
Grove I2C temp and hum PIC
Grove I2C Quad 7-Segment PIC
This example demonstrates how to interface with a Grove I2C quad 7-segment display using a PIC microcontroller.
 Grove I2C quad 7-seg PIC
Grove I2C quad 7-seg PIC
Arduino
Arduino Uno
These Arduino Uno Flowcode example projects provide a hands-on introduction to working with various sensors, motors, and control mechanisms using the Arduino Uno platform.
From controlling DC motors to interacting with I2C components and creating flashing patterns, these examples are perfect for beginners looking to explore embedded systems development with the Arduino Uno.
These will also work with Matrix's EBlocks Arduino Programmer.
Flasher - Uno
This example creates a basic flashing LED pattern, controlled by the Arduino Uno.
 Flasher - Uno
Flasher - Uno
Counter - Uno
A simple counter program that increments values based on input signals using the Arduino Uno.
 Counter - Uno
Counter - Uno
Potentiometer Uno
This example shows how to read analog values from a potentiometer and display them on the Arduino Uno.
 Potentiometer Uno
Potentiometer Uno
Macros Uno
Learn how to create and use macros to simplify repetitive tasks in Flowcode projects with the Arduino Uno.
 Macros Uno
Macros Uno
LCDs Uno
This example explores how to control and display information on an LCD using the Arduino Uno.
 LCDs Uno
LCDs Uno
DC Motor Test - Uno
This project tests DC motor control functionality using the Arduino Uno.
 DC motor test - Uno
DC motor test - Uno
Grove Temperature and Humidity Sensor - Uno
This program shows how to read temperature and humidity data from a Grove sensor with the Arduino Uno.
 Grove temp hum sensor - Uno
Grove temp hum sensor - Uno
Grove I2C Quad 7-Segment - Uno
This example demonstrates how to interface with a Grove I2C quad 7-segment display using the Arduino Uno.
 Grove I2C quad 7-seg - Uno
Grove I2C quad 7-seg - Uno
Introduction to Microcontrollers Course
We recommend going through the Flowcode section (section 3 page 28-38) of the Free Introduction to Microcontroller Programming Course.
This section of the course teaches the following basic concepts about Flowcode:
- How to Design a Flowchart: Learn how to create flowcharts by dragging and dropping icons, which represent commands and functions, to develop microcontroller applications.
- How to Add and Configure Components: Understand how to include and manage external devices, such as LEDs, switches, and displays, by using Flowcode’s extensive component libraries. You will also learn to configure the properties and connections of these components to the microcontroller.
- How to Simulate Programs: Explore how to run simulations of your flowchart, allowing you to check the behavior of your application before transferring it to the microcontroller. Flowcode offers real-time variable and macro tracking during simulations.
- How to Compile and Transfer Flowcharts: Once your flowchart is complete, you will learn how to compile it into C code and transfer it to the microcontroller for real-world testing and implementation.
- How to Use the Flowcode Interface: Gain familiarity with the key panels and toolbars in Flowcode, such as the main workspace for building flowcharts, the 2D Dashboard and 3D System panels for managing components, and the Project Explorer for organizing variables, macros, and components.
By the end of this section of the course, you will have learned how to use Flowcode to create and simulate embedded applications, manage microcontroller interactions, and troubleshoot your programs effectively.
Embedded Getting Started Guide
The Embedded Getting Started Guide introduces you to the Flowcode environment and take you though to programming a microcontroller.
Web Developer getting started
New with the release of Flowcode v10.1 is Web Developer which allows the development of interactive web pages using the Flowcode IDE environment on any platform that supports HTML browsers.
The Web Developer Getting Started Guide takes you through your first experience of Web Developer and demonstrates how to generate interactive HTML files.
PC Developer Getting Started Guide
The PC Developer Getting Started Guide takes you through the various stages of creating PC developer code that includes switches, timer and graph logging.
Using PC_Developer APIs to Control an Arduino
The Using PC Developer APIs to Control an Arduino Takes you through creating HMI (Human machine Interface) Windows-based applications. that can control ESP32, and Arduino hardware in real time.
Raspberry Pi_Getting Started Guide
The Raspberry Pi Getting Started Guide shows you how to set up the Raspberry Pi to enable it to be programmed via Flowcode.
Sysblocks Getting Started Guide
The Sysblocks Getting Started Guide take you through signal processing for Music Technology, DSP, Communications and Software Defined Radio.
Sysblocks is an exciting piece of hardware for use with education in mind.
Examples
There are loads of examples available. To find an example of a component you are interested in. Search for the component by selecting the magnifying glass on the left Components Libraries ribbon. Right-click on the component you would like to look at an example for, then select help. If there are no examples available then you can request an example on the forums.
Embedded
Heat Control - Coarse
Many modern electronic systems include some form of simple closed loop heat control to function. Some examples include a kitchen oven, a microwave oven, an iron, hair straighteners, electric heater, etc.
These devices typically work by monitoring the temperature and then switching on a heating element when the temperature is less then the required temperature. The element is then switched off again when the required temperature is reached.
The electronics involved could be a microcontroller digital output pin connected to a simple transistor, diode and relay to control the heater element and a thermistor to measure the heat.
Heat Control - Fine
More advanced electronic systems may require a bit more fine control of the temperature to avoid overshoot and improve response to load changes. Some examples include a SMD reflow oven, 3D printer hotend, soldering iron, etc.
These devices typically work by monitoring the temperature and then providing an analogue output to a heating element. The analogue value is calculated using a transfer function in this case we are using PID control.
The electronics involved could be a microcontroller PWM output pin connected to logic level FET or TRIAC to control the heater element and a thermocouple to measure the heat.
Multi-function AC Power Monitor
The PZEM-004T is Multifunction AC Power Monitor which uses MODBUS to communicate with the microcontroller.
It can measure Voltage, Current, Frequency Power, Power Factor & Energy used (Resettable).
The power level threshold can be set to give OVERPOWER warning.
Before programming, check LCD address and Power Level Threshold are correct within the 2D Panel Properties.
As the MODBUS uses UART channel on the Arduino Uno, the UART software timer is used to send all the power values. Therefore you will require a TTL to USB converter or an analyser that can decode UART.
 Arduino Uno AC Multi-function Monitor v1.2
Arduino Uno AC Multi-function Monitor v1.2
Current Sensor (ACS7xx) component
ACS7XX range of unidirectional and bidirectional 5, 20, 30, 50, 100, 150 & 200A current sensors
A simple example shows how to use a ASC712 component to measure a current range of +/- 5A. The component type can be changed within its properties.
Circular Buffer - Reliable Communications Data
This example takes bytes received from the Serial UART and uses the circular buffer to store the bytes as they come in using an interrupt. The main routine then forwards the bytes through to a PC using a USB serial connection.
This example would work equally well for creating a bridge between several UARTs or translating Serial to SPI or I2C etc.
 UART to USB Serial Data Bridge
UART to USB Serial Data Bridge
The LCD will retain the contents of the display, for high speed data we only want to have to write to the portion of the display that can change.
 BME280 Barometer plus Altitude v1.0
This example reads and displays the pressure, temperature & humidity.
If the pressure is increasing then Rise will be displayed.
BME280 Barometer plus Altitude v1.0
This example reads and displays the pressure, temperature & humidity.
If the pressure is increasing then Rise will be displayed.
Alternatively if the pressure is falling, then Fall will be displayed.
The altitude displayed is calculated based on the current pressure reading.
What makes the altitude useful is the ability to tare it, then after going up or downstairs for example the feet & meters are displayed.
Note since the altitude is calculated based on pressure, then if the sensor is left at the same height, the height displayed can be different each day.
Programming Touch and Graphical Displays
These programs are used in the Youtube video Touch and graphical displays parts 1 and 2
 gLCD Demo for SPI HGY 480 x 320 Display
gLCD Demo for SPI HGY 480 x 320 Display
 gLCD Demo for Cap Touch Display on Rowland Technology PCB
gLCD Demo for Cap Touch Display on Rowland Technology PCB
 Image for Test_card_6_for_Rowland
Image for Test_card_6_for_Rowland
 Images for Test_card_7_for_HGY_480_320
Images for Test_card_7_for_HGY_480_320
 Menu system example for a gLCD
Menu system example for a gLCD
 Images for Menu system example
Images for Menu system example
Place the bitmap files in the same folder as the project file for the simulation to work.
M5stack Dial
 M5stack demo shows you how you can develop a simple test card for the M5 stack dial using Flowcode
M5stack demo shows you how you can develop a simple test card for the M5 stack dial using Flowcode
 M5stack demo shows you how you can make an electronic safe project for the M5stack Dial
M5stack demo shows you how you can make an electronic safe project for the M5stack Dial
Place the bitmap file in the same folder as the project file for the simulation to work.
M5Stack Dial workshops with Espressif
Link to the full article on Espressif.
 Example 5 - Expanding with I2C
Example 5 - Expanding with I2C
 Example 7 - Connecting to web (Embedded)
Example 7 - Connecting to web (Embedded)
 Example 7 - Connecting to web (Web Developer)
Example 7 - Connecting to web (Web Developer)
 Image for M5stack_Dial_Workshops
Image for M5stack_Dial_Workshops
 Image for_Full project and Connecting to_the Web -
Image for_Full project and Connecting to_the Web - 
embedded
Place the bitmap file in the same folder as the project file for the simulation and embedded download to work.
App Developer
A range of example App Developer projects are available from here: https://www.flowcode.co.uk/app-developer/free-apps/
A simple example that shows how to use some common functions of the potentiometer in conjunction with an LCD.
A basic worked example showing how to use Flowcode to create an embedded project that is controlled via a web app using HTTP.
This set of 6 projects provides a detailed look at simple communications between an ESP32 device and a web browser using Flowcode to construct both the embedded app and the web app.
HTTP Comms Worked Example - Web Developer
A worked example showing how to create an embedded project that communicates with a PC via the serial port.
This simple example shows two projects - an embedded app and a PC-based app - that communicate with each other using the serial port, exchanging text messages between the embedded device and the PC.
Serial Comms Worked Example - PC Developer
A worked example showing how to develop Flowcode MQTT apps.
This project details a simple application for exchanging messages between embedded and non-embedded devices using the popular MQTT protocol. Flowcode is used to create three apps - an embedded app running on an ESP32 device, a PC app running on Windows and a web app running in a browser.
MQTT Worked Example - Web & PC Developer
Scenarios
This page contains a list of the scenarios included with Flowcode.
The corresponding components can be found in the Runtime section of the component toolbar.

