Search for usage in LXR

KDecoration2::Decoration Class Referenceabstract

#include <decoration.h>

Inheritance diagram for KDecoration2::Decoration:


int borderBottom
int borderLeft
int borderRight
QMargins borders
int borderTop
bool opaque
int resizeOnlyBorderBottom
int resizeOnlyBorderLeft
int resizeOnlyBorderRight
QMargins resizeOnlyBorders
int resizeOnlyBorderTop
Qt::WindowFrameSection sectionUnderMouse
QRect titleBar
- Properties inherited from QObject


void blurRegionChanged ()
void bordersChanged ()
void damaged (const QRegion &region)
void opaqueChanged (bool)
void resizeOnlyBordersChanged ()
void sectionUnderMouseChanged (Qt::WindowFrameSection)
void shadowChanged (const std::shared_ptr< DecorationShadow > &shadow)
void titleBarChanged ()

Public Slots

virtual bool init ()=0
void requestClose ()
void requestContextHelp ()
void requestHideToolTip ()
void requestMinimize ()
void requestShowApplicationMenu (const QRect &rect, int actionId)
void requestShowToolTip (const QString &text)
void requestShowWindowMenu (const QRect &rect)
void requestToggleKeepAbove ()
void requestToggleKeepBelow ()
void requestToggleMaximization (Qt::MouseButtons buttons)
void requestToggleOnAllDesktops ()
void requestToggleShade ()
void showApplicationMenu (int actionId)
void update ()
void update (const QRect &rect)

Public Member Functions

QRegion blurRegion () const
int borderBottom () const
int borderLeft () const
int borderRight () const
QMargins borders () const
int borderTop () const
DecoratedClientclient () const
bool event (QEvent *event) override
bool isOpaque () const
virtual void paint (QPainter *painter, const QRect &repaintArea)=0
QRect rect () const
int resizeOnlyBorderBottom () const
int resizeOnlyBorderLeft () const
int resizeOnlyBorderRight () const
QMargins resizeOnlyBorders () const
int resizeOnlyBorderTop () const
Qt::WindowFrameSection sectionUnderMouse () const
void setSettings (const std::shared_ptr< DecorationSettings > &settings)
std::shared_ptr< DecorationSettingssettings () const
std::shared_ptr< DecorationShadowshadow () const
QSize size () const
QRect titleBar () const
- Public Member Functions inherited from QObject
 QObject (QObject *parent)
QBindable< QStringbindableObjectName ()
bool blockSignals (bool block)
const QObjectListchildren () const const
QMetaObject::Connection connect (const QObject *sender, const char *signal, const char *method, Qt::ConnectionType type) const const
void deleteLater ()
void destroyed (QObject *obj)
bool disconnect (const char *signal, const QObject *receiver, const char *method) const const
bool disconnect (const QObject *receiver, const char *method) const const
void dumpObjectInfo () const const
void dumpObjectTree () const const
QList< QByteArraydynamicPropertyNames () const const
virtual bool eventFilter (QObject *watched, QEvent *event)
findChild (const QString &name, Qt::FindChildOptions options) const const
QList< T > findChildren (const QRegularExpression &re, Qt::FindChildOptions options) const const
QList< T > findChildren (const QString &name, Qt::FindChildOptions options) const const
QList< T > findChildren (Qt::FindChildOptions options) const const
bool inherits (const char *className) const const
void installEventFilter (QObject *filterObj)
bool isQuickItemType () const const
bool isWidgetType () const const
bool isWindowType () const const
void killTimer (int id)
virtual const QMetaObjectmetaObject () const const
void moveToThread (QThread *targetThread)
QString objectName () const const
void objectNameChanged (const QString &objectName)
QObjectparent () const const
QVariant property (const char *name) const const
 Q_CLASSINFO (Name, Value)
 Q_ENUM (...)
 Q_ENUM_NS (...)
 Q_ENUMS (...)
 Q_FLAG (...)
 Q_FLAG_NS (...)
 Q_FLAGS (...)
