Advance Wayland and KDE package bring-up
Ultraworked with [Sisyphus](https://github.com/code-yeongyu/oh-my-openagent) Co-authored-by: Sisyphus <clio-agent@sisyphuslabs.ai>
This commit is contained in:
@@ -0,0 +1,148 @@
|
||||
/*
|
||||
SPDX-FileCopyrightText: 2009 Sebastian Trueg <trueg@kde.org>
|
||||
|
||||
SPDX-License-Identifier: LGPL-2.1-or-later
|
||||
*/
|
||||
|
||||
#ifndef _K_PIXMAPSEQUENCE_OVERLAY_PAINTER_H_
|
||||
#define _K_PIXMAPSEQUENCE_OVERLAY_PAINTER_H_
|
||||
|
||||
#include <QObject>
|
||||
#include <QPoint>
|
||||
#include <memory>
|
||||
|
||||
#include <kwidgetsaddons_export.h>
|
||||
|
||||
class KPixmapSequence;
|
||||
class QWidget;
|
||||
class QEvent;
|
||||
class QRect;
|
||||
|
||||
/**
|
||||
* \class KPixmapSequenceOverlayPainter kpixmapsequenceoverlaypainter.h KPixmapSequenceOverlayPainter
|
||||
*
|
||||
* \brief Paints a KPixmapSequence on top of any widget at any position.
|
||||
*
|
||||
* The KPixmapSequenceOverlayPainter paints an overlay on top of an arbitrary QWidget
|
||||
* using a KPixmapSequence. This is typically used for spinners indicating that a process
|
||||
* is not finished yet.
|
||||
*
|
||||
* \author Sebastian Trueg <trueg@kde.org>
|
||||
*
|
||||
* \since 4.4
|
||||
*/
|
||||
class KWIDGETSADDONS_EXPORT KPixmapSequenceOverlayPainter : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
/**
|
||||
* Constructor
|
||||
*/
|
||||
explicit KPixmapSequenceOverlayPainter(QObject *parent = nullptr);
|
||||
KPixmapSequenceOverlayPainter(const KPixmapSequence &seq, QObject *parent = nullptr);
|
||||
|
||||
/**
|
||||
* Destructor
|
||||
*/
|
||||
~KPixmapSequenceOverlayPainter() override;
|
||||
|
||||
/**
|
||||
* The sequence used to draw the overlay.
|
||||
*
|
||||
* \sa setSequence
|
||||
*/
|
||||
KPixmapSequence sequence() const;
|
||||
|
||||
/**
|
||||
* The interval between frames.
|
||||
*
|
||||
* \sa setInterval
|
||||
*/
|
||||
int interval() const;
|
||||
|
||||
/**
|
||||
* The optional rect to draw the pixmaps in.
|
||||
* \sa setRect
|
||||
*/
|
||||
QRect rect() const;
|
||||
|
||||
/**
|
||||
* The alignment of the pixmaps in the rect.
|
||||
* \sa setAlignment
|
||||
*/
|
||||
Qt::Alignment alignment() const;
|
||||
|
||||
/**
|
||||
* The optional offset within the rect.
|
||||
* \sa setOffset
|
||||
*/
|
||||
QPoint offset() const;
|
||||
|
||||
public Q_SLOTS:
|
||||
/**
|
||||
* Set the sequence to be used. By default the KDE busy sequence is used.
|
||||
*/
|
||||
void setSequence(const KPixmapSequence &seq);
|
||||
|
||||
/**
|
||||
* Set the interval between frames. The default is 200.
|
||||
*/
|
||||
void setInterval(int msecs);
|
||||
|
||||
/**
|
||||
* Set the widget to draw the overlay on.
|
||||
*/
|
||||
void setWidget(QWidget *w);
|
||||
|
||||
/**
|
||||
* Set the rect in which to place the sequence. Be aware that
|
||||
* this optional property does not scale the pixmaps (except if
|
||||
* it is smaller) but allows to change the placement.
|
||||
*
|
||||
* \param rect The rect in which to draw the pixmap using alignment
|
||||
* and offset. Be aware that setting a rect bigger than the widget
|
||||
* can lead to weird painting errors.
|
||||
*
|
||||
* Defaults to the widget's rect.
|
||||
*/
|
||||
void setRect(const QRect &rect);
|
||||
|
||||
/**
|
||||
* Set the alignment of the sequence in rect.
|
||||
*
|
||||
* \param align alignment of the overlay. Qt::AlignJustify does not make sense here.
|
||||
* Defaults to Qt::Center.
|
||||
*/
|
||||
void setAlignment(Qt::Alignment align);
|
||||
|
||||
/**
|
||||
* Set the offset relative to the placement determined by alignment
|
||||
* and rect.
|
||||
*
|
||||
* \param offset An optional offset which allows an absolute placement.
|
||||
*
|
||||
* Defaults to an empty point.
|
||||
*/
|
||||
void setOffset(const QPoint &offset);
|
||||
|
||||
/**
|
||||
* Start drawing the sequence.
|
||||
*
|
||||
* The overlay will be drawn until a call to stop()
|
||||
*/
|
||||
void start();
|
||||
|
||||
/**
|
||||
* Stop drawing the overlay.
|
||||
*/
|
||||
void stop();
|
||||
|
||||
protected:
|
||||
bool eventFilter(QObject *obj, QEvent *event) override;
|
||||
|
||||
private:
|
||||
std::unique_ptr<class KPixmapSequenceOverlayPainterPrivate> const d;
|
||||
};
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user