New Features in Qt 6.0: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
(Added short overview of Qt 6 to the beginning.)
m (Made minor updates to text, removed typos and fixed grammar.)
Line 1: Line 1:
[[Category:Release]]
[[Category:Release]]
[[Category:Developing Qt::Qt6]]
[[Category:Developing Qt::Qt6]]
Qt 6 is crated to enable Qt to be the productivity platform for the future. Qt 6.0 as a major release of Qt provides a higher degree of freedom to implement new features, functionality and better support the requirements of today and tomorrow. Qt 6.0 is a continuation of the Qt 5 series and should as such not be disruptive for users to migrate on.
The product mission of Qt 6 is to enable Qt to be the productivity platform for the future. Qt 6.0, as a major release of Qt, provides a higher degree of freedom to implement new features, functionality, and better support today and tomorrow's requirements. Qt 6.0 is a continuation of the Qt 5 series and should not be disruptive for users to migrate on.


When creating Qt 6, we have especially wanted to ensure that the core values that Qt has for our customers and users are adhered to:
When creating Qt 6, we have especially wanted to ensure that the core values that Qt has for our customers and users are adhered to:


* Its cross-platform nature, allowing users to deploy their applications to all desktop, mobile and embedded platforms using one technology and from a single code base
* Its cross-platform nature, allowing users to deploy their applications to all desktop, mobile, and embedded platforms using one technology and from a single code base
* Its scalability from low-end, single-purpose devices to high-end complex desktop applications or connected system
* Its scalability from low-end, single-purpose devices to high-end complex desktop applications or connected system
* World-class APIs and tools and documentation, simplifying the creation of applications and devices
* World-class APIs and tools and documentation, simplifying the creation of applications and devices
* Maintainability, stability, and compatibility, allowing to maintain large code bases with minimal effort
* Maintainability, stability, and compatibility, allowing to maintain large code bases with minimal effort
* A large developer ecosystem with more than 1 million users
* A large developer ecosystem with more than 1.5 million users


Qt 6.0 is the first release of of Qt 6 series addressing the new market demands while keeping the core values at the heart of what we’re doing.  
Qt 6.0 is the first release of the Qt 6 series addressing new market demands while keeping the core values at the heart of what we're doing.