qobject_cast (const QObject *object)
qobject_cast (QObject *object)
void removeEventFilter (QObject *obj)
void setObjectName (const QString &name)
void setObjectName (QAnyStringView name)
void setParent (QObject *parent)
bool setProperty (const char *name, const QVariant &value)
bool setProperty (const char *name, QVariant &&value)
bool signalsBlocked () const const
int startTimer (int interval, Qt::TimerType timerType)
int startTimer (std::chrono::milliseconds interval, Qt::TimerType timerType)
QThreadthread () const const

Protected Member Functions

 Decoration (QObject *parent, const QVariantList &args)
virtual void hoverEnterEvent (QHoverEvent *event)
virtual void hoverLeaveEvent (QHoverEvent *event)
virtual void hoverMoveEvent (QHoverEvent *event)
virtual void mouseMoveEvent (QMouseEvent *event)
virtual void mousePressEvent (QMouseEvent *event)
virtual void mouseReleaseEvent (QMouseEvent *event)
void setBlurRegion (const QRegion &region)
void setBorders (const QMargins &borders)
void setOpaque (bool opaque)
void setResizeOnlyBorders (const QMargins &borders)
void setShadow (const std::shared_ptr< DecorationShadow > &shadow)
void setTitleBar (const QRect &rect)
virtual void wheelEvent (QWheelEvent *event)
- Protected Member Functions inherited from QObject
virtual void childEvent (QChildEvent *event)
virtual void connectNotify (const QMetaMethod &signal)
virtual void customEvent (QEvent *event)
virtual void disconnectNotify (const QMetaMethod &signal)
bool isSignalConnected (const QMetaMethod &signal) const const
int receivers (const char *signal) const const
QObjectsender () const const
int senderSignalIndex () const const
virtual void timerEvent (QTimerEvent *event)

Additional Inherited Members

- Static Public Member Functions inherited from QObject
QMetaObject::Connection connect (const QObject *sender, const char *signal, const QObject *receiver, const char *method, Qt::ConnectionType type)
QMetaObject::Connection connect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method, Qt::ConnectionType type)
QMetaObject::Connection connect (const QObject *sender, PointerToMemberFunction signal, const QObject *context, Functor functor, Qt::ConnectionType type)
QMetaObject::Connection connect (const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method, Qt::ConnectionType type)
QMetaObject::Connection connect (const QObject *sender, PointerToMemberFunction signal, Functor functor)
bool disconnect (const QMetaObject::Connection &connection)
bool disconnect (const QObject *sender, const char *signal, const QObject *receiver, const char *method)
bool disconnect (const QObject *sender, const QMetaMethod &signal, const QObject *receiver, const QMetaMethod &method)
bool disconnect (const QObject *sender, PointerToMemberFunction signal, const QObject *receiver, PointerToMemberFunction method)
QString tr (const char *sourceText, const char *disambiguation, int n)
- Public Attributes inherited from QObject
typedef QObjectList

Detailed Description

Base class for the Decoration.

To provide a Decoration one needs to inherit from this class. The framework will instantiate an instance of the inherited class for each DecoratedClient.

The main tasks of the Decoration is to provide borders around the DecoratedClient. For this the Deocration provides border sizes: those should be adjusted depending on the state of the DecoratedClient. E.g. commonly a maximized DecoratedClient does not have borders on the side, only the title bar.

Whenever the visual representation of the Decoration changes the slot Decoration::update should be invoked to request a repaint. The framework will in return invoke the Decoration::paint method. This method needs to be implemented by inheriting classes.

A Decoration commonly provides buttons for interaction. E.g. a close button to close the DecoratedClient. For such actions the Decoration provides slots which should be connected to the clicked signals of the buttons. For convenience the framework provides the DecorationButton and the DecorationButtonGroup for easier layout. It is not required to use those, if one uses different ways to represent the actions one needs to filter the events accordingly.

