Porting C++ Applications to Qt 5

This topic talks about the Qt Widgets changes in Qt 5. The following step-by-step instructions take you through the changes required to port the Animated Tiles application to Qt 5:

  1. Open the Animated Tiles project using Qt Creator.
  2. Edit main.cpp and replace the #include <QtGui> instance with #include <QtWidgets>. The Perl-script fixqt4headers.pl can be used to scan the source files of a project and perform the replacements.
  3. Edit the animatedtiles.pro and add QT += widgets towards the end of the file.

    Note: Qt GUI is included by default in all Qt applications unless excluded using the QT -= gui directive in the qmake project file.

  4. Save the changes and run the application.

Once you see the application running, check whether it behaves as expected.

"A snapshot of the \c animatedtiles application running on Ubuntu v12.04"

It is also possible to keep the project compiling with Qt 4 and Qt 5. This requires:

  1. Omitting the module name from all includes by running the fixqt4headers.pl script with the --strip-modules option.
  2. Adding scopes depending on the version of Qt to the .pro files:
    greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
  3. Introducing #if scopes around code using modified API:
    #if QT_VERSION >= 0x050000
        headerView->setSectionResizeMode(QHeaderView::ResizeToContents);
    #else
        headerView->setResizeMode(QHeaderView::ResizeToContents);
    #endif

if you are using Qt WebKit, see Qt WebKit to Qt WebEngine porting instructions.

© 2019 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.