Graphics Component  Version 5.30
MDK-Professional Middleware for Graphical User Interfaces
 All Files Pages
Create a Dialog Application

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.
gui_compononent_selection.png
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:

  • Open the Add New Item ... dialog by right-clicking a source group in your project. Select the Template emWin GUI Thread for Single-Tasking Execution Model from the User Code Template section.

    AddItem.png
    Add Template
    • To start the graphics component just call Init_GUIThread(); from your main task.
    • The GUIThread requires some additional resources from your CMSIS-RTOS Kernel. Adjust your RTX_Conf_CM.c to provide following resources:
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.
OptionsForComponent.png
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.
OptionsForComponent2.png
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".
GuiBuilder.png
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:
AddDialog.png
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.