See also

Definition at line 57 of file decoration.h.

Property Documentation

◆ borderBottom

int KDecoration2::Decoration::borderBottom

Definition at line 64 of file decoration.h.

◆ borderLeft

int KDecoration2::Decoration::borderLeft

Definition at line 61 of file decoration.h.

◆ borderRight

int KDecoration2::Decoration::borderRight

Definition at line 62 of file decoration.h.

◆ borders

QMargins KDecoration2::Decoration::borders

Definition at line 60 of file decoration.h.

◆ borderTop

int KDecoration2::Decoration::borderTop

Definition at line 63 of file decoration.h.

◆ opaque

bool KDecoration2::Decoration::opaque

Whether the Decoration is fully opaque.

By default a Decoration is considered to use the alpha channel and this property has the value false. But for e.g. a maximized DecoratedClient it is possible that the Decoration is fully opaque. In this case the Decoration should set this property to true.

Definition at line 87 of file decoration.h.

◆ resizeOnlyBorderBottom

int KDecoration2::Decoration::resizeOnlyBorderBottom

Definition at line 69 of file decoration.h.

◆ resizeOnlyBorderLeft

int KDecoration2::Decoration::resizeOnlyBorderLeft

Definition at line 66 of file decoration.h.

◆ resizeOnlyBorderRight

int KDecoration2::Decoration::resizeOnlyBorderRight

Definition at line 67 of file decoration.h.

◆ resizeOnlyBorders

QMargins KDecoration2::Decoration::resizeOnlyBorders

Definition at line 65 of file decoration.h.

◆ resizeOnlyBorderTop

int KDecoration2::Decoration::resizeOnlyBorderTop

Definition at line 68 of file decoration.h.

◆ sectionUnderMouse

Qt::WindowFrameSection KDecoration2::Decoration::sectionUnderMouse

This property denotes the part of the Decoration which is currently under the mouse pointer.

It gets automatically updated whenever a QMouseEvent or QHoverEvent gets processed.

Definition at line 74 of file decoration.h.

◆ titleBar

QRect KDecoration2::Decoration::titleBar

The titleBar is the area inside the Decoration containing all controls (e.g.

Buttons) and the caption. The titleBar is the main interaction area, while all other areas of the Decoration are normally used as resize areas.

Definition at line 80 of file decoration.h.

Constructor & Destructor Documentation

◆ Decoration()

KDecoration2::Decoration::Decoration ( QObject * parent,
const QVariantList & args )

Constructor for the Decoration.

The args are used by the decoration framework to pass meta information to the Decoration. An inheriting class is supposed to pass the args to the parent class.

parentThe parent of the Decoration
argsAdditional arguments passed in from the framework

Definition at line 131 of file decoration.cpp.

Member Function Documentation

◆ blurRegion()

QRegion KDecoration2::Decoration::blurRegion ( ) const

The decoration's blur region in local coordinates.

Definition at line 274 of file decoration.cpp.

◆ borderBottom()

int KDecoration2::Decoration::borderBottom ( ) const

Definition at line 339 of file decoration.cpp.

◆ borderLeft()

int KDecoration2::Decoration::borderLeft ( ) const

Definition at line 309 of file decoration.cpp.

◆ borderRight()

int KDecoration2::Decoration::borderRight ( ) const

Definition at line 319 of file decoration.cpp.

◆ borders()

QMargins KDecoration2::Decoration::borders ( ) const

Definition at line 279 of file decoration.cpp.

◆ borderTop()

int KDecoration2::Decoration::borderTop ( ) const

Definition at line 329 of file decoration.cpp.

◆ client()

DecoratedClient * KDecoration2::Decoration::client ( ) const

The DecoratedClient for this Decoration.

Definition at line 142 of file decoration.cpp.

◆ event()

bool KDecoration2::Decoration::event ( QEvent * event)

Reimplemented from QObject.

Definition at line 361 of file decoration.cpp.

