mirror of
https://github.com/rizinorg/cutter.git
synced 2024-12-23 05:16:11 +00:00
192 lines
4.6 KiB
C++
192 lines
4.6 KiB
C++
#ifndef COLORPICKER_H
|
|
#define COLORPICKER_H
|
|
|
|
#include <QWidget>
|
|
|
|
/**
|
|
* @namespace ColorPickerHelpers is a namespace that hides all classes needed for ColorPicker class,
|
|
* because classes inherite QObject can not be declared in *.cpp files or inside of another class.
|
|
*/
|
|
namespace ColorPickerHelpers {
|
|
class ColorPickWidgetAbstract : public QWidget
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
ColorPickWidgetAbstract(QWidget *parent = nullptr): QWidget(parent) {}
|
|
virtual ~ColorPickWidgetAbstract() {}
|
|
|
|
signals:
|
|
void colorChanged(const QColor& color);
|
|
|
|
public slots:
|
|
virtual void setColor(const QColor& color) = 0;
|
|
|
|
protected:
|
|
QColor currColor;
|
|
};
|
|
}
|
|
|
|
namespace Ui {
|
|
class ColorPicker;
|
|
}
|
|
|
|
/**
|
|
* @brief The ColorPicker class provides widget that allows user to pick color
|
|
* from screen or from palette or type in HSV or RGB or HEX representation of color.
|
|
*/
|
|
class ColorPicker : public ColorPickerHelpers::ColorPickWidgetAbstract
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
explicit ColorPicker(QWidget *parent = nullptr);
|
|
~ColorPicker();
|
|
|
|
/**
|
|
* @brief isPickingFromScreen returns true if color picker is picking from screen.
|
|
*/
|
|
bool isPickingFromScreen() const;
|
|
|
|
void setAlphaEnabled(bool enabled);
|
|
|
|
|
|
public slots:
|
|
/**
|
|
* @brief setColor sets displayed color to @a color and emits colorChanged signal.
|
|
*/
|
|
virtual void setColor(const QColor &color) override;
|
|
|
|
void colorChannelChanged();
|
|
|
|
/**
|
|
* @brief updateColor sets displayed color to @a color.
|
|
*/
|
|
void updateColor(const QColor& color);
|
|
|
|
/**
|
|
* @brief startPickingFromScreen starts process of picking from screen.
|
|
* Function is called automatically when "Pick from screen" button is clicked.
|
|
*/
|
|
void startPickingFromScreen();
|
|
|
|
/**
|
|
* @brief stopPickingFromScreen terminates process of picking from screen.
|
|
*/
|
|
void stopPickingFromScreen();
|
|
|
|
protected:
|
|
void mouseReleaseEvent(QMouseEvent* event) override;
|
|
void mouseMoveEvent(QMouseEvent* event) override;
|
|
|
|
private:
|
|
Ui::ColorPicker *ui;
|
|
bool pickingFromScreen;
|
|
|
|
QColor getColorAtMouse();
|
|
|
|
/**
|
|
* @brief bufferColor is used to buffer current color while picking from screen.
|
|
*/
|
|
QColor bufferColor;
|
|
};
|
|
|
|
namespace ColorPickerHelpers {
|
|
/**
|
|
* @brief The ColorPickerWidget class is parent class for ColorPickArea and ColorValueBar classes.
|
|
*/
|
|
class ColorPickerWidget : public ColorPickWidgetAbstract {
|
|
Q_OBJECT
|
|
public:
|
|
ColorPickerWidget(QWidget *parent = nullptr);
|
|
|
|
protected:
|
|
void mouseReleaseEvent(QMouseEvent* event) override;
|
|
void mousePressEvent(QMouseEvent* event) override;
|
|
void mouseMoveEvent(QMouseEvent* event) override;
|
|
|
|
virtual void mouseEvent(QMouseEvent* event);
|
|
|
|
/**
|
|
* @brief pointToColor converts coordinates on widget to color these coordinates represents.
|
|
*/
|
|
virtual QColor pointToColor(int x, int y) const = 0;
|
|
|
|
/**
|
|
* @brief colorToPoint converts color to coordinates that represent this color.
|
|
*/
|
|
virtual QPoint colorToPoint(const QColor& color) const = 0;
|
|
};
|
|
|
|
class ColorShowWidget : public ColorPickWidgetAbstract
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
explicit ColorShowWidget(QWidget *parent = nullptr);
|
|
|
|
void setColor(const QColor& c) override;
|
|
|
|
protected:
|
|
void paintEvent(QPaintEvent *event) override;
|
|
};
|
|
|
|
/**
|
|
* @brief The ColorPickArea class provides widget that helps to pick
|
|
* Saturation and Hue of color in HSV colorspace.
|
|
*/
|
|
class ColorPickArea : public ColorPickerWidget
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
explicit ColorPickArea(QWidget *parent = nullptr);
|
|
|
|
void setColor(const QColor& c) override;
|
|
|
|
protected:
|
|
void paintEvent(QPaintEvent *event) override;
|
|
|
|
private:
|
|
QColor pointToColor(int x, int y) const override;
|
|
|
|
QPoint colorToPoint(const QColor& color) const override;
|
|
};
|
|
|
|
class AlphaChannelBar : public ColorPickerWidget
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
AlphaChannelBar(QWidget *parent = nullptr) : ColorPickerWidget(parent) {}
|
|
|
|
void setColor(const QColor& c) override;
|
|
|
|
protected:
|
|
void paintEvent(QPaintEvent *event) override;
|
|
|
|
private:
|
|
QColor pointToColor(int x, int y) const override;
|
|
|
|
QPoint colorToPoint(const QColor& color) const override;
|
|
};
|
|
|
|
/**
|
|
* @brief The ColorValueBar class provides widget that helps to set Valuse of color
|
|
* in HSV colorspace.
|
|
*/
|
|
class ColorValueBar : public ColorPickerWidget
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
ColorValueBar(QWidget *parent = nullptr) : ColorPickerWidget(parent) {}
|
|
|
|
void setColor(const QColor& c) override;
|
|
|
|
protected:
|
|
void paintEvent(QPaintEvent *event) override;
|
|
|
|
private:
|
|
QColor pointToColor(int x, int y) const override;
|
|
|
|
QPoint colorToPoint(const QColor& color) const override;
|
|
};
|
|
}
|
|
|
|
#endif // COLORPICKER_H
|