summaryrefslogtreecommitdiff
path: root/libopie2
authoralwin <alwin>2005-03-24 21:13:40 (UTC)
committer alwin <alwin>2005-03-24 21:13:40 (UTC)
commitb6fc9840f4fe9bad392167c49dbcfa2acda9ed21 (patch) (unidiff)
tree1d7d1225a9c440f5d0608d8901dfd151db8a6f1c /libopie2
parent1e6c3181dcc7ec4edbe99db0d886ce7a9c483056 (diff)
downloadopie-b6fc9840f4fe9bad392167c49dbcfa2acda9ed21.zip
opie-b6fc9840f4fe9bad392167c49dbcfa2acda9ed21.tar.gz
opie-b6fc9840f4fe9bad392167c49dbcfa2acda9ed21.tar.bz2
last bugfixes on opie-eye an imagescrollview. Seems that now all is working
as it should.
Diffstat (limited to 'libopie2') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiemm/oimagescrollview.cpp5
1 files changed, 4 insertions, 1 deletions
diff --git a/libopie2/opiemm/oimagescrollview.cpp b/libopie2/opiemm/oimagescrollview.cpp
index 10da823..76f50e1 100644
--- a/libopie2/opiemm/oimagescrollview.cpp
+++ b/libopie2/opiemm/oimagescrollview.cpp
@@ -160,96 +160,97 @@ void OImageScrollView::init()
160 _zoomer, (SLOT(setVisiblePoint(int,int))) ); 160 _zoomer, (SLOT(setVisiblePoint(int,int))) );
161 connect(this,SIGNAL(imageSizeChanged(const QSize&)), 161 connect(this,SIGNAL(imageSizeChanged(const QSize&)),
162 _zoomer, SLOT(setImageSize(const QSize&)) ); 162 _zoomer, SLOT(setImageSize(const QSize&)) );
163 connect(this,SIGNAL(viewportSizeChanged(const QSize&)), 163 connect(this,SIGNAL(viewportSizeChanged(const QSize&)),
164 _zoomer, SLOT(setViewPortSize(const QSize&)) ); 164 _zoomer, SLOT(setViewPortSize(const QSize&)) );
165 165
166 setBackgroundColor(white); 166 setBackgroundColor(white);
167 setFocusPolicy(QWidget::StrongFocus); 167 setFocusPolicy(QWidget::StrongFocus);
168 setImageScaledLoaded(false); 168 setImageScaledLoaded(false);
169 setImageIsJpeg(false); 169 setImageIsJpeg(false);
170 if (FirstResizeDone()) { 170 if (FirstResizeDone()) {
171 m_last_rot = Rotate0; 171 m_last_rot = Rotate0;
172 generateImage(); 172 generateImage();
173 } else if (_original_data.size().isValid()) { 173 } else if (_original_data.size().isValid()) {
174 if (image_fit_into(_original_data.size()) || !ShowZoomer()) _zoomer->hide(); 174 if (image_fit_into(_original_data.size()) || !ShowZoomer()) _zoomer->hide();
175 resizeContents(_original_data.width(),_original_data.height()); 175 resizeContents(_original_data.width(),_original_data.height());
176 } 176 }
177 _intensity = 0; 177 _intensity = 0;
178} 178}
179 179
180void OImageScrollView::setAutoRotate(bool how) 180void OImageScrollView::setAutoRotate(bool how)
181{ 181{
182 /* to avoid double repaints */ 182 /* to avoid double repaints */
183 if (AutoRotate() != how) { 183 if (AutoRotate() != how) {
184 m_states.setBit(AUTO_ROTATE,how); 184 m_states.setBit(AUTO_ROTATE,how);
185 _image_data = QImage(); 185 _image_data = QImage();
186 generateImage(); 186 generateImage();
187 } 187 }
188} 188}
189 189
190bool OImageScrollView::AutoRotate()const 190bool OImageScrollView::AutoRotate()const
191{ 191{
192 return m_states.testBit(AUTO_ROTATE); 192 return m_states.testBit(AUTO_ROTATE);
193} 193}
194 194
195void OImageScrollView::setAutoScaleRotate(bool scale, bool rotate) 195void OImageScrollView::setAutoScaleRotate(bool scale, bool rotate)
196{ 196{
197 m_states.setBit(AUTO_ROTATE,rotate); 197 m_states.setBit(AUTO_ROTATE,rotate);
198 setAutoScale(scale); 198 setAutoScale(scale);
199} 199}
200 200
201void OImageScrollView::setAutoScale(bool how) 201void OImageScrollView::setAutoScale(bool how)
202{ 202{
203 m_states.setBit(AUTO_SCALE,how); 203 m_states.setBit(AUTO_SCALE,how);
204 _image_data = QImage(); 204 _image_data = QImage();
205 if (ImageIsJpeg() && how == false && ImageScaledLoaded()==true) { 205 if (ImageIsJpeg() && how == false && ImageScaledLoaded()==true) {
206 loadJpeg(true); 206 loadJpeg(true);
207 } 207 }
208 _newImage = true;
208 generateImage(); 209 generateImage();
209} 210}
210 211
211bool OImageScrollView::AutoScale()const 212bool OImageScrollView::AutoScale()const
212{ 213{
213 return m_states.testBit(AUTO_SCALE); 214 return m_states.testBit(AUTO_SCALE);
214} 215}
215 216
216OImageScrollView::~OImageScrollView() 217OImageScrollView::~OImageScrollView()
217{ 218{
218} 219}
219 220
220void OImageScrollView::rescaleImage(int w, int h) 221void OImageScrollView::rescaleImage(int w, int h)
221{ 222{
222 if (_image_data.width()==w && _image_data.height()==h) { 223 if (_image_data.width()==w && _image_data.height()==h) {
223 return; 224 return;
224 } 225 }
225 double hs = (double)h / (double)_image_data.height() ; 226 double hs = (double)h / (double)_image_data.height() ;
226 double ws = (double)w / (double)_image_data.width() ; 227 double ws = (double)w / (double)_image_data.width() ;
227 double scaleFactor = (hs > ws) ? ws : hs; 228 double scaleFactor = (hs > ws) ? ws : hs;
228 int smoothW = (int)(scaleFactor * _image_data.width()); 229 int smoothW = (int)(scaleFactor * _image_data.width());
229 int smoothH = (int)(scaleFactor * _image_data.height()); 230 int smoothH = (int)(scaleFactor * _image_data.height());
230 _image_data = _image_data.smoothScale(smoothW,smoothH); 231 _image_data = _image_data.smoothScale(smoothW,smoothH);
231} 232}
232 233
233void OImageScrollView::rotate_into_data(Rotation r) 234void OImageScrollView::rotate_into_data(Rotation r)
234{ 235{
235 /* realy - we must do this that way, 'cause when acting direct on _image_data the app will 236 /* realy - we must do this that way, 'cause when acting direct on _image_data the app will
236 segfault :( */ 237 segfault :( */
237 QImage dest; 238 QImage dest;
238 int x, y; 239 int x, y;
239 if ( _original_data.depth() > 8 ) 240 if ( _original_data.depth() > 8 )
240 { 241 {
241 unsigned int *srcData, *destData; 242 unsigned int *srcData, *destData;
242 switch ( r ) 243 switch ( r )
243 { 244 {
244 case Rotate90: 245 case Rotate90:
245 dest.create(_original_data.height(), _original_data.width(), _original_data.depth()); 246 dest.create(_original_data.height(), _original_data.width(), _original_data.depth());
246 for ( y=0; y < _original_data.height(); ++y ) 247 for ( y=0; y < _original_data.height(); ++y )
247 { 248 {
248 srcData = (unsigned int *)_original_data.scanLine(y); 249 srcData = (unsigned int *)_original_data.scanLine(y);
249 for ( x=0; x < _original_data.width(); ++x ) 250 for ( x=0; x < _original_data.width(); ++x )
250 { 251 {
251 destData = (unsigned int *)dest.scanLine(x); 252 destData = (unsigned int *)dest.scanLine(x);
252 destData[_original_data.height()-y-1] = srcData[x]; 253 destData[_original_data.height()-y-1] = srcData[x];
253 } 254 }
254 } 255 }
255 break; 256 break;
@@ -303,98 +304,100 @@ void OImageScrollView::rotate_into_data(Rotation r)
303 } 304 }
304 } 305 }
305 break; 306 break;
306 case Rotate180: 307 case Rotate180:
307 dest.create(_original_data.width(), _original_data.height(), _original_data.depth()); 308 dest.create(_original_data.width(), _original_data.height(), _original_data.depth());
308 dest.setNumColors(_original_data.numColors()); 309 dest.setNumColors(_original_data.numColors());
309 srcTable = (unsigned int *)_original_data.colorTable(); 310 srcTable = (unsigned int *)_original_data.colorTable();
310 destTable = (unsigned int *)dest.colorTable(); 311 destTable = (unsigned int *)dest.colorTable();
311 for ( x=0; x < _original_data.numColors(); ++x ) 312 for ( x=0; x < _original_data.numColors(); ++x )
312 destTable[x] = srcTable[x]; 313 destTable[x] = srcTable[x];
313 for ( y=0; y < _original_data.height(); ++y ) 314 for ( y=0; y < _original_data.height(); ++y )
314 { 315 {
315 srcData = (unsigned char *)_original_data.scanLine(y); 316 srcData = (unsigned char *)_original_data.scanLine(y);
316 destData = (unsigned char *)dest.scanLine(_original_data.height()-y-1); 317 destData = (unsigned char *)dest.scanLine(_original_data.height()-y-1);
317 for ( x=0; x < _original_data.width(); ++x ) 318 for ( x=0; x < _original_data.width(); ++x )
318 destData[_original_data.width()-x-1] = srcData[x]; 319 destData[_original_data.width()-x-1] = srcData[x];
319 } 320 }
320 break; 321 break;
321 case Rotate270: 322 case Rotate270:
322 dest.create(_original_data.height(), _original_data.width(), _original_data.depth()); 323 dest.create(_original_data.height(), _original_data.width(), _original_data.depth());
323 dest.setNumColors(_original_data.numColors()); 324 dest.setNumColors(_original_data.numColors());
324 srcTable = (unsigned int *)_original_data.colorTable(); 325 srcTable = (unsigned int *)_original_data.colorTable();
325 destTable = (unsigned int *)dest.colorTable(); 326 destTable = (unsigned int *)dest.colorTable();
326 for ( x=0; x < _original_data.numColors(); ++x ) 327 for ( x=0; x < _original_data.numColors(); ++x )
327 destTable[x] = srcTable[x]; 328 destTable[x] = srcTable[x];
328 for ( y=0; y < _original_data.height(); ++y ) 329 for ( y=0; y < _original_data.height(); ++y )
329 { 330 {
330 srcData = (unsigned char *)_original_data.scanLine(y); 331 srcData = (unsigned char *)_original_data.scanLine(y);
331 for ( x=0; x < _original_data.width(); ++x ) 332 for ( x=0; x < _original_data.width(); ++x )
332 { 333 {
333 destData = (unsigned char *)dest.scanLine(_original_data.width()-x-1); 334 destData = (unsigned char *)dest.scanLine(_original_data.width()-x-1);
334 destData[y] = srcData[x]; 335 destData[y] = srcData[x];
335 } 336 }
336 } 337 }
337 break; 338 break;
338 default: 339 default:
339 dest = _original_data; 340 dest = _original_data;
340 break; 341 break;
341 } 342 }
342 343
343 } 344 }
344 _newImage = true; 345 _newImage = true;
345 _image_data = dest; 346 _image_data = dest;
346} 347}
347 348
348// yes - sorry - it is NOT gamma it is just BRIGHTNESS. Alwin 349// yes - sorry - it is NOT gamma it is just BRIGHTNESS. Alwin
349void OImageScrollView::apply_gamma(int aValue) 350void OImageScrollView::apply_gamma(int aValue)
350{ 351{
351 if (!_image_data.size().isValid()) return; 352 if (aValue==0 || !_image_data.size().isValid()) return;
352 float percent = ((float)aValue/100.0); 353 float percent = ((float)aValue/100.0);
354 /* make sure working on a copy */
355 _image_data.detach();
353 356
354 int segColors = _image_data.depth() > 8 ? 256 : _image_data.numColors(); 357 int segColors = _image_data.depth() > 8 ? 256 : _image_data.numColors();
355 /* must be - otherwise it displays some ... strange colors */ 358 /* must be - otherwise it displays some ... strange colors */
356 if (segColors<256) segColors=256; 359 if (segColors<256) segColors=256;
357 360
358 unsigned char *segTbl = new unsigned char[segColors]; 361 unsigned char *segTbl = new unsigned char[segColors];
359 int pixels = _image_data.depth()>8?_image_data.width()*_image_data.height() : _image_data.numColors(); 362 int pixels = _image_data.depth()>8?_image_data.width()*_image_data.height() : _image_data.numColors();
360 363
361 364
362 bool brighten = (percent >= 0); 365 bool brighten = (percent >= 0);
363 if ( percent < 0 ) { 366 if ( percent < 0 ) {
364 percent = -percent; 367 percent = -percent;
365 } 368 }
366 369
367 unsigned int *data = _image_data.depth() > 8 ? (unsigned int *)_image_data.bits() : 370 unsigned int *data = _image_data.depth() > 8 ? (unsigned int *)_image_data.bits() :
368 (unsigned int *)_image_data.colorTable(); 371 (unsigned int *)_image_data.colorTable();
369 372
370 int tmp = 0; 373 int tmp = 0;
371 374
372 if (brighten) { 375 if (brighten) {
373 for ( int i=0; i < segColors; ++i ) 376 for ( int i=0; i < segColors; ++i )
374 { 377 {
375 tmp = (int)(i*percent); 378 tmp = (int)(i*percent);
376 if ( tmp > 255 ) 379 if ( tmp > 255 )
377 tmp = 255; 380 tmp = 255;
378 segTbl[i] = tmp; 381 segTbl[i] = tmp;
379 } 382 }
380 } else { 383 } else {
381 for ( int i=0; i < segColors; ++i ) 384 for ( int i=0; i < segColors; ++i )
382 { 385 {
383 tmp = (int)(i*percent); 386 tmp = (int)(i*percent);
384 if ( tmp < 0 ) 387 if ( tmp < 0 )
385 tmp = 0; 388 tmp = 0;
386 segTbl[i] = tmp; 389 segTbl[i] = tmp;
387 } 390 }
388 } 391 }
389 if (brighten) { 392 if (brighten) {
390 for ( int i=0; i < pixels; ++i ) 393 for ( int i=0; i < pixels; ++i )
391 { 394 {
392 int r = qRed(data[i]); 395 int r = qRed(data[i]);
393 int g = qGreen(data[i]); 396 int g = qGreen(data[i]);
394 int b = qBlue(data[i]); 397 int b = qBlue(data[i]);
395 int a = qAlpha(data[i]); 398 int a = qAlpha(data[i]);
396 r = r + segTbl[r] > 255 ? 255 : r + segTbl[r]; 399 r = r + segTbl[r] > 255 ? 255 : r + segTbl[r];
397 g = g + segTbl[g] > 255 ? 255 : g + segTbl[g]; 400 g = g + segTbl[g] > 255 ? 255 : g + segTbl[g];
398 b = b + segTbl[b] > 255 ? 255 : b + segTbl[b]; 401 b = b + segTbl[b] > 255 ? 255 : b + segTbl[b];
399 data[i] = qRgba(r, g, b,a); 402 data[i] = qRgba(r, g, b,a);
400 } 403 }