◆ hoverEnterEvent()

void KDecoration2::Decoration::hoverEnterEvent ( QHoverEvent * event)

Definition at line 390 of file decoration.cpp.

◆ hoverLeaveEvent()

void KDecoration2::Decoration::hoverLeaveEvent ( QHoverEvent * event)

Definition at line 399 of file decoration.cpp.

◆ hoverMoveEvent()

void KDecoration2::Decoration::hoverMoveEvent ( QHoverEvent * event)

Definition at line 407 of file decoration.cpp.

◆ init

virtual bool KDecoration2::Decoration::init ( )
pure virtualslot

This method gets invoked from the framework once the Decoration is created and completely setup.

An inheriting class should override this method and perform all initialization in this method instead of the constructor.

true if initialization has been successful, false otherwise (for example, a QML component could not be loaded)

◆ isOpaque()

bool KDecoration2::Decoration::isOpaque ( ) const

Definition at line 304 of file decoration.cpp.

◆ mouseMoveEvent()

void KDecoration2::Decoration::mouseMoveEvent ( QMouseEvent * event)

Definition at line 429 of file decoration.cpp.

◆ mousePressEvent()

void KDecoration2::Decoration::mousePressEvent ( QMouseEvent * event)

Definition at line 440 of file decoration.cpp.

◆ mouseReleaseEvent()

void KDecoration2::Decoration::mouseReleaseEvent ( QMouseEvent * event)

Definition at line 453 of file decoration.cpp.

◆ paint()

virtual void KDecoration2::Decoration::paint ( QPainter * painter,
const QRect & repaintArea )
pure virtual

Implement this method in inheriting classes to provide the rendering.

The painter is set up to paint on an internal QPaintDevice. The painting is implicitly double buffered.

painterThe painter which needs to be used for rendering
repaintAreaThe region which needs to be repainted.

◆ rect()

QRect KDecoration2::Decoration::rect ( ) const

The decoration's geometry in local coordinates.

Basically the size of the DecoratedClient combined with the borders.

Definition at line 356 of file decoration.cpp.

◆ requestClose

void KDecoration2::Decoration::requestClose ( )

Definition at line 147 of file decoration.cpp.

◆ requestContextHelp

void KDecoration2::Decoration::requestContextHelp ( )

Definition at line 152 of file decoration.cpp.

◆ requestHideToolTip

void KDecoration2::Decoration::requestHideToolTip ( )

Definition at line 199 of file decoration.cpp.

◆ requestMinimize

void KDecoration2::Decoration::requestMinimize ( )

Definition at line 157 of file decoration.cpp.

◆ requestShowApplicationMenu

void KDecoration2::Decoration::requestShowApplicationMenu ( const QRect & rect,
int actionId )

Definition at line 219 of file decoration.cpp.

◆ requestShowToolTip

void KDecoration2::Decoration::requestShowToolTip ( const QString & text)

Definition at line 194 of file decoration.cpp.

◆ requestShowWindowMenu

void KDecoration2::Decoration::requestShowWindowMenu ( const QRect & rect)
rectthe location at which to show the window menu

Definition at line 189 of file decoration.cpp.

◆ requestToggleKeepAbove

void KDecoration2::Decoration::requestToggleKeepAbove ( )

Definition at line 172 of file decoration.cpp.

◆ requestToggleKeepBelow

void KDecoration2::Decoration::requestToggleKeepBelow ( )

Definition at line 177 of file decoration.cpp.

◆ requestToggleMaximization

void KDecoration2::Decoration::requestToggleMaximization ( Qt::MouseButtons buttons)

Definition at line 204 of file decoration.cpp.

◆ requestToggleOnAllDesktops

void KDecoration2::Decoration::requestToggleOnAllDesktops ( )

Definition at line 162 of file decoration.cpp.

◆ requestToggleShade

void KDecoration2::Decoration::requestToggleShade ( )

Definition at line 167 of file decoration.cpp.

