comparison layer/ColourDatabase.cpp @ 1459:42c87368287c

Merge from branch single-point
author Chris Cannam
date Fri, 17 May 2019 10:02:52 +0100
parents ad86aa712d11
children 57a4ee52ad69
comparison
equal deleted inserted replaced
1441:8d5bf4ab98ef 1459:42c87368287c
16 #include "ColourDatabase.h" 16 #include "ColourDatabase.h"
17 #include "base/XmlExportable.h" 17 #include "base/XmlExportable.h"
18 18
19 #include <QPainter> 19 #include <QPainter>
20 20
21 //#define DEBUG_COLOUR_DATABASE 1
22
21 ColourDatabase 23 ColourDatabase
22 ColourDatabase::m_instance; 24 ColourDatabase::m_instance;
23 25
24 ColourDatabase * 26 ColourDatabase *
25 ColourDatabase::getInstance() 27 ColourDatabase::getInstance()
83 } 85 }
84 86
85 return -1; 87 return -1;
86 } 88 }
87 89
90 int
91 ColourDatabase::getNearbyColourIndex(QColor col) const
92 {
93 int index = 0;
94 int closestIndex = -1;
95 int closestDistance = 0;
96
97 for (auto &c: m_colours) {
98 int distance =
99 std::abs(col.red() - c.colour.red()) +
100 std::abs(col.green() - c.colour.green()) +
101 std::abs(col.blue() - c.colour.blue());
102 #ifdef DEBUG_COLOUR_DATABASE
103 SVDEBUG << "getNearbyColourIndex: comparing " << c.colour.name()
104 << " to " << col.name() << ": distance = " << distance << endl;
105 #endif
106 if (closestIndex < 0 || distance < closestDistance) {
107 closestIndex = index;
108 closestDistance = distance;
109 #ifdef DEBUG_COLOUR_DATABASE
110 SVDEBUG << "(this is the best so far)" << endl;
111 #endif
112 }
113 ++index;
114 }
115
116 #ifdef DEBUG_COLOUR_DATABASE
117 SVDEBUG << "returning " << closestIndex << endl;
118 #endif
119 return closestIndex;
120 }
121
88 QColor 122 QColor
89 ColourDatabase::getContrastingColour(int c) const 123 ColourDatabase::getContrastingColour(int c) const
90 { 124 {
91 QColor col = getColour(c); 125 QColor col = getColour(c);
92 if (col.red() > col.blue()) { 126 QColor contrasting = Qt::red;
93 if (col.green() > col.blue()) { 127 bool dark = (col.red() < 240 && col.green() < 240 && col.blue() < 240);
94 return Qt::blue; 128 if (dark) {
129 if (col.red() > col.blue()) {
130 if (col.green() > col.blue()) {
131 contrasting = Qt::blue;
132 } else {
133 contrasting = Qt::yellow;
134 }
95 } else { 135 } else {
96 return Qt::yellow; 136 if (col.green() > col.blue()) {
137 contrasting = Qt::yellow;
138 } else {
139 contrasting = Qt::red;
140 }
97 } 141 }
98 } else { 142 } else {
99 if (col.green() > col.blue()) { 143 if (col.red() > 230 && col.green() > 230 && col.blue() > 230) {
100 return Qt::yellow; 144 contrasting = QColor(30, 150, 255);
101 } else { 145 } else {
102 return Qt::red; 146 contrasting = QColor(255, 188, 80);
103 } 147 }
104 } 148 }
105 return Qt::red; 149 #ifdef DEBUG_COLOUR_DATABASE
150 SVDEBUG << "getContrastingColour(" << col.name() << "): dark = " << dark
151 << ", returning " << contrasting.name() << endl;
152 #endif
153 return contrasting;
106 } 154 }
107 155
108 bool 156 bool
109 ColourDatabase::useDarkBackground(int c) const 157 ColourDatabase::useDarkBackground(int c) const
110 { 158 {