Site icon Embarcadero RAD Studio, Delphi, & C++Builder Blogs

Cross Platform Activity Progress Dialog For Android, iOS, macOS, and Windows In Delphi 10.2 Tokyo

The Hospitality Survey Client project is part of the Hospitality Survey App template for Delphi 10.2 Tokyo, which Embarcadero released through their GetIt platform. The Hospitality Survey App consists of four different projects. In this blog post, I will cover the progress/activity dialog TFrame built into the Hospitality Survey Client project.

The progress/activity functionality is built as a TFrame, included in the Main Form, and set to Align := Contents. Align := Contents means that it ignores all of the other aligned elements and just fills its parent container (which in this case is the Main Form). Inside of the TFrame there is a semi-transparent background rectangle to cover the entire interface under the TFrame, and then there is a TCircle in the center of the TFrame. Inside of the TCircle is a second smaller TCircle and a TArc component.

The TArc component has a 90 degree arc which fills in the space between the two circles (see the diagram). A TFloatAnimation component on the TArc allows its RotationAngle property to animation and the end result is that the TArc spins around in between the two TCircles creating a nice-looking progress/activity dialog. You can see on the TFloatAnimation component that the StartValue is 0 and the StopValue is 360.

Throughout the app where it needs to show a “working” dialog and disable the user interface, it calls ShowActivity (see below) before starting the long operation, and then when the long operation is complete, it calls HideActivity.

[crayon-673fe693735ce560843507/]

Inside the TProgressFrame these two functions Show and Hide the TFrame and enable/disable the animation.

[crayon-673fe693735d9624176445/]

And that’s all there is to it. There is no other code to write. This responsive progress/activity dialog should work across Android, iOS, macOS, and Windows.

If you need a platform-native dialog for Android and iOS you can check out the TfgProgressDialog and TfgActivityDialog components in the FGX component set over on Github. You could also combine the native dialogs with the TFrame dialog mentioned above to get coverage across all 4 platforms (native dialogs on Android/iOS and then FMX dialogs on Windows and macOS).

 

Do you want to create an app for iOS, Android, macOS, and Windows? Try the Cross-Platform App Builder for the healthcare industry, which can help you create apps in the Delphi or C++ environments.
Exit mobile version