==Porting guide==
==Porting guide==
When creating Qt 6 our aim has been to keep as much compatibility with Qt 5 as possible, but some changes were inevitable in an effort to make Qt a better framework. To make it easier to port to Qt 6.0 we have created a [https://doc-snapshots.qt.io/qt6-dev/portingguide.html Porting guide] where  we try to summarize those changes and provide guidance to handle them. In the [https://doc-snapshots.qt.io/qt6-dev/portingguide.html g guide] you can find links to articles about changes that may affect your application, and which can help you transitioning from Qt 5 to Qt 6.
When creating Qt 6, we aim to retain as much compatibility with Qt 5 as possible, but some changes were inevitable to make Qt a better framework. To make it easier to port to Qt 6.0, we have created a [https://doc-snapshots.qt.io/qt6-dev/portingguide.html Porting guide] to summarize those changes and provide guidance to handle them. In the [https://doc-snapshots.qt.io/qt6-dev/portingguide.html guide], you can find links to articles about changes that may affect your application and help you transitioning from Qt 5 to Qt 6.


==New Features (within existing modules)==
==New Features (within existing modules)==


There's been lots of clean-up all round and many deprecated methods have been removed.
There have been lots of clean-up rounds, and we have removed many deprecated methods. The Qt 6 [https://doc-snapshots.qt.io/qt6-dev/ documentation snapshot]
The Qt 6 [https://doc-snapshots.qt.io/qt6-dev/ documentation snapshot]
pages, automatically generated by QDoc based on the code, include [https://doc-snapshots.qt.io/qt6-dev/obsoleteclasses.html Obsolete Classes] and [https://doc-snapshots.qt.io/qt6-dev/whatsnew60.html#new-classes-and-functions New Classes and Functions] lists.  
pages, automatically generated by QDoc based on the code, include
lists of [https://doc-snapshots.qt.io/qt6-dev/obsoleteclasses.html Obsolete Classes]
and [https://doc-snapshots.qt.io/qt6-dev/whatsnew60.html#new-classes-and-functions New Classes and Functions].


===Within QtCore===
===Within QtCore===
Line 40: Line 37:
**That enables support for number formatting and parsing in locales whose numerals are not in the BMP, making it possible now to include such locales, where CLDR has data for them.
**That enables support for number formatting and parsing in locales whose numerals are not in the BMP, making it possible now to include such locales, where CLDR has data for them.
**Corrections to grouping of digits (a.k.a. placement of "thousands separators", except that …) so that locales which group other than in threes are properly covered, and a leading separator is omitted if there are too few digits before it, as required by some locales (e.g. Spanish).
**Corrections to grouping of digits (a.k.a. placement of "thousands separators", except that …) so that locales which group other than in threes are properly covered, and a leading separator is omitted if there are too few digits before it, as required by some locales (e.g. Spanish).
**Use of accountancy formats for currency quantities, where available, in particular improving support for locale-specific representation of negative currency quantities.
**Use of accountancy formats for currency quantities, where available, improving support for locale-specific representation of negative currency quantities.


==New Modules==
==New Modules==
Line 72: Line 69:
See [[Checklist for Qt 6.0 inclusion]] for the selection process.
See [[Checklist for Qt 6.0 inclusion]] for the selection process.


Code from these Qt ''<platform>'' Extras modules will
Code from these Qt ''<platform>'' Extras modules will find new homes in more relevant modules over time, and any remaining APIs considered for inclusion in later 6.x releases:
find new homes in more relevant modules over time, and
any remaining APIs considered for inclusion in later 6.x releases:


*Qt Android Extras
*Qt Android Extras
Line 81: Line 76:


==Additional Modules Available via Package Manager==
==Additional Modules Available via Package Manager==
The following additional modules are are available via package manager functionality of the Qt online installer:  
The following additional modules are available via the package manager functionality in the Qt online installer:  


*Qt Image Formats
*Qt Image Formats

Revision as of 10:27, 3 November 2020

The product mission of Qt 6 is to enable Qt to be the productivity platform for the future. Qt 6.0, as a major release of Qt, provides a higher degree of freedom to implement new features, functionality, and better support today and tomorrow's requirements. Qt 6.0 is a continuation of the Qt 5 series and should not be disruptive for users to migrate on.

When creating Qt 6, we have especially wanted to ensure that the core values that Qt has for our customers and users are adhered to:

  • Its cross-platform nature, allowing users to deploy their applications to all desktop, mobile, and embedded platforms using one technology and from a single code base
  • Its scalability from low-end, single-purpose devices to high-end complex desktop applications or connected system
  • World-class APIs and tools and documentation, simplifying the creation of applications and devices
  • Maintainability, stability, and compatibility, allowing to maintain large code bases with minimal effort
  • A large developer ecosystem with more than 1.5 million users

Qt 6.0 is the first release of the Qt 6 series addressing new market demands while keeping the core values at the heart of what we're doing.

Porting guide

When creating Qt 6, we aim to retain as much compatibility with Qt 5 as possible, but some changes were inevitable to make Qt a better framework. To make it easier to port to Qt 6.0, we have created a Porting guide to summarize those changes and provide guidance to handle them. In the guide, you can find links to articles about changes that may affect your application and help you transitioning from Qt 5 to Qt 6.

New Features (within existing modules)

There have been lots of clean-up rounds, and we have removed many deprecated methods. The Qt 6 documentation snapshot pages, automatically generated by QDoc based on the code, include Obsolete Classes and New Classes and Functions lists.

Within QtCore

  • QByteArrayView now provides a light-weight way to view the content of a QByteArray or other char-equivalent array data
  • QPromise allows setting values, progress and exceptions to QFuture
  • QFuture supports attaching continuations
  • Signals can now be converted to QFuture objects
  • QVector and QList are unified. QList is updated and should be used by default when array-like behaviour is needed
  • QList, QString and QByteArray now have optimized complexity of insertion at the beginning (a.k.a. prepend)
  • Q_DECLARE_TYPEINFO() mechanism simplified:
    • Trivially copyable and trivially destructible types are automatically treated as relocatable (Q_RELOCATABLE_TYPE)
    • Q_MOVABLE_TYPE and Q_RELOCATABLE_TYPE mean the same thing
  • Container classes now use qsizetype as an underlying type for size and indexing. Additionally, several related classes got updated in a similar fashion (e.g. QTextBoundaryFinder and QRegularExpression). This change allows containers to hold more than 2^31 items on 64 bit platforms
  • QLocale improvements, principally around number formatting (plus lots of clean-up).
    • A few QChar-returning methods now return QString to cope with locales where the relevant "single character" is represented by a code-point outside Unicode's BMP (Basic Multilingual Plane); that is, they use surrogate pairs in UTF-16, hence two code-units in the encoding Qt uses, rather than only one.
    • That enables support for number formatting and parsing in locales whose numerals are not in the BMP, making it possible now to include such locales, where CLDR has data for them.
    • Corrections to grouping of digits (a.k.a. placement of "thousands separators", except that …) so that locales which group other than in threes are properly covered, and a leading separator is omitted if there are too few digits before it, as required by some locales (e.g. Spanish).
    • Use of accountancy formats for currency quantities, where available, improving support for locale-specific representation of negative currency quantities.

New Modules

Qt5Compat
Compatibility library providing access to legacy APIs removed in Qt 6.

Platform Changes

All

  • Qt is now built with CMake.
  • Qt High DPI scaling is now activated by default; the default rounding policy is PassThrough

Linux

macOS

Windows

Removed Modules

The following modules are removed and not planned to be developed further. Other modules that are not part of Qt 6.0 are considered for candidates to support with later Qt 6.x releases or as additional libraries on top of the baseline Qt release.

  • Qt Multimedia Widgets
  • Qt Graphical Effects
  • Qt Purchasing
  • Qt Quick Extras
  • Qt Quick WebGL
  • Qt Script
  • Qt XML Patterns

See Checklist for Qt 6.0 inclusion for the selection process.

Code from these Qt <platform> Extras modules will find new homes in more relevant modules over time, and any remaining APIs considered for inclusion in later 6.x releases:

  • Qt Android Extras
  • Qt Mac Extras
  • Qt X11 Extras

Additional Modules Available via Package Manager

The following additional modules are available via the package manager functionality in the Qt online installer:

  • Qt Image Formats
  • Qt 3D
  • Qt Network Authorization

The package manager provides these additional modules as source packages, which need to be built locally by the user.