This library contains code to interface pybind11 with Qt and PyQt.
The main part of this library is a set of (templated) type casters for Qt types that
can be used by simply importing pybind11_qt/pybind11_qt.h.
This provides type casters for:
- Standard Qt types, such as
QStringorQVariant.QStringis equivalent to Pythonstr(unicode or not).QVariantis not exposed but the object is directly converted, similarly tostd::variantdefault type caster.
- Qt containers (
QList,QSet,QMap,QStringList).- The
QListtype-caster is more flexible than the standard container type-casters from pybind11 as it accepts any iterable.
- The
QFlags- Delegates the cast to the underlying type, basically.- Qt enumerations: a lot of enumerations are provided in
pybind11_qt_enums.hand new ones can be easily added using thePYQT_ENUMmacro (inside the header file). - Qt objects: very few are provided in
pybind11_qt_objects.hand new ones can be added using thePYQT_OBJECTmacro (inside the header file).- Copy-constructible Qt objects are copied when passing from C++ to Python or vice-versa.
- Non copy-constructible Qt objects, e.g.,
QObjectorQWidgetshould always be exposed as pointer, and their ownership is transferred to C++ when coming from Python.
The library also provides a pybind11::qt::qobject_holder holder for pybind11 that
transfer ownerships of the Python object to the underlying QObject.
This holder is useful when exposing classes inheriting QObject (or a child class of
QObject) that can be extended to Python.
The library also provides two set_qt_owner functions that can be used to transfer
ownership manually.
The library provides a add_qt_delegate function that can be used to delegate Python
call to Qt functions to C++:
py::class_<
// the C++ class extending QObject to expose
ISaveGameInfoWidget,
// the trampoline class
PySaveGameInfoWidget,
// the Qt holder to keep the Python object alive alongside the C++ one
py::qt::qobject_holder<ISaveGameInfoWidget>
> iSaveGameInfoWidget(m, "ISaveGameInfoWidget");
// allow to access most of the class attributes through Python via an overload of
// __getattr__ and add a _widget() method to access the widget itself if needed
//
py::qt::add_qt_delegate<QWidget>(iSaveGameInfoWidget, "_widget");