QtBase  v6.3.1
Public Types | Public Member Functions | Static Public Member Functions | List of all members
QCocoaIntegration Class Reference

#include <qcocoaintegration.h>

Inheritance diagram for QCocoaIntegration:
Inheritance graph
[legend]
Collaboration diagram for QCocoaIntegration:
Collaboration graph
[legend]

Public Types

enum  Option { UseFreeTypeFontEngine = 0x1 }
 
- Public Types inherited from QPlatformIntegration
enum  Capability {
  ThreadedPixmaps = 1 , OpenGL , ThreadedOpenGL , SharedGraphicsCache ,
  BufferQueueingOpenGL , WindowMasks , MultipleWindows , ApplicationState ,
  ForeignWindows , NonFullScreenWindows , NativeWidgets , WindowManagement ,
  WindowActivation , SyncState , RasterGLSurface , AllGLFunctionsQueryable ,
  ApplicationIcon , SwitchableWidgetComposition , TopStackedNativeChildWindows , OpenGLOnRasterSurface ,
  MaximizeUsingFullscreenGeometry , PaintEvents , RhiBasedRendering
}
 
enum  StyleHint {
  CursorFlashTime , KeyboardInputInterval , MouseDoubleClickInterval , StartDragDistance ,
  StartDragTime , KeyboardAutoRepeatRate , ShowIsFullScreen , PasswordMaskDelay ,
  FontSmoothingGamma , StartDragVelocity , UseRtlExtensions , PasswordMaskCharacter ,
  SetFocusOnTouchRelease , ShowIsMaximized , MousePressAndHoldInterval , TabFocusBehavior ,
  ReplayMousePressOutsidePopup , ItemViewActivateItemOnSingleClick , UiEffects , WheelScrollLines ,
  ShowShortcutsInContextMenus , MouseQuickSelectionThreshold
}
 

Public Member Functions

 QCocoaIntegration (const QStringList &paramList)
 
 ~QCocoaIntegration ()
 
Options options () const
 
bool hasCapability (QPlatformIntegration::Capability cap) const override
 
QPlatformWindowcreatePlatformWindow (QWindow *window) const override
 
QPlatformWindowcreateForeignWindow (QWindow *window, WId nativeHandle) const override
 
QPlatformOffscreenSurfacecreatePlatformOffscreenSurface (QOffscreenSurface *surface) const override
 
QPlatformOpenGLContextcreatePlatformOpenGLContext (QOpenGLContext *context) const override
 
QOpenGLContextcreateOpenGLContext (NSOpenGLContext *, QOpenGLContext *shareContext) const override
 
QPlatformBackingStorecreatePlatformBackingStore (QWindow *widget) const override
 
QAbstractEventDispatchercreateEventDispatcher () const override
 
QCoreTextFontDatabasefontDatabase () const override
 
QCocoaNativeInterfacenativeInterface () const override
 
QPlatformInputContextinputContext () const override
 
QCocoaAccessibilityaccessibility () const override
 
QCocoaClipboardclipboard () const override
 
QCocoaDragdrag () const override
 
QStringList themeNames () const override
 
QPlatformThemecreatePlatformTheme (const QString &name) const override
 
QCocoaServicesservices () const override
 
QVariant styleHint (StyleHint hint) const override
 
Qt::KeyboardModifiers queryKeyboardModifiers () const override
 
QList< int > possibleKeys (const QKeyEvent *event) const override
 
void setToolbar (QWindow *window, NSToolbar *toolbar)
 
NSToolbar * toolbar (QWindow *window) const
 
void clearToolbars ()
 
void setApplicationIcon (const QIcon &icon) const override
 
void beep () const override
 
void quit () const override
 
- Public Member Functions inherited from QObject
Q_INVOKABLE QObject (QObject *parent=nullptr)
 
virtual ~QObject ()
 
virtual bool event (QEvent *event)
 
virtual bool eventFilter (QObject *watched, QEvent *event)
 
QString objectName () const
 
void setObjectName (const QString &name)
 
