An ImageProgress shows the current progress by using a TiledImage as the progress indicator on top of a background Image. The progress image, the Alpha and the Direction towards which the image will progress can be configured. It is possible to create a custom background image and change the different parameters of the progress indicator such as the position and the size to fit the custom background image.
The ImageProgress can be found in the Progress Indicators widget group in TouchGFX Designer.
The properties for an ImageProgress in TouchGFX Designer.
|Property Group||Property Descriptions|
|Name||Name of the widget. Name is the unique identifier used in TouchGFX Designer and code.|
|Location||X and Y specify the top left corner of the widget relative to its parent.|
W and H specify the width and height of the widget.
The size of an ImageProgress is determined by the size of the selected background image.
Lock specifies if the widget should be locked in its current X, Y, W and H.
Locking the widget also disables interacting with the widget through the screen.
Visible specifies the visibility of the widget.
Making the widget invisible also disables interacting with the widget through the screen.
|Style||Style specifies a predefined setup of the widget, that sets select properties to predefined values.|
These styles contain images that are free to use.
|Image||Background sets the background image.|
Progress sets the image used to display progress.
|Progress Position||X and Y coordinates specify the top left corner of the progress image relative to the position of the ProgressIndicator.|
W and H specify the width and height of the progress image.
|Values||Range Min and Range Max specify the minimum and maximum integer values of the indicator.|
Initial specifies the initial value of the progress indicator.Steps Total specifies at what granularity the progress indicator reports new values. For instance, if the progress needs to be reported as 0%, 10%, 20%, ..., 100%, the total value should be set to 10.
Steps Min specifies the minimum steps the progress indicator shows.
|Appearance||Direction specifies in which direction the progress indicator should progress.|
Anchor progress image at zero specifies if the progress image should be anchored in the 0 point relative to the progress direction, i.e. whether the image is "revealed" or "pulled".
Alpha specifies the transparency of the widget. The alpha value ranges between 0 and 255 for the widget. 0 is fully transparent and 255 is solid.
|Mixins||Draggable specifies if the widget is draggable at runtime.|
ClickListener specifies if the widget emits a callback when clicked.
FadeAnimator specifies if the widget can animate changes to its Alpha value.
MoveAnimator specifies if the widget can animate changes to X and Y values.
The actions and triggers supported by the ImageProgress are described in the following sections.
|Widget specific actions||Description|
|Set value||Set the value of the progress indicator.|
|Standard widget actions||Description|
|Move widget||Move a widget to a new position over time.|
|Fade widget||Modify alpha value of widget over time.|
|Hide widget||Hides a widget (sets visibility to false).|
|Show widget||Make a hidden widget visible (sets visibility to true).|
The ImageProgress does not emit any triggers.
An ImageProgress consists of a TiledImage and a background Image. Therefore, the ImageProgress is dependent on image drawing and is considered a fast performing widget on most platforms.
For more details on image drawing performance, read the General UI Component Performance section.
In the generated code for the View base class we can see how TouchGFX Designer sets up an ImageProgress.
imageProgress1.invalidate()if you change the appearance of the widget.
The following example illustrates how to implement the
handleTickEvent() function to simulate progress. Running this code creates the application shown at the beginning of this article.
To further explore the ImageProgress, try creating a new application within TouchGFX Designer with the following UI template: