Mercurial > hg > svgui
comparison layer/ColourDatabase.cpp @ 944:78c152e4db95
Merge from branch tonioni
author | Chris Cannam |
---|---|
date | Mon, 20 Apr 2015 09:12:17 +0100 |
parents | e0f08e108064 |
children | a34a2a25907c |
comparison
equal
deleted
inserted
replaced
896:78e041e45ff0 | 944:78c152e4db95 |
---|---|
32 } | 32 } |
33 | 33 |
34 int | 34 int |
35 ColourDatabase::getColourCount() const | 35 ColourDatabase::getColourCount() const |
36 { | 36 { |
37 return m_colours.size(); | 37 return int(m_colours.size()); |
38 } | 38 } |
39 | 39 |
40 QString | 40 QString |
41 ColourDatabase::getColourName(int c) const | 41 ColourDatabase::getColourName(int c) const |
42 { | 42 { |
43 if (c < 0 || size_t(c) >= m_colours.size()) return ""; | 43 if (!in_range_for(m_colours, c)) return ""; |
44 return m_colours[c].name; | 44 return m_colours[c].name; |
45 } | 45 } |
46 | 46 |
47 QColor | 47 QColor |
48 ColourDatabase::getColour(int c) const | 48 ColourDatabase::getColour(int c) const |
49 { | 49 { |
50 if (c < 0 || size_t(c) >= m_colours.size()) return Qt::black; | 50 if (!in_range_for(m_colours, c)) return Qt::black; |
51 return m_colours[c].colour; | 51 return m_colours[c].colour; |
52 } | 52 } |
53 | 53 |
54 QColor | 54 QColor |
55 ColourDatabase::getColour(QString name) const | 55 ColourDatabase::getColour(QString name) const |
56 { | 56 { |
57 for (ColourList::const_iterator i = m_colours.begin(); | 57 for (auto &c: m_colours) { |
58 i != m_colours.end(); ++i) { | 58 if (c.name == name) return c.colour; |
59 if (i->name == name) return i->colour; | |
60 } | 59 } |
61 | 60 |
62 return Qt::black; | 61 return Qt::black; |
63 } | 62 } |
64 | 63 |
65 int | 64 int |
66 ColourDatabase::getColourIndex(QString name) const | 65 ColourDatabase::getColourIndex(QString name) const |
67 { | 66 { |
68 int index = 0; | 67 int index = 0; |
69 for (ColourList::const_iterator i = m_colours.begin(); | 68 for (auto &c: m_colours) { |
70 i != m_colours.end(); ++i) { | 69 if (c.name == name) return index; |
71 if (i->name == name) return index; | |
72 ++index; | 70 ++index; |
73 } | 71 } |
74 | 72 |
75 return -1; | 73 return -1; |
76 } | 74 } |
77 | 75 |
78 int | 76 int |
79 ColourDatabase::getColourIndex(QColor c) const | 77 ColourDatabase::getColourIndex(QColor col) const |
80 { | 78 { |
81 int index = 0; | 79 int index = 0; |
82 for (ColourList::const_iterator i = m_colours.begin(); | 80 for (auto &c: m_colours) { |
83 i != m_colours.end(); ++i) { | 81 if (c.colour == col) return index; |
84 if (i->colour == c) return index; | |
85 ++index; | 82 ++index; |
86 } | 83 } |
87 | 84 |
88 return -1; | 85 return -1; |
89 } | 86 } |
90 | 87 |
91 bool | 88 bool |
92 ColourDatabase::useDarkBackground(int c) const | 89 ColourDatabase::useDarkBackground(int c) const |
93 { | 90 { |
94 if (c < 0 || size_t(c) >= m_colours.size()) return false; | 91 if (!in_range_for(m_colours, c)) return false; |
95 return m_colours[c].darkbg; | 92 return m_colours[c].darkbg; |
96 } | 93 } |
97 | 94 |
98 void | 95 void |
99 ColourDatabase::setUseDarkBackground(int c, bool dark) | 96 ColourDatabase::setUseDarkBackground(int c, bool dark) |
100 { | 97 { |
101 if (c < 0 || size_t(c) >= m_colours.size()) return; | 98 if (!in_range_for(m_colours, c)) return; |
102 if (m_colours[c].darkbg != dark) { | 99 if (m_colours[c].darkbg != dark) { |
103 m_colours[c].darkbg = dark; | 100 m_colours[c].darkbg = dark; |
104 emit colourDatabaseChanged(); | 101 emit colourDatabaseChanged(); |
105 } | 102 } |
106 } | 103 } |
107 | 104 |
108 int | 105 int |
109 ColourDatabase::addColour(QColor c, QString name) | 106 ColourDatabase::addColour(QColor c, QString name) |
110 { | 107 { |
111 int index = 0; | 108 int index = 0; |
109 | |
112 for (ColourList::iterator i = m_colours.begin(); | 110 for (ColourList::iterator i = m_colours.begin(); |
113 i != m_colours.end(); ++i) { | 111 i != m_colours.end(); ++i) { |
114 if (i->name == name) { | 112 if (i->name == name) { |
115 i->colour = c; | 113 i->colour = c; |
116 return index; | 114 return index; |
145 QString &colourSpec, | 143 QString &colourSpec, |
146 QString &darkbg) const | 144 QString &darkbg) const |
147 { | 145 { |
148 colourName = ""; | 146 colourName = ""; |
149 colourSpec = ""; | 147 colourSpec = ""; |
150 if (index < 0 || size_t(index) >= m_colours.size()) return; | 148 if (!in_range_for(m_colours, index)) return; |
151 | 149 |
152 colourName = getColourName(index); | 150 colourName = getColourName(index); |
153 QColor c = getColour(index); | 151 QColor c = getColour(index); |
154 colourSpec = XmlExportable::encodeColour(c.red(), c.green(), c.blue()); | 152 colourSpec = XmlExportable::encodeColour(c.red(), c.green(), c.blue()); |
155 darkbg = useDarkBackground(index) ? "true" : "false"; | 153 darkbg = useDarkBackground(index) ? "true" : "false"; |