QBindable< QStringbindableObjectName ()
 
bool isWidgetType () const
 
bool isWindowType () const
 
bool signalsBlocked () const noexcept
 
bool blockSignals (bool b) noexcept
 
QThreadthread () const
 
void moveToThread (QThread *thread)
 
int startTimer (int interval, Qt::TimerType timerType=Qt::CoarseTimer)
 
void killTimer (int id)
 
template<typename T >
T findChild (const QString &aName=QString(), Qt::FindChildOptions options=Qt::FindChildrenRecursively) const
 
template<typename T >
QList< TfindChildren (const QString &aName, Qt::FindChildOptions options=Qt::FindChildrenRecursively) const
 
template<typename T >
QList< TfindChildren (Qt::FindChildOptions options=Qt::FindChildrenRecursively) const
 
const QObjectListchildren () const
 
void setParent (QObject *parent)
 
void installEventFilter (QObject *filterObj)
 
void removeEventFilter (QObject *obj)
 
QMetaObject::Connection connect (const QObject *sender, const char *signal, const char *member, Qt::ConnectionType type=Qt::AutoConnection) const
 
bool disconnect (const char *signal=nullptr, const QObject *receiver=nullptr, const char *member=nullptr) const
 
bool disconnect (const QObject *receiver, const char *member=nullptr) const
 
void dumpObjectTree () const
 
void dumpObjectInfo () const
 
bool setProperty (const char *name, const QVariant &value)
 
QVariant property (const char *name) const
 
QList< QByteArraydynamicPropertyNames () const
 
QBindingStoragebindingStorage ()
 
const QBindingStoragebindingStorage () const
 
QObjectparent () const
 
bool inherits (const char *classname) const
 
- Public Member Functions inherited from QPlatformIntegration
virtual ~QPlatformIntegration ()
 
virtual QPlatformPixmapcreatePlatformPixmap (QPlatformPixmap::PixelType type) const
 
virtual QPlatformSharedGraphicsCachecreatePlatformSharedGraphicsCache (const char *cacheId) const
 
virtual QPaintEnginecreateImagePaintEngine (QPaintDevice *paintDevice) const
 
virtual void initialize ()
 
virtual void destroy ()
 
virtual Qt::WindowState defaultWindowState (Qt::WindowFlags) const
 
virtual QPlatformSessionManagercreatePlatformSessionManager (const QString &id, const QString &key) const
 
virtual void sync ()
 
virtual QOpenGLContext::OpenGLModuleType openGLModuleType ()
 
template<auto func, typename... Args>
auto call (Args... args)
 

Static Public Member Functions

static QCocoaIntegrationinstance ()
 
- Static Public Member Functions inherited from QObject
static QMetaObject::Connection connect (const QObject *sender, const char *signal, const QObject *receiver, const char *member, Qt::ConnectionType=Qt::AutoConnection)
 
static QMetaObject::Connection connect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method, Qt::ConnectionType type=Qt::AutoConnection)
 
template<typename Func1 , typename Func2 >
static QMetaObject::Connection connect (const typename QtPrivate::FunctionPointer< Func1 >::Object *sender, Func1 signal, const typename QtPrivate::FunctionPointer< Func2 >::Object *receiver, Func2 slot, Qt::ConnectionType type=Qt::AutoConnection)
 
static QMetaObject::Connection ::type connect (const typename QtPrivate::FunctionPointer< Func1 >::Object *sender, Func1 signal, Func2 slot)
 
static QMetaObject::Connection ::type connect (const typename QtPrivate::FunctionPointer< Func1 >::Object *sender, Func1 signal, const QObject *context, Func2 slot, Qt::ConnectionType type=Qt::AutoConnection)
 
template<typename Func1 , typename Func2 >
static std::enable_if< QtPrivate::FunctionPointer< Func2 >::ArgumentCount==-1 &&!std::is_convertible_v< Func2, const char * >, QMetaObject::Connection >::type connect (const typename QtPrivate::FunctionPointer< Func1 >::Object *sender, Func1 signal, Func2 slot)
 
