Create mobile apps with Qt Creator

Extensible

The UI controls mentioned above were useful as a solid base that I could easily customize. All I was missing was a date and time picker in the style of Google Material. I programmed that within a few hours, and it is now available to the general public via the GitHub repository. I also found buttons, but not floating action buttons (FABs), which modern apps that use a Google Material style would need. Listing 1 shows the code to make a FAB from a button. Calling a FAB in the main program is then quite simple. Listing 2 shows you how.

Listing 1

Floating action button (FAB)

 

Listing 2

Calling the FAB

 

Navigation, Data, and Structure

The major navigation elements are all used in the conference app. The Drawer navigation control with the hamburger menu (Figure 2) allows access to all areas of the program. A navigation bar at the bottom helps a user reach the main targets quickly.

Figure 2: The Drawer control at top left allows access to all areas of the program.

The conference schedule uses the SwipeView and TabBar elements, which users can use to switch between the days of the conference using swipe gestures or tabs. The StackView element lets users climb up through the different levels and view contextual details (Figure 3) relating to, for example, sessions, details, speakers, talks, and venues.

Figure 3: The contextual details can be designed as Pages with a StackView.

Developers can easily combine all these navigation elements; thus, even very complex apps are no problem for Qt. Because components and loaders dynamically generate the controls and pages, memory usage remains manageable, and the app remains fast as a whole.

The application pushes data into the filesystem in the usual way in the form of JSON files or stores them permanently in a SQLite database. Listing 3 contains the code for saving a list as a JSON array, and Figure 4 shows a typical application structure.

Figure 4: The complete app structure with Qt 5.7.

Listing 3

Save a list as a JSON array

 

Conclusion

Following the release of version 5.7 and thanks to Qt Quick Controls 2, Qt is now an excellent choice for developing visually appealing, high-performance mobile apps. The advantage is that you need only one codebase for all platforms.

It can be somewhat difficult to find the appropriate pages in the documentation, because Qt is not just available for mobile devices, but also for desktop and embedded devices. The blog [7] gives developers a little assistance in this matter.

Qt is open source, but also available with a commercial license. Independent developers and start-ups need a license, which you can secure from $79 (EUR72) per month, because, unfortunately, the LGPL is not suitable for apps in Apple's App Store. If you have any questions about the licenses, your best bet is to watch the video [8] that discusses the legal situation in more detail.

Infos

  1. Qt Widgets: https://doc.qt.io/qt-5/qtwidgets-index.html
  2. Qt Quick: https://www.qt.io/qt-quick/
  3. Qt Quick Controls 2: http://doc.qt.io/qt-5/qtquickcontrols2-index.html
  4. Qt Creator: https://www.qt.io/ide/
  5. QtCon website: https://qtcon.org
  6. QtCon Conference App on Github: https://github.com/ekke/c2gQtCon_x
  7. Blog on mobile apps with Qt: http://j.mp/qt-x
  8. Qt video on licensing issues: https://www.youtube.com/watch?v=lSYDWnsfWUk

The Author

Ekke Gentz is an independent software architect and has been developing software for almost 40 years. In the past few years, he has focused on mobile apps for business applications.

Buy this article as PDF

Express-Checkout as PDF
Price $2.95
(incl. VAT)

Buy Linux Magazine

SINGLE ISSUES
 
SUBSCRIPTIONS
 
TABLET & SMARTPHONE APPS
Get it on Google Play

US / Canada

Get it on Google Play

UK / Australia

Related content

  • Firefox for Mobile (Fennec)

    Firefox goes mobile – a “desktop” browser in the palm of your hand.

  • Q-DVD-Author

    Authoring video DVDs with Linux was a problem for a long time, but a few useful tools are closing the gap. And Q-DVD-Author gives you a handy front-end for controlling the process.

  • Tutorials – Cordova Sensor

    Frameworks like Cordova make creating simple mobile apps quite easy. Making apps that use your phone's sensor is slightly trickier, but, thanks to a new universal standard, things are not as hard as you may think.

  • Cinnamon and Mate

    The Cinnamon and Mate desktop systems have stirred up plenty attention around the Linux world. We'll show you around these innovative new desktop systems and help you decide which is right for you.

  • Krita Vs. MyPaint

    If you are looking for an open source drawing program, Krita and MyPaint both offer graphic tablet support and brushes. Deciding which one works best depends on your specific needs.

comments powered by Disqus
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters

Support Our Work

Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.

Learn More

News