annotate layer/ColourDatabase.h @ 1548:bd6af89982d7

Permit getScaleProvidingLayerForUnit to return a dormant layer if there is no visible alternative. This is necessary to avoid the scale disappearing in Tony when the spectrogram is toggled off.
author Chris Cannam
date Thu, 17 Oct 2019 14:44:22 +0100
parents ad86aa712d11
children 57a4ee52ad69
rev   line source
Chris@376 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@376 2
Chris@376 3 /*
Chris@376 4 Sonic Visualiser
Chris@376 5 An audio file viewer and annotation editor.
Chris@376 6 Centre for Digital Music, Queen Mary, University of London.
Chris@376 7 This file copyright 2007 QMUL.
Chris@376 8
Chris@376 9 This program is free software; you can redistribute it and/or
Chris@376 10 modify it under the terms of the GNU General Public License as
Chris@376 11 published by the Free Software Foundation; either version 2 of the
Chris@376 12 License, or (at your option) any later version. See the file
Chris@376 13 COPYING included with this distribution for more information.
Chris@376 14 */
Chris@376 15
Chris@1407 16 #ifndef SV_COLOUR_DATABASE_H
Chris@1407 17 #define SV_COLOUR_DATABASE_H
Chris@376 18
Chris@376 19 #include <QObject>
Chris@376 20 #include <QString>
Chris@376 21 #include <QColor>
Chris@376 22 #include <QSize>
Chris@376 23 #include <QPixmap>
Chris@376 24 #include <vector>
Chris@376 25
Chris@376 26 class ColourDatabase : public QObject
Chris@376 27 {
Chris@376 28 Q_OBJECT
Chris@376 29
Chris@376 30 public:
Chris@376 31 static ColourDatabase *getInstance();
Chris@376 32
Chris@1445 33 /**
Chris@1445 34 * Return the number of colours in the database.
Chris@1445 35 */
Chris@376 36 int getColourCount() const;
Chris@1445 37
Chris@1445 38 /**
Chris@1445 39 * Return the name of the colour at index c.
Chris@1445 40 */
Chris@376 41 QString getColourName(int c) const;
Chris@1445 42
Chris@1445 43 /**
Chris@1445 44 * Return the colour at index c.
Chris@1445 45 */
Chris@376 46 QColor getColour(int c) const;
Chris@1445 47
Chris@1445 48 /**
Chris@1445 49 * Return the colour with the given name, if found in the
Chris@1445 50 * database. If not found, return Qt::black.
Chris@1445 51 */
Chris@376 52 QColor getColour(QString name) const;
Chris@1445 53
Chris@1445 54 /**
Chris@1445 55 * Return the index of the colour with the given name, if found in
Chris@1445 56 * the database. If not found, return -1.
Chris@1445 57 */
Chris@1445 58 int getColourIndex(QString name) const;
Chris@1445 59
Chris@1445 60 /**
Chris@1445 61 * Return the index of the given colour, if found in the
Chris@1445 62 * database. If not found, return -1. Note that it is possible for
Chris@1445 63 * a colour to appear more than once in the database: names have
Chris@1445 64 * to be unique in the database, but colours don't. This always
Chris@1445 65 * returns the first match.
Chris@1445 66 */
Chris@1445 67 int getColourIndex(QColor c) const;
Chris@1445 68
Chris@1445 69 /**
Chris@1445 70 * Return true if the given colour exists in the database.
Chris@1445 71 */
Chris@376 72 bool haveColour(QColor c) const;
Chris@376 73
Chris@1445 74 /**
Chris@1445 75 * Return the index of the colour in the database that is closest
Chris@1445 76 * to the given one, by some simplistic measure (Manhattan
Chris@1445 77 * distance in RGB space). This always returns some valid index,
Chris@1445 78 * unless the database is empty, in which case it returns -1.
Chris@1445 79 */
Chris@1445 80 int getNearbyColourIndex(QColor c) const;
Chris@1445 81
Chris@1445 82 /**
Chris@1445 83 * Add a colour to the database, with the associated name. Return
Chris@1445 84 * the index of the colour in the database. Names are unique
Chris@1445 85 * within the database: if another colour exists already with the
Chris@1445 86 * given name, its colour value is replaced with the given
Chris@1445 87 * one. Colours may appear more than once under different names.
Chris@1445 88 */
Chris@1445 89 int addColour(QColor c, QString name);
Chris@1445 90
Chris@1445 91 /**
Chris@1445 92 * Remove the colour with the given name from the database.
Chris@1445 93 */
Chris@1445 94 void removeColour(QString);
Chris@1445 95
Chris@1445 96 /**
Chris@1445 97 * Return true if the colour at index c is marked as using a dark
Chris@1445 98 * background. Such colours are presumably "bright" ones, but all
Chris@1445 99 * this reports is whether the colour has been marked with
Chris@1445 100 * setUseDarkBackground, not any intrinsic property of the colour.
Chris@1445 101 */
Chris@376 102 bool useDarkBackground(int c) const;
Chris@1445 103
Chris@1445 104 /**
Chris@1445 105 * Mark the colour at index c as using a dark
Chris@1445 106 * background. Generally this should be called for "bright"
Chris@1445 107 * colours.
Chris@1445 108 */
Chris@376 109 void setUseDarkBackground(int c, bool dark);
Chris@376 110
Chris@1445 111 /**
Chris@1445 112 * Return a colour that contrasts with the one at index c,
Chris@1445 113 * according to some simplistic algorithm. The returned colour is
Chris@1445 114 * not necessarily in the database; pass it to
Chris@1445 115 * getNearbyColourIndex if you need one that is.
Chris@1445 116 */
Chris@376 117 QColor getContrastingColour(int c) const;
Chris@376 118
Chris@376 119 // for use in XML export
Chris@376 120 void getStringValues(int index,
Chris@376 121 QString &colourName,
Chris@376 122 QString &colourSpec,
Chris@376 123 QString &darkbg) const;
Chris@376 124
Chris@376 125 // for use in XML import
Chris@376 126 int putStringValues(QString colourName,
Chris@376 127 QString colourSpec,
Chris@376 128 QString darkbg);
Chris@376 129
Chris@376 130 // for use by PropertyContainer getPropertyRangeAndValue methods
Chris@376 131 void getColourPropertyRange(int *min, int *max) const;
Chris@376 132
Chris@1445 133 /**
Chris@1445 134 * Generate a swatch pixmap illustrating the colour at index c.
Chris@1445 135 */
Chris@1445 136 QPixmap getExamplePixmap(int c, QSize size) const;
Chris@376 137
Chris@376 138 signals:
Chris@376 139 void colourDatabaseChanged();
Chris@376 140
Chris@376 141 protected:
Chris@376 142 ColourDatabase();
Chris@376 143
Chris@376 144 struct ColourRec {
Chris@376 145 QColor colour;
Chris@376 146 QString name;
Chris@376 147 bool darkbg;
Chris@376 148 };
Chris@376 149
Chris@376 150 typedef std::vector<ColourRec> ColourList;
Chris@376 151 ColourList m_colours;
Chris@376 152
Chris@376 153 static ColourDatabase m_instance;
Chris@376 154 };
Chris@376 155
Chris@376 156 #endif