QGIS API Documentation 3.99.0-Master (26c88405ac0)
Loading...
Searching...
No Matches
qgscolorrampimpl.h
Go to the documentation of this file.
1/***************************************************************************
2 qgscolorrampimpl.h
3 ---------------------
4 begin : November 2009
5 copyright : (C) 2009 by Martin Dobias
6 email : wonder dot sk at gmail dot com
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
15
16#ifndef QGSCOLORRAMPIMPL_H
17#define QGSCOLORRAMPIMPL_H
18
19#include "qgis.h"
20#include "qgis_core.h"
21#include "qgscolorramp.h"
22#include "qgscolorscheme.h"
23
24#include <QColor>
25#include <QGradient>
26
27#ifndef SIP_RUN
29typedef QColor( *InterpolateColorFunc )( const QColor &c1, const QColor &c2, const double value, Qgis::AngularDirection direction );
31#endif
32
38class CORE_EXPORT QgsGradientStop
39{
40 public:
41
47 QgsGradientStop( double offset, const QColor &color );
48
50 double offset;
52 QColor color;
53
54 bool operator==( const QgsGradientStop &other ) const
55 {
56 return other.color == color && qgsDoubleNear( other.offset, offset ) && other.mColorSpec == mColorSpec && other.mDirection == mDirection;
57 }
58
59 bool operator!=( const QgsGradientStop &other ) const
60 {
61 return !( *this == other );
62 }
63
73 QColor::Spec colorSpec() const { return mColorSpec; }
74
86 void setColorSpec( QColor::Spec spec );
87
98 Qgis::AngularDirection direction() const { return mDirection; }
99
111
112 private:
113
114 QColor::Spec mColorSpec = QColor::Spec::Rgb;
116 InterpolateColorFunc mFunc = nullptr;
117
119};
120
122typedef QList<QgsGradientStop> QgsGradientStopsList;
123
124// these are the QGIS branding colors, exaggerated a bit to make a default ramp with greater color variation
125// then the official QGIS color gradient!
126#define DEFAULT_GRADIENT_COLOR1 QColor(69, 116, 40)
127#define DEFAULT_GRADIENT_COLOR2 QColor(188, 220, 60)
128
135class CORE_EXPORT QgsGradientColorRamp : public QgsColorRamp
136{
137 public:
138
148 const QColor &color2 = DEFAULT_GRADIENT_COLOR2,
149 bool discrete = false,
151
153 static QgsColorRamp *create( const QVariantMap &properties = QVariantMap() ) SIP_FACTORY;
154
155 int count() const override { return mStops.count() + 2; }
156 double value( int index ) const override;
157 QColor color( double value ) const override;
158
164 static QString typeString() { return QStringLiteral( "gradient" ); }
165
166 QString type() const override;
167 void invert() override;
168 QgsGradientColorRamp *clone() const override SIP_FACTORY;
169 QVariantMap properties() const override;
170
176 QColor color1() const { return mColor1; }
177
183 QColor color2() const { return mColor2; }
184
191 void setColor1( const QColor &color ) { mColor1 = color; }
192
199 void setColor2( const QColor &color ) { mColor2 = color; }
200
206 bool isDiscrete() const { return mDiscrete; }
207
215 void setDiscrete( bool discrete ) { mDiscrete = discrete; }
216
224 void convertToDiscrete( bool discrete );
225
233 void setStops( const QgsGradientStopsList &stops );
234
240
245 QgsStringMap info() const { return mInfo; }
246
252 void setInfo( const QgsStringMap &info ) { mInfo = info; }
253
260 void addStopsToGradient( QGradient *gradient, double opacity = 1 ) const;
261
271 QColor::Spec colorSpec() const { return mColorSpec; }
272
284 void setColorSpec( QColor::Spec spec );
285
297
309
310 protected:
311 QColor mColor1;
312 QColor mColor2;
316 QColor::Spec mColorSpec = QColor::Spec::Rgb;
318
319 InterpolateColorFunc mFunc = nullptr;
320};
321
323
324#define DEFAULT_RANDOM_COUNT 10
325#define DEFAULT_RANDOM_HUE_MIN 0
326#define DEFAULT_RANDOM_HUE_MAX 359
327#define DEFAULT_RANDOM_VAL_MIN 200
328#define DEFAULT_RANDOM_VAL_MAX 240
329#define DEFAULT_RANDOM_SAT_MIN 100
330#define DEFAULT_RANDOM_SAT_MAX 240
331
337class CORE_EXPORT QgsLimitedRandomColorRamp : public QgsColorRamp
338{
339 public:
340
355
362 static QgsColorRamp *create( const QVariantMap &properties = QVariantMap() ) SIP_FACTORY;
363
364 double value( int index ) const override;
365 QColor color( double value ) const override;
366
372 static QString typeString() { return QStringLiteral( "random" ); }
373
374 QString type() const override;
375 QgsLimitedRandomColorRamp *clone() const override SIP_FACTORY;
376 QVariantMap properties() const override;
377 int count() const override { return mCount; }
378
382 static QList<QColor> randomColors( int count,
383 int hueMax = DEFAULT_RANDOM_HUE_MAX, int hueMin = DEFAULT_RANDOM_HUE_MIN,
384 int satMax = DEFAULT_RANDOM_SAT_MAX, int satMin = DEFAULT_RANDOM_SAT_MIN,
385 int valMax = DEFAULT_RANDOM_VAL_MAX, int valMin = DEFAULT_RANDOM_VAL_MIN );
386
391 void updateColors();
392
397 int hueMin() const { return mHueMin; }
398
403 int hueMax() const { return mHueMax; }
404
409 int satMin() const { return mSatMin; }
410
415 int satMax() const { return mSatMax; }
416
421 int valMin() const { return mValMin; }
422
427 int valMax() const { return mValMax; }
428
432 void setCount( int val ) { mCount = val; }
433
438 void setHueMin( int val ) { mHueMin = val; }
439
444 void setHueMax( int val ) { mHueMax = val; }
445
450 void setSatMin( int val ) { mSatMin = val; }
451
456 void setSatMax( int val ) { mSatMax = val; }
457
462 void setValMin( int val ) { mValMin = val; }
463
468 void setValMax( int val ) { mValMax = val; }
469
470 protected:
478 QList<QColor> mColors;
479};
480
489class CORE_EXPORT QgsRandomColorRamp: public QgsColorRamp
490{
491 public:
492
494
495 int count() const override;
496
497 double value( int index ) const override;
498
499 QColor color( double value ) const override;
500
507 virtual void setTotalColorCount( int colorCount );
508
514 static QString typeString() { return QStringLiteral( "randomcolors" ); }
515
516 QString type() const override;
517
518 QgsRandomColorRamp *clone() const override SIP_FACTORY;
519
520 QVariantMap properties() const override;
521
522 protected:
523
525 QList<QColor> mPrecalculatedColors;
526
527};
528
529
535class CORE_EXPORT QgsPresetSchemeColorRamp : public QgsColorRamp, public QgsColorScheme
536{
537 public:
538
543 QgsPresetSchemeColorRamp( const QList< QColor > &colors = QList< QColor >() );
544
550
557 static QgsColorRamp *create( const QVariantMap &properties = QVariantMap() ) SIP_FACTORY;
558
564 bool setColors( const QgsNamedColorList &colors, const QString & = QString(), const QColor & = QColor() ) override { mColors = colors; return true; }
565
570 QList< QColor > colors() const;
571
572 double value( int index ) const override;
573 QColor color( double value ) const override;
574
580 static QString typeString() { return QStringLiteral( "preset" ); }
581
582 QString type() const override;
583 void invert() override;
584 QgsPresetSchemeColorRamp *clone() const override SIP_FACTORY;
585 QVariantMap properties() const override;
586 int count() const override;
587
588 QString schemeName() const override { return QStringLiteral( "preset" ); }
589 QgsNamedColorList fetchColors( const QString &context = QString(), const QColor &baseColor = QColor() ) override;
590 bool isEditable() const override { return true; }
591
592 private:
593
594 QgsNamedColorList mColors;
595};
596
597
598#define DEFAULT_COLORBREWER_SCHEMENAME "Spectral"
599#define DEFAULT_COLORBREWER_COLORS 5
600
606class CORE_EXPORT QgsColorBrewerColorRamp : public QgsColorRamp
607{
608 public:
609
618 bool inverted = false );
619
626 static QgsColorRamp *create( const QVariantMap &properties = QVariantMap() ) SIP_FACTORY;
627
628 double value( int index ) const override;
629 QColor color( double value ) const override;
630
636 static QString typeString() { return QStringLiteral( "colorbrewer" ); }
637
638 QString type() const override { return QgsColorBrewerColorRamp::typeString(); }
639 void invert() override;
640 QgsColorBrewerColorRamp *clone() const override SIP_FACTORY;
641 QVariantMap properties() const override;
642 int count() const override { return mColors; }
643
648 QString schemeName() const { return mSchemeName; }
649
654 int colors() const { return mColors; }
655
663
671
676 static QStringList listSchemeNames();
677
684 static QList<int> listSchemeVariants( const QString &schemeName );
685
686 protected:
687
689 void loadPalette();
690
691 QString mSchemeName;
693 QList<QColor> mPalette;
695};
696
697
698#define DEFAULT_CPTCITY_SCHEMENAME "cb/div/BrBG_" //change this
699#define DEFAULT_CPTCITY_VARIANTNAME "05"
700
708{
709 public:
710
720 bool inverted = false,
721 bool doLoadFile = true );
722
731 QgsCptCityColorRamp( const QString &schemeName, const QStringList &variantList,
732 const QString &variantName = QString(), bool inverted = false,
733 bool doLoadFile = true );
734
736 static QgsColorRamp *create( const QVariantMap &properties = QVariantMap() ) SIP_FACTORY; // cppcheck-suppress duplInheritedMember
737
743 static QString typeString() { return QStringLiteral( "cpt-city" ); } // cppcheck-suppress duplInheritedMember
744
745 QString type() const override;
746
747 void invert() override;
748
749 QgsCptCityColorRamp *clone() const override SIP_FACTORY;
750 void copy( const QgsCptCityColorRamp *other );
751 QgsGradientColorRamp *cloneGradientRamp() const SIP_FACTORY;
752
753 QVariantMap properties() const override;
754
755 QString schemeName() const { return mSchemeName; }
756 QString variantName() const { return mVariantName; }
757 QStringList variantList() const { return mVariantList; }
758
759 // lazy loading - have to call loadPalette() explicitly
760 void setSchemeName( const QString &schemeName ) { mSchemeName = schemeName; mFileLoaded = false; }
761 void setVariantName( const QString &variantName ) { mVariantName = variantName; mFileLoaded = false; }
762 void setVariantList( const QStringList &variantList ) { mVariantList = variantList; }
763 void setName( const QString &schemeName, const QString &variantName = QString(), const QStringList &variantList = QStringList() )
765
766 void loadPalette() { loadFile(); }
767 bool hasMultiStops() const { return mMultiStops; }
768
775 static QString fileNameForVariant( const QString &schema, const QString &variant ) SIP_SKIP;
776
777 QString fileName() const;
778 bool loadFile();
779 bool fileLoaded() const { return mFileLoaded; }
780
781 QString copyingFileName() const;
782 QString descFileName() const;
783 QgsStringMap copyingInfo() const;
784
785 protected:
786 QString mSchemeName;
788 QStringList mVariantList;
789 bool mFileLoaded = false;
790 bool mMultiStops = false;
792
793};
794
795// clazy:excludeall=qstring-allocations
796
797#endif
AngularDirection
Angular directions.
Definition qgis.h:3432
@ CounterClockwise
Counter-clockwise direction.
Definition qgis.h:3434
Color ramp utilising "Color Brewer" preset color schemes.
QColor color(double value) const override
Returns the color corresponding to a specified value.
int count() const override
Returns number of defined colors, or -1 if undefined.
static QString typeString()
Returns the string identifier for QgsColorBrewerColorRamp.
static QgsColorRamp * create(const QVariantMap &properties=QVariantMap())
Returns a new QgsColorBrewerColorRamp color ramp created using the properties encoded in a string map...
QString type() const override
Returns a string representing the color ramp type.
double value(int index) const override
Returns relative value between [0,1] of color at specified index.
QString schemeName() const
Returns the name of the color brewer color scheme.
int colors() const
Returns the number of colors in the ramp.
QVariantMap properties() const override
Returns a string map containing all the color ramp's properties.
QgsColorBrewerColorRamp(const QString &schemeName=DEFAULT_COLORBREWER_SCHEMENAME, int colors=DEFAULT_COLORBREWER_COLORS, bool inverted=false)
Constructor for QgsColorBrewerColorRamp.
void setSchemeName(const QString &schemeName)
Sets the name of the color brewer color scheme.
void setColors(int colors)
Sets the number of colors in the ramp.
void loadPalette()
Generates the scheme using the current name and number of colors.
Abstract base class for color ramps.
QgsColorScheme()=default
A color ramp from the CPT City collection.
void setName(const QString &schemeName, const QString &variantName=QString(), const QStringList &variantList=QStringList())
void setSchemeName(const QString &schemeName)
void setVariantList(const QStringList &variantList)
QVariantMap properties() const override
Returns a string map containing all the color ramp's properties.
QgsCptCityColorRamp(const QString &schemeName=DEFAULT_CPTCITY_SCHEMENAME, const QString &variantName=DEFAULT_CPTCITY_VARIANTNAME, bool inverted=false, bool doLoadFile=true)
Constructor for QgsCptCityColorRamp.
static QgsColorRamp * create(const QVariantMap &properties=QVariantMap())
Creates the symbol layer.
QStringList variantList() const
void setVariantName(const QString &variantName)
static QString typeString()
Returns the string identifier for QgsCptCityColorRamp.
QString schemeName() const
QString variantName() const
Gradient color ramp, which smoothly interpolates between two colors and also supports optional extra ...
QgsGradientStopsList mStops
void setColor1(const QColor &color)
Sets the gradient start color.
void setColor2(const QColor &color)
Sets the gradient end color.
void setInfo(const QgsStringMap &info)
Sets additional info to attach to the gradient ramp (e.g., authorship notes).
bool isDiscrete() const
Returns true if the gradient is using discrete interpolation, rather than smoothly interpolating betw...
int count() const override
Returns number of defined colors, or -1 if undefined.
QVariantMap properties() const override
Returns a string map containing all the color ramp's properties.
static QgsColorRamp * create(const QVariantMap &properties=QVariantMap())
Creates a new QgsColorRamp from a map of properties.
QgsStringMap info() const
Returns any additional info attached to the gradient ramp (e.g., authorship notes).
Qgis::AngularDirection mDirection
QColor::Spec colorSpec() const
Returns the color specification in which the color component interpolation will occur.
QColor color(double value) const override
Returns the color corresponding to a specified value.
static QString typeString()
Returns the string identifier for QgsGradientColorRamp.
QgsGradientColorRamp(const QColor &color1=DEFAULT_GRADIENT_COLOR1, const QColor &color2=DEFAULT_GRADIENT_COLOR2, bool discrete=false, const QgsGradientStopsList &stops=QgsGradientStopsList())
Constructor for QgsGradientColorRamp.
QColor color1() const
Returns the gradient start color.
void setDirection(Qgis::AngularDirection direction)
Sets the direction to traverse the color wheel using when interpolating hue-based color specification...
Qgis::AngularDirection direction() const
Returns the direction to traverse the color wheel using when interpolating hue-based color specificat...
QgsGradientStopsList stops() const
Returns the list of intermediate gradient stops for the ramp.
void setDiscrete(bool discrete)
Sets whether the gradient should use discrete interpolation, rather than smoothly interpolating betwe...
InterpolateColorFunc mFunc
QColor color2() const
Returns the gradient end color.
Qgis::AngularDirection direction() const
Returns the direction to traverse the color wheel using when interpolating hue-based color specificat...
bool operator==(const QgsGradientStop &other) const
QColor::Spec colorSpec() const
Returns the color specification in which the color component interpolation will occur.
double offset
Relative positional offset, between 0 and 1.
bool operator!=(const QgsGradientStop &other) const
void setDirection(Qgis::AngularDirection direction)
Sets the direction to traverse the color wheel using when interpolating hue-based color specification...
friend class QgsGradientColorRamp
QColor color
Gradient color at stop.
QgsGradientStop(double offset, const QColor &color)
Constructor for QgsGradientStop.
Constrained random color ramp, which returns random colors based on preset parameters.
static QString typeString()
Returns the string identifier for QgsLimitedRandomColorRamp.
void setSatMin(int val)
Sets the minimum saturation for generated colors.
int count() const override
Returns number of defined colors, or -1 if undefined.
void setHueMin(int val)
Sets the minimum hue for generated colors.
void setSatMax(int val)
Sets the maximum saturation for generated colors.
QColor color(double value) const override
Returns the color corresponding to a specified value.
double value(int index) const override
Returns relative value between [0,1] of color at specified index.
QVariantMap properties() const override
Returns a string map containing all the color ramp's properties.
int valMax() const
Returns the maximum value for generated colors.
int satMax() const
Returns the maximum saturation for generated colors.
static QgsColorRamp * create(const QVariantMap &properties=QVariantMap())
Returns a new QgsLimitedRandomColorRamp color ramp created using the properties encoded in a string m...
void setHueMax(int val)
Sets the maximum hue for generated colors.
void setCount(int val)
Sets the number of colors contained in the ramp.
int hueMax() const
Returns the maximum hue for generated colors.
int hueMin() const
Returns the minimum hue for generated colors.
void setValMax(int val)
Sets the maximum value for generated colors.
int valMin() const
Returns the minimum value for generated colors.
QgsLimitedRandomColorRamp(int count=DEFAULT_RANDOM_COUNT, int hueMin=DEFAULT_RANDOM_HUE_MIN, int hueMax=DEFAULT_RANDOM_HUE_MAX, int satMin=DEFAULT_RANDOM_SAT_MIN, int satMax=DEFAULT_RANDOM_SAT_MAX, int valMin=DEFAULT_RANDOM_VAL_MIN, int valMax=DEFAULT_RANDOM_VAL_MAX)
Constructor for QgsLimitedRandomColorRamp.
void setValMin(int val)
Sets the minimum value for generated colors.
int satMin() const
Returns the minimum saturation for generated colors.
A scheme based color ramp consisting of a list of predefined colors.
bool setColors(const QgsNamedColorList &colors, const QString &=QString(), const QColor &=QColor()) override
Sets the list of colors used by the ramp.
QList< QColor > colors() const
Returns the list of colors used by the ramp.
QString schemeName() const override
Gets the name for the color scheme.
static QString typeString()
Returns the string identifier for QgsPresetSchemeColorRamp.
QVariantMap properties() const override
Returns a string map containing all the color ramp's properties.
static QgsColorRamp * create(const QVariantMap &properties=QVariantMap())
Returns a new QgsPresetSchemeColorRamp color ramp created using the properties encoded in a string ma...
QgsPresetSchemeColorRamp(const QList< QColor > &colors=QList< QColor >())
Constructor for QgsPresetSchemeColorRamp.
bool isEditable() const override
Returns whether the color scheme is editable.
A color ramp consisting of random colors, constrained within component ranges.
double value(int index) const override
Returns relative value between [0,1] of color at specified index.
QList< QColor > mPrecalculatedColors
QgsRandomColorRamp()=default
static QString typeString()
Returns the string identifier for QgsRandomColorRamp.
int count() const override
Returns number of defined colors, or -1 if undefined.
virtual void setTotalColorCount(int colorCount)
Sets the desired total number of unique colors for the resultant ramp.
QColor color(double value) const override
Returns the color corresponding to a specified value.
QList< QPair< QColor, QString > > QgsNamedColorList
List of colors paired with a friendly display name identifying the color.
bool qgsDoubleNear(double a, double b, double epsilon=4 *std::numeric_limits< double >::epsilon())
Compare two doubles (but allow some difference).
Definition qgis.h:6607
QMap< QString, QString > QgsStringMap
Definition qgis.h:7132
#define SIP_SKIP
Definition qgis_sip.h:134
#define SIP_FACTORY
Definition qgis_sip.h:84
#define DEFAULT_COLORBREWER_COLORS
#define DEFAULT_COLORBREWER_SCHEMENAME
#define DEFAULT_RANDOM_HUE_MAX
#define DEFAULT_CPTCITY_SCHEMENAME
#define DEFAULT_RANDOM_HUE_MIN
#define DEFAULT_RANDOM_COUNT
#define DEFAULT_RANDOM_SAT_MAX
#define DEFAULT_RANDOM_SAT_MIN
#define DEFAULT_CPTCITY_VARIANTNAME
#define DEFAULT_GRADIENT_COLOR1
#define DEFAULT_RANDOM_VAL_MIN
QList< QgsGradientStop > QgsGradientStopsList
List of gradient stops.
#define DEFAULT_GRADIENT_COLOR2
#define DEFAULT_RANDOM_VAL_MAX
Q_DECLARE_METATYPE(QgsDatabaseQueryLogEntry)