cf12defd28
Ultraworked with [Sisyphus](https://github.com/code-yeongyu/oh-my-openagent) Co-authored-by: Sisyphus <clio-agent@sisyphuslabs.ai>
149 lines
3.4 KiB
C++
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
|