Files
RedBear-OS/local/recipes/kde/kf6-kwidgetsaddons/source/src/kpixmapsequenceoverlaypainter.h
T
2026-04-14 10:51:06 +01:00

149 lines
3.4 KiB
C++

/*
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