◆ resizeOnlyBorderBottom()

int KDecoration2::Decoration::resizeOnlyBorderBottom ( ) const

Definition at line 344 of file decoration.cpp.

◆ resizeOnlyBorderLeft()

int KDecoration2::Decoration::resizeOnlyBorderLeft ( ) const

Definition at line 314 of file decoration.cpp.

◆ resizeOnlyBorderRight()

int KDecoration2::Decoration::resizeOnlyBorderRight ( ) const

Definition at line 324 of file decoration.cpp.

◆ resizeOnlyBorders()

QMargins KDecoration2::Decoration::resizeOnlyBorders ( ) const

Definition at line 284 of file decoration.cpp.

◆ resizeOnlyBorderTop()

int KDecoration2::Decoration::resizeOnlyBorderTop ( ) const

Definition at line 334 of file decoration.cpp.

◆ sectionUnderMouse()

Qt::WindowFrameSection KDecoration2::Decoration::sectionUnderMouse ( ) const

Definition at line 294 of file decoration.cpp.

◆ setBlurRegion()

void KDecoration2::Decoration::setBlurRegion ( const QRegion & region)

Definition at line 226 of file decoration.cpp.

◆ setBorders()

void KDecoration2::Decoration::setBorders ( const QMargins & borders)

Definition at line 234 of file decoration.cpp.

◆ setOpaque()

void KDecoration2::Decoration::setOpaque ( bool opaque)

Definition at line 258 of file decoration.cpp.

◆ setResizeOnlyBorders()

void KDecoration2::Decoration::setResizeOnlyBorders ( const QMargins & borders)

Definition at line 242 of file decoration.cpp.

◆ setSettings()

void KDecoration2::Decoration::setSettings ( const std::shared_ptr< DecorationSettings > & settings)

Invoked by the framework to set the Settings for this Decoration before init is invoked.

Definition at line 485 of file decoration.cpp.

◆ setShadow()

void KDecoration2::Decoration::setShadow ( const std::shared_ptr< DecorationShadow > & shadow)

Definition at line 266 of file decoration.cpp.

◆ settings()

std::shared_ptr< DecorationSettings > KDecoration2::Decoration::settings ( ) const
The DecorationSettings used for this Decoration.

Definition at line 490 of file decoration.cpp.

◆ setTitleBar()

void KDecoration2::Decoration::setTitleBar ( const QRect & rect)

An implementation has to invoke this method whenever the area containing the controls and caption changes.

rectThe new geometry of the titleBar in Decoration coordinates

Definition at line 250 of file decoration.cpp.

◆ shadow()

std::shared_ptr< DecorationShadow > KDecoration2::Decoration::shadow ( ) const

DecorationShadow for this Decoration.

It is recommended that multiple Decorations share the same DecorationShadow. E.g one DecorationShadow for all inactive Decorations and one for the active Decoration.

Definition at line 299 of file decoration.cpp.

◆ showApplicationMenu

void KDecoration2::Decoration::showApplicationMenu ( int actionId)

Definition at line 209 of file decoration.cpp.

◆ size()

QSize KDecoration2::Decoration::size ( ) const

Definition at line 349 of file decoration.cpp.

◆ titleBar()

QRect KDecoration2::Decoration::titleBar ( ) const

Definition at line 289 of file decoration.cpp.

◆ update [1/2]

void KDecoration2::Decoration::update ( )

Definition at line 480 of file decoration.cpp.

◆ update [2/2]

void KDecoration2::Decoration::update ( const QRect & rect)

Definition at line 475 of file decoration.cpp.

◆ wheelEvent()

void KDecoration2::Decoration::wheelEvent ( QWheelEvent * event)

Definition at line 465 of file decoration.cpp.

The documentation for this class was generated from the following files:
This file is part of the KDE documentation.
Documentation copyright © 1996-2024 The KDE developers.
Generated on Fri May 17 2024 11:51:42 by doxygen 1.10.0 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.