template<typename Func1 , typename Func2 >
static std::enable_if< QtPrivate::FunctionPointer< Func2 >::ArgumentCount==-1 &&!std::is_convertible_v< Func2, const char * >, QMetaObject::Connection >::type connect (const typename QtPrivate::FunctionPointer< Func1 >::Object *sender, Func1 signal, const QObject *context, Func2 slot, Qt::ConnectionType type=Qt::AutoConnection)
 
static bool disconnect (const QObject *sender, const char *signal, const QObject *receiver, const char *member)
 
static bool disconnect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &member)
 
static bool disconnect (const QMetaObject::Connection &)
 
template<typename Func1 , typename Func2 >
static bool disconnect (const typename QtPrivate::FunctionPointer< Func1 >::Object *sender, Func1 signal, const typename QtPrivate::FunctionPointer< Func2 >::Object *receiver, Func2 slot)
 
template<typename Func1 >
static bool disconnect (const typename QtPrivate::FunctionPointer< Func1 >::Object *sender, Func1 signal, const QObject *receiver, void **zero)
 

Additional Inherited Members

- Public Slots inherited from QObject
void deleteLater ()
 
- Signals inherited from QObject
void destroyed (QObject *=nullptr)
 
void objectNameChanged (const QString &objectName, QPrivateSignal)
 
- Protected Member Functions inherited from QObject
QObjectsender () const
 
int senderSignalIndex () const
 
int receivers (const char *signal) const
 
bool isSignalConnected (const QMetaMethod &signal) const
 
virtual void timerEvent (QTimerEvent *event)
 
virtual void childEvent (QChildEvent *event)
 
virtual void customEvent (QEvent *event)
 
virtual void connectNotify (const QMetaMethod &signal)
 
virtual void disconnectNotify (const QMetaMethod &signal)
 
 QObject (QObjectPrivate &dd, QObject *parent=nullptr)
 
- Protected Member Functions inherited from QPlatformIntegration
 QPlatformIntegration ()=default
 
- Protected Attributes inherited from QObject
QScopedPointer< QObjectDatad_ptr
 
- Properties inherited from QObject
QString objectName
 the name of this object More...
 

Detailed Description

Definition at line 65 of file qcocoaintegration.h.

Member Enumeration Documentation

◆ Option

Enumerator
UseFreeTypeFontEngine 

Definition at line 72 of file qcocoaintegration.h.

Constructor & Destructor Documentation

◆ QCocoaIntegration()

QCocoaIntegration::QCocoaIntegration ( const QStringList paramList)

Definition at line 133 of file qcocoaintegration.mm.

◆ ~QCocoaIntegration()

QCocoaIntegration::~QCocoaIntegration ( )

Definition at line 215 of file qcocoaintegration.mm.

Here is the call graph for this function:

Member Function Documentation

◆ accessibility()

QCocoaAccessibility * QCocoaIntegration::accessibility ( ) const
overridevirtual

Returns the platforms accessibility.

The default implementation returns QPlatformAccessibility which delegates handling of accessibility to accessiblebridge plugins.

Reimplemented from QPlatformIntegration.

Definition at line 379 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ beep()

void QCocoaIntegration::beep ( ) const
overridevirtual
Since
5.7

Should sound a bell, using the default volume and sound.

See also
QApplication::beep()

Reimplemented from QPlatformIntegration.

Definition at line 470 of file qcocoaintegration.mm.

◆ clearToolbars()

void QCocoaIntegration::clearToolbars ( )

Definition at line 453 of file qcocoaintegration.mm.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ clipboard()

QCocoaClipboard * QCocoaIntegration::clipboard ( ) const
overridevirtual

Accessor for the platform integration's clipboard.

Default implementation returns a default QPlatformClipboard.

See also
QPlatformClipboard

Reimplemented from QPlatformIntegration.

Definition at line 386 of file qcocoaintegration.mm.

◆ createEventDispatcher()

QAbstractEventDispatcher * QCocoaIntegration::createEventDispatcher ( ) const
overridevirtual

