The steps to create a microcontroller application with Graphical User Interface are:
RTE Component Selection
Only a few steps are necessary to complete the RTE Component selection:
- From the Graphics Component:
- Select Graphics:CORE that provides the full emWin library.
- From the Display (API) select the preconfigured LCD Interface for your platform. If you are running on unsupported or custom hardware select the Interface Template. The User and Reference Guide - 34.4.2 Customizing LCDConf.c describes how to customize the Interface Template.
- Optionally you can now also add a Pointer Input Device like Joystick or Touch if present on your hardware.
- From Board Support:
- Enable emWin LCD. If there's no board support available for your development environment, refer to the User and Reference Guide - 31. Display drivers on how to create a suitable LCD driver.
- Enable Touchscreen. If there's no board support available for your development environment, refer to the User and Reference Guide - 24.4 Touch screen driver on how to create a suitable touchscreen driver.
RTE Component Selection
Add and Configure the GUI Template
User code template files provide templates for running an application using the Graphic component. The following templates are available for the Graphic component (refer to Execution Models for further information):
Template Name | Purpose |
GUI_SingleThread.c | GUI Thread for Single-Task Execution Model |
GUI_MultiThread.c | GUI Thread for Multiple-Task Execution Model |
GUI_TemplateThread.c | Thread to run emWin Demos or Templates |
To integrate a User Code Template in your application, follow these steps:
Additional RTOS Kernel Resources | Value to add to existing resources |
Number of concurrent running threads | +1 |
Number of threads with user-provided stack size | +1 |
Total stack size [bytes] for threads with user-provided stack size | +2048 Bytes |
Configure the Memory for the Component
The Graphics Component has some increased resource requirements. In most cases you will allocate external RAM (or some separate RAM area on your device) for the GUI buffer.
- Open GUIConf.c for editing. Set the GUI_NUMBYTES define to 0x4000. This will be sufficient for simple GUI dialogs. If you are increasing complexity of your GUI you also need to increase this buffer size.
- Run the Options for Component dialog from the context menu of the file GUIConf.c.
Context Menu
- In the Options for Component dialog select the RAM area you want to use for the Core Component. This will relocate the buffer in the selected area.
Options for Component Dialog
CMSIS-RTOS Requirements
If you are using a touch-screen device, you'll need to enable the user timer in the RTX_Conf_CM.c file. Also, an additional 1024 Bytes of stack for the User Timer Thread is required.
For more information, check the Graphic component's Resource Requirements section.
Design a Dialog and Include in the Application
- Create a new Framewin by clicking the icon on the toolbar. Adjust the properties. First you need to rename the Framewin object. In this example we call it "myDialog". The name of the root object will also be reflected in the generated source file name.
- Adjust the xSize and ySize to fit onto your display area. If the dialog is larger than your display it will be truncated.
- Add elements of your choice using the GUIBuilder toolbar. Here we add a button called "Button".
The GUIBuilder Utility
- Once you are done, save the file (File-Save...). A new file called myDialog.c will be created.
- Add this file to a source group in your project using the context menu:
Source Group - Add Existing Files...
- Open GUI_SingleThread.c in the editor. Add #include "dialog.h" to the includes. In the GUIThread thread loop call CreatemyDialog();
You will also need to add an extern
declaration WM_HWIN CreatemyDialog(void);
The Graphics Component is now completely integrated in your application.