93{
94
96
97
99 {
101 editedImage =
new QImage( tmp->convertDepth( 32, Qt::AutoColor ) );
102 delete tmp; tmp=NULL;
103 }
104
105
106 QString statusMessage = qApp->translate( "improveColorBalance", "Enhancing Color Balance:" );
108 qApp->processEvents();
109
110
113
114
115 int redVals[256];
116 int greenVals[256];
117 int blueVals[256];
118 int i=0;
119 for(i=0; i<256; i++)
120 {
121 redVals[i] = 0;
122 greenVals[i] = 0;
123 blueVals[i] = 0;
124 }
125
126
128 QRgb* rgb;
129 uchar* scanLine;
130 int x, y;
132 {
133
136 {
137 rgb = ((QRgb*)scanLine+x);
138 redVals[qRed(*rgb)]++;
139 greenVals[qGreen(*rgb)]++;
140 blueVals[qBlue(*rgb)]++;
141 }
142 }
143
144
145
146 int sumR=0;
147 int sumG=0;
148 int sumB=0;
149 int indexLowR, indexHighR;
150 int indexLowG, indexHighG;
151 int indexLowB, indexHighB;
152 indexLowR = -1; indexHighR = -1;
153 indexLowG = -1; indexHighG = -1;
154 indexLowB = -1; indexHighB = -1;
155 for(i=0; i<256; i++)
156 {
157 sumR+=redVals[i];
158 sumG+=greenVals[i];
159 sumB+=blueVals[i];
160
161
162 if(indexLowR < 0 && sumR >= 0.01*numPixels)
163 { indexLowR = i; }
164 if(indexLowG < 0 && sumG >= 0.01*numPixels)
165 { indexLowG = i; }
166 if(indexLowB < 0 && sumB >= 0.01*numPixels)
167 { indexLowB = i; }
168
169
170 if(indexHighR < 0 && sumR >= 0.99*numPixels)
171 { indexHighR = i; }
172 if(indexHighG < 0 && sumG >= 0.99*numPixels)
173 { indexHighG = i; }
174 if(indexHighB < 0 && sumB >= 0.99*numPixels)
175 { indexHighB = i; }
176 }
177
178
180 {
181
184 {
185
186 rgb = ((QRgb*)scanLine+x);
187 double r = ((double)qRed(*rgb) );
188 double g = ((double)qGreen(*rgb) );
189 double b = ((double)qBlue(*rgb) );
190
191 if(indexHighR != indexLowR) { r = (255*(r-indexLowR))/(indexHighR-indexLowR); }
192 if(indexHighG != indexLowG) { g = (255*(g-indexLowG))/(indexHighG-indexLowG); }
193 if(indexHighB != indexLowB) {
b = (255*(
b-indexLowB))/(indexHighB-indexLowB); }
194
195 int rp = (int)
MIN(
MAX(r, 0), 255 );
196 int gp = (int)
MIN(
MAX(g, 0), 255 );
197 int bp = (int)
MIN(
MAX(
b, 0), 255 );
198
199
200 *rgb = qRgb(rp,gp,bp);
201
202
205 {
208 qApp->processEvents();
209 }
210
211 }
212 }
213
214
216 qApp->processEvents();
217
218
220}