Factory function for the GUI event dispatcher. The platform plugin should create and return a QAbstractEventDispatcher subclass when this function is called.

If the platform plugin for some reason creates the event dispatcher outside of this function (for example in the constructor), it needs to handle the case where this function is never called, ensuring that the event dispatcher is still deleted at some point (typically in the destructor).

Note that the platform plugin should never explicitly set the event dispatcher itself, using QCoreApplication::setEventDispatcher(), but let QCoreApplication decide when and which event dispatcher to create.

Since
5.2

Implements QPlatformIntegration.

Definition at line 345 of file qcocoaintegration.mm.

◆ createForeignWindow()

QPlatformWindow * QCocoaIntegration::createForeignWindow ( QWindow window,
WId  nativeHandle 
) const
overridevirtual

Reimplemented from QPlatformIntegration.

Definition at line 291 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ createOpenGLContext()

QOpenGLContext * QCocoaIntegration::createOpenGLContext ( NSOpenGLContext *  nativeContext,
QOpenGLContext shareContext 
) const
override

Definition at line 320 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ createPlatformBackingStore()

QPlatformBackingStore * QCocoaIntegration::createPlatformBackingStore ( QWindow window) const
overridevirtual

Factory function for QPlatformBackingStore. The QWindow parameter is a pointer to the top level widget(tlw) the window surface is created for. A QPlatformWindow is always created before the QPlatformBackingStore for tlw where the widget also requires a backing store.

See also
QBackingStore
createPlatformWindow()

Implements QPlatformIntegration.

Definition at line 334 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ createPlatformOffscreenSurface()

QPlatformOffscreenSurface * QCocoaIntegration::createPlatformOffscreenSurface ( QOffscreenSurface surface) const
overridevirtual

Factory function for QOffscreenSurface. An offscreen surface will typically be implemented with a pixel buffer (pbuffer). If the platform doesn't support offscreen surfaces, an invisible window will be used by QOffscreenSurface instead.

Reimplemented from QPlatformIntegration.

Definition at line 309 of file qcocoaintegration.mm.

◆ createPlatformOpenGLContext()

QPlatformOpenGLContext * QCocoaIntegration::createPlatformOpenGLContext ( QOpenGLContext context) const
overridevirtual

Factory function for QPlatformOpenGLContext. The context parameter is a pointer to the context for which a platform-specific context backend needs to be created. Configuration settings like the format, share context and screen have to be taken from this QOpenGLContext and the resulting platform context is expected to be backed by a native context that fulfills these criteria.

If the context has native handles set, no new native context is expected to be created. Instead, the provided handles have to be used. In this case the ownership of the handle must not be taken and the platform implementation is not allowed to destroy the native context. Configuration parameters like the format are also to be ignored. Instead, the platform implementation is responsible for querying the configuriation from the provided native context.

Returns a pointer to a QPlatformOpenGLContext instance or \nullptr if the context could not be created.

See also
QOpenGLContext

Reimplemented from QPlatformIntegration.

Definition at line 315 of file qcocoaintegration.mm.

◆ createPlatformTheme()

QPlatformTheme * QCocoaIntegration::createPlatformTheme ( const QString name) const
overridevirtual

Reimplemented from QPlatformIntegration.

Definition at line 402 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ createPlatformWindow()

QPlatformWindow * QCocoaIntegration::createPlatformWindow ( QWindow window) const
overridevirtual

Factory function for QPlatformWindow. The window parameter is a pointer to the window which the QPlatformWindow is supposed to be created for.

All windows have to have a QPlatformWindow, and it will be created on-demand when the QWindow is made visible for the first time, or explicitly through calling QWindow::create().

In the constructor, of the QPlatformWindow, the window flags, state, title and geometry of the window should be applied to the underlying window. If the resulting flags or state differs, the resulting values should be set on the window using QWindow::setWindowFlags() or QWindow::setWindowState(), respectively.

See also
QPlatformWindow, QPlatformWindowFormat
createPlatformBackingStore()

Implements QPlatformIntegration.

Definition at line 286 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ drag()

QCocoaDrag * QCocoaIntegration::drag ( ) const
override

Definition at line 392 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ fontDatabase()

QCoreTextFontDatabase * QCocoaIntegration::fontDatabase ( ) const
overridevirtual

Accessor for the platform integration's fontdatabase.

Default implementation returns a default QPlatformFontDatabase.

See also
QPlatformFontDatabase

Reimplemented from QPlatformIntegration.

Definition at line 363 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ hasCapability()

bool QCocoaIntegration::hasCapability ( QPlatformIntegration::Capability  cap) const
overridevirtual

Reimplemented from QPlatformIntegration.

Definition at line 260 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ inputContext()

QPlatformInputContext * QCocoaIntegration::inputContext ( ) const
overridevirtual

Returns the platforms input context.

The default implementation returns \nullptr, implying no input method support.

Reimplemented from QPlatformIntegration.

Definition at line 373 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ instance()

QCocoaIntegration * QCocoaIntegration::instance ( )
static

Definition at line 243 of file qcocoaintegration.mm.

Here is the caller graph for this function:

◆ nativeInterface()

QCocoaNativeInterface * QCocoaIntegration::nativeInterface ( ) const
overridevirtual

Reimplemented from QPlatformIntegration.

Definition at line 368 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ options()

QCocoaIntegration::Options QCocoaIntegration::options ( ) const

Definition at line 248 of file qcocoaintegration.mm.

Here is the caller graph for this function:

◆ possibleKeys()

QList< int > QCocoaIntegration::possibleKeys ( const QKeyEvent ) const
overridevirtual

Should be used to obtain a list of possible shortcuts for the given key event. Shortcuts should be encoded as int(Qt::Key + Qt::KeyboardModifiers).

One example for more than one possibility is the key combination of Shift+5. That one might trigger a shortcut which is set as "Shift+5" as well as one using %. These combinations depend on the currently set keyboard layout.

Note
This function should be called only from key event handlers.

Reimplemented from QPlatformIntegration.

Definition at line 434 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ queryKeyboardModifiers()

Qt::KeyboardModifiers QCocoaIntegration::queryKeyboardModifiers ( ) const
overridevirtual

Reimplemented from QPlatformIntegration.

Definition at line 429 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ quit()

void QCocoaIntegration::quit ( ) const
overridevirtual
Since
6.0

Asks the platform to terminate the application.

Overrides should ensure there's a callback into the QWSI function handleApplicationTermination so that the quit can be propagated to QtGui and the application.

Reimplemented from QPlatformIntegration.

Definition at line 475 of file qcocoaintegration.mm.

◆ services()

QCocoaServices * QCocoaIntegration::services ( ) const
overridevirtual

Reimplemented from QPlatformIntegration.

Definition at line 409 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ setApplicationIcon()

void QCocoaIntegration::setApplicationIcon ( const QIcon icon) const
overridevirtual
Since
5.5

Platform integration function for setting the application icon.

See also
QGuiApplication::setWindowIcon()

Reimplemented from QPlatformIntegration.

Definition at line 463 of file qcocoaintegration.mm.

◆ setToolbar()

void QCocoaIntegration::setToolbar ( QWindow window,
NSToolbar *  toolbar 
)

Definition at line 439 of file qcocoaintegration.mm.

Here is the call graph for this function:

◆ styleHint()

QVariant QCocoaIntegration::styleHint ( StyleHint  hint) const
overridevirtual

Reimplemented from QPlatformIntegration.

Definition at line 414 of file qcocoaintegration.mm.

◆ themeNames()

QStringList QCocoaIntegration::themeNames ( ) const
overridevirtual

Reimplemented from QPlatformIntegration.

Definition at line 397 of file qcocoaintegration.mm.

◆ toolbar()

NSToolbar * QCocoaIntegration::toolbar ( QWindow window) const

Definition at line 448 of file qcocoaintegration.mm.

Here is the call graph for this function:
Here is the caller graph for this function:

The documentation for this class was generated from the following files: