QGCPalette.h 12.2 KB
Newer Older
1 2 3 4 5 6 7 8 9
/****************************************************************************
 *
 *   (c) 2009-2016 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>
 *
 * QGroundControl is licensed according to the terms in the file
 * COPYING.md in the root of the source code directory.
 *
 ****************************************************************************/

10 11 12 13 14 15
#ifndef QGCPalette_h
#define QGCPalette_h

#include <QObject>
#include <QColor>

Don Gagne's avatar
Don Gagne committed
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
/*!
 QGCPalette is used in QML ui to expose color properties for the QGC palette. There are two
 separate palettes in QGC, light and dark. The light palette is for outdoor use and the dark
 palette is for indoor use. Each palette also has a set of different colors for enabled and
 disabled states.

 Usage:

        import QGroundControl.Palette 1.0

        Rectangle {
            anchors.fill:   parent
            color:          qgcPal.window

            QGCPalette { id: qgcPal: colorGroupEnabled: enabled }
        }
*/
33 34 35 36
class QGCPalette : public QObject
{
    Q_OBJECT
    
37
    Q_ENUMS(Theme)
38
    
39 40 41
    Q_PROPERTY(Theme globalTheme READ globalTheme WRITE setGlobalTheme NOTIFY paletteChanged)
    
    Q_PROPERTY(bool colorGroupEnabled READ colorGroupEnabled WRITE setColorGroupEnabled NOTIFY paletteChanged)
42

43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
    Q_PROPERTY(QColor window                READ window                 WRITE setWindow                 NOTIFY paletteChanged)
    Q_PROPERTY(QColor windowShade           READ windowShade            WRITE setWindowShade            NOTIFY paletteChanged)
    Q_PROPERTY(QColor windowShadeDark       READ windowShadeDark        WRITE setWindowShadeDark        NOTIFY paletteChanged)
    Q_PROPERTY(QColor text                  READ text                   WRITE setText                   NOTIFY paletteChanged)
    Q_PROPERTY(QColor warningText           READ warningText            WRITE setWarningText            NOTIFY paletteChanged)
    Q_PROPERTY(QColor button                READ button                 WRITE setButton                 NOTIFY paletteChanged)
    Q_PROPERTY(QColor buttonText            READ buttonText             WRITE setButtonText             NOTIFY paletteChanged)
    Q_PROPERTY(QColor buttonHighlight       READ buttonHighlight        WRITE setButtonHighlight        NOTIFY paletteChanged)
    Q_PROPERTY(QColor buttonHighlightText   READ buttonHighlightText    WRITE setButtonHighlightText    NOTIFY paletteChanged)
    Q_PROPERTY(QColor primaryButton         READ primaryButton          WRITE setPrimaryButton          NOTIFY paletteChanged)
    Q_PROPERTY(QColor primaryButtonText     READ primaryButtonText      WRITE setPrimaryButtonText      NOTIFY paletteChanged)
    Q_PROPERTY(QColor textField             READ textField              WRITE setTextField              NOTIFY paletteChanged)
    Q_PROPERTY(QColor textFieldText         READ textFieldText          WRITE setTextFieldText          NOTIFY paletteChanged)
    Q_PROPERTY(QColor mapButton             READ mapButton              WRITE setMapButton              NOTIFY paletteChanged)
    Q_PROPERTY(QColor mapButtonHighlight    READ mapButtonHighlight     WRITE setMapButtonHighlight     NOTIFY paletteChanged)
58 59
    Q_PROPERTY(QColor mapWidgetBorderLight  READ mapWidgetBorderLight   WRITE setMapWidgetBorderLight   NOTIFY paletteChanged)
    Q_PROPERTY(QColor mapWidgetBorderDark   READ mapWidgetBorderDark    WRITE setMapWidgetBorderDark    NOTIFY paletteChanged)
Don Gagne's avatar
Don Gagne committed
60 61
    Q_PROPERTY(QColor brandingPurple        READ brandingPurple                                         NOTIFY paletteChanged)
    Q_PROPERTY(QColor brandingBlue          READ brandingBlue                                           NOTIFY paletteChanged)
62

63 64 65 66 67 68 69
    Q_PROPERTY(QColor colorGreen            READ colorGreen             CONSTANT)
    Q_PROPERTY(QColor colorOrange           READ colorOrange            CONSTANT)
    Q_PROPERTY(QColor colorRed              READ colorRed               CONSTANT)
    Q_PROPERTY(QColor colorGrey             READ colorGrey              CONSTANT)
    Q_PROPERTY(QColor colorBlue             READ colorBlue              CONSTANT)
    Q_PROPERTY(QColor colorWhite            READ colorWhite             CONSTANT)

70 71
public:
    enum ColorGroup {
Don Gagne's avatar
Don Gagne committed
72
        Disabled = 0,
73
        Enabled
74 75
    };
    
76 77 78 79 80
    enum Theme {
        Light = 0,
        Dark
    };
    
81 82 83
    QGCPalette(QObject* parent = NULL);
    ~QGCPalette();
    
84 85 86
    bool colorGroupEnabled(void) const { return _colorGroupEnabled; }
    void setColorGroupEnabled(bool enabled);
    
Don Gagne's avatar
Don Gagne committed
87
    /// Background color for windows
88
    QColor window(void)                 const { return _window[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
89 90

    /// Color for shaded areas within a window. The windowShade color is a color between window and button.
91
    QColor windowShade(void)            const { return _windowShade[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
92 93

    /// Color for darker shared areas within a window. The windowShadeDark color is a color between window and windowShade.
94
    QColor windowShadeDark(void)        const { return _windowShadeDark[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
95 96

    /// Text color
97
    QColor text(void)                   const { return _text[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
98 99

    /// Color for warning text
100
    QColor warningText(void)            const { return _warningText[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
101 102

    /// Background color for buttons
103
    QColor button(void)                 const { return _button[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
104 105

    /// Text color for buttons
106
    QColor buttonText(void)             const { return _buttonText[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
107 108

    /// Background color for button in selected or hover state
109
    QColor buttonHighlight(void)        const { return _buttonHighlight[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
110 111

    /// Text color for button in selected or hover state
112
    QColor buttonHighlightText(void)    const { return _buttonHighlightText[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
113 114 115

    /// Background color for primary buttons. A primary button is the button which would be the normal default  button to press.
    /// For example in an Ok/Cancel situation where Ok would normally be pressed, Ok is the primary button.
116
    QColor primaryButton(void)          const { return _primaryButton[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
117 118

    /// Text color for primary buttons
119
    QColor primaryButtonText(void)      const { return _primaryButtonText[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
120 121

    /// Background color for TextFields
122
    QColor textField(void)              const { return _textField[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
123 124

    /// Text color for TextFields
125
    QColor textFieldText(void)          const { return _textFieldText[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
126 127

    /// Background color for map buttons
128
    QColor mapButton(void)              const { return _mapButton[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
129 130

    /// Background color for map button in selected or hover state
131
    QColor mapButtonHighlight(void)     const { return _mapButtonHighlight[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
132 133

    /// Widget border color which will stand out against light map tiles
134
    QColor mapWidgetBorderLight(void)   const { return _mapWidgetBorderLight[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
135 136

    /// Widget border color which will stand out against dark map tiles
137
    QColor mapWidgetBorderDark(void)    const { return _mapWidgetBorderDark[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
138 139

    /// Purple color from branding guidelines
Don Gagne's avatar
Don Gagne committed
140
    QColor brandingPurple(void)         const { return _brandingPurple[_theme][_colorGroupEnabled ? 1 : 0]; }
Don Gagne's avatar
Don Gagne committed
141 142

    /// Blue color from branding guidelines
Don Gagne's avatar
Don Gagne committed
143
    QColor brandingBlue(void)           const { return _brandingBlue[_theme][_colorGroupEnabled ? 1 : 0]; }
144

145 146 147 148 149 150 151
    QColor colorGreen   () { return QColor("#05f068"); }
    QColor colorOrange  () { return QColor("#f0ab06"); }
    QColor colorRed     () { return QColor("#fc4638"); }
    QColor colorGrey    () { return QColor("#7f7f7f"); }
    QColor colorBlue    () { return QColor("#636efe"); }
    QColor colorWhite   () { return QColor("#ffffff"); }

152 153 154 155 156 157 158 159 160 161 162 163 164 165 166
    void setWindow(QColor& color)               { _window[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setWindowShade(QColor& color)          { _windowShade[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setWindowShadeDark(QColor& color)      { _windowShadeDark[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setText(QColor& color)                 { _text[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setWarningText(QColor& color)          { _warningText[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setButton(QColor& color)               { _button[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setButtonText(QColor& color)           { _buttonText[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setButtonHighlight(QColor& color)      { _buttonHighlight[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setButtonHighlightText(QColor& color)  { _buttonHighlightText[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setPrimaryButton(QColor& color)        { _primaryButton[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setPrimaryButtonText(QColor& color)    { _primaryButtonText[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setTextField(QColor& color)            { _textField[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setTextFieldText(QColor& color)        { _textFieldText[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setMapButton(QColor& color)            { _mapButton[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setMapButtonHighlight(QColor& color)   { _mapButtonHighlight[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
167 168
    void setMapWidgetBorderLight(QColor& color) { _mapWidgetBorderLight[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
    void setMapWidgetBorderDark(QColor& color)  { _mapWidgetBorderDark[_theme][_colorGroupEnabled ? 1 : 0] = color; _signalPaletteChangeToAll(); }
169

170 171
    static Theme globalTheme(void) { return _theme; }
    static void setGlobalTheme(Theme newTheme);
172

173 174 175 176
signals:
    void paletteChanged(void);
    
private:
177 178 179
    static void _signalPaletteChangeToAll(void);
    void _signalPaletteChanged(void);

180 181
    static Theme    _theme;             ///< There is a single theme for all palettes
    bool            _colorGroupEnabled; ///< Currently selected ColorGroup. true: enabled, false: disabled
182
    
183
    static const int _cThemes = 2;
184
    static const int _cColorGroups = 2;
185

186
    static QColor _window[_cThemes][_cColorGroups];
187 188
    static QColor _windowShade[_cThemes][_cColorGroups];
    static QColor _windowShadeDark[_cThemes][_cColorGroups];
189
    
190 191
	static QColor _warningText[_cThemes][_cColorGroups];
	static QColor _text[_cThemes][_cColorGroups];
192 193 194
    
    static QColor _button[_cThemes][_cColorGroups];
    static QColor _buttonText[_cThemes][_cColorGroups];
Don Gagne's avatar
Don Gagne committed
195
    static QColor _buttonHighlight[_cThemes][_cColorGroups];
196 197 198 199 200 201 202 203 204
    static QColor _buttonHighlightText[_cThemes][_cColorGroups];
    
    static QColor _primaryButton[_cThemes][_cColorGroups];
    static QColor _primaryButtonText[_cThemes][_cColorGroups];
    static QColor _primaryButtonHighlight[_cThemes][_cColorGroups];
    static QColor _primaryButtonHighlightText[_cThemes][_cColorGroups];
    
    static QColor _textField[_cThemes][_cColorGroups];
    static QColor _textFieldText[_cThemes][_cColorGroups];
205
    
206 207
    static QColor _mapButton[_cThemes][_cColorGroups];
    static QColor _mapButtonHighlight[_cThemes][_cColorGroups];
208 209 210
    static QColor _mapWidgetBorderLight[_cThemes][_cColorGroups];
    static QColor _mapWidgetBorderDark[_cThemes][_cColorGroups];

Don Gagne's avatar
Don Gagne committed
211 212 213
    static QColor _brandingPurple[_cThemes][_cColorGroups];
    static QColor _brandingBlue[_cThemes][_cColorGroups];

214 215 216
    void _themeChanged(void);
    
    static QList<QGCPalette*>   _paletteObjects;    ///< List of all active QGCPalette objects
217 218 219
};

#endif