author | alwin <alwin> | 2004-04-16 20:33:55 (UTC) |
---|---|---|
committer | alwin <alwin> | 2004-04-16 20:33:55 (UTC) |
commit | cc56768485c3785439883dd1c456493f7ece2d84 (patch) (unidiff) | |
tree | 8ab6ff6feae6f2cc9cb73b4eaf8215cdd0d53a0d | |
parent | 7dc52619640437ec448ea3bccdf924ea9a29bfa6 (diff) | |
download | opie-cc56768485c3785439883dd1c456493f7ece2d84.zip opie-cc56768485c3785439883dd1c456493f7ece2d84.tar.gz opie-cc56768485c3785439883dd1c456493f7ece2d84.tar.bz2 |
fixed painting problems when reloading images when widget is visible
-rw-r--r-- | libopie2/opiemm/oimagescrollview.cpp | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/libopie2/opiemm/oimagescrollview.cpp b/libopie2/opiemm/oimagescrollview.cpp index 61b2062..a8165a4 100644 --- a/libopie2/opiemm/oimagescrollview.cpp +++ b/libopie2/opiemm/oimagescrollview.cpp | |||
@@ -96,129 +96,129 @@ void OImageScrollView::loadJpeg(bool interncall) | |||
96 | hei = wid; | 96 | hei = wid; |
97 | } | 97 | } |
98 | param = QString( "Fast Shrink( 3 ) Scale( %1, %2, ScaleMin)" ).arg( wid ).arg( hei ); | 98 | param = QString( "Fast Shrink( 3 ) Scale( %1, %2, ScaleMin)" ).arg( wid ).arg( hei ); |
99 | odebug << "Load jpeg scaled \"" << param << "\"" << oendl; | 99 | odebug << "Load jpeg scaled \"" << param << "\"" << oendl; |
100 | iio.setParameters(param.latin1()); | 100 | iio.setParameters(param.latin1()); |
101 | setImageScaledLoaded(true); | 101 | setImageScaledLoaded(true); |
102 | real_load = true; | 102 | real_load = true; |
103 | } | 103 | } |
104 | } else { | 104 | } else { |
105 | if (ImageScaledLoaded()||!interncall) { | 105 | if (ImageScaledLoaded()||!interncall) { |
106 | odebug << "Load jpeg unscaled" << oendl; | 106 | odebug << "Load jpeg unscaled" << oendl; |
107 | real_load = true; | 107 | real_load = true; |
108 | } | 108 | } |
109 | setImageScaledLoaded(false); | 109 | setImageScaledLoaded(false); |
110 | } | 110 | } |
111 | if (real_load) { | 111 | if (real_load) { |
112 | _original_data = iio.read() ? iio.image() : QImage(); | 112 | _original_data = iio.read() ? iio.image() : QImage(); |
113 | } | 113 | } |
114 | } | 114 | } |
115 | 115 | ||
116 | void OImageScrollView::setImage( const QString& path ) { | 116 | void OImageScrollView::setImage( const QString& path ) { |
117 | odebug << "load new image " << oendl; | 117 | odebug << "load new image " << oendl; |
118 | if (m_lastName == path) return; | 118 | if (m_lastName == path) return; |
119 | m_lastName = path; | 119 | m_lastName = path; |
120 | _original_data = QImage(); | 120 | _original_data = QImage(); |
121 | QString itype = QImage::imageFormat(m_lastName); | 121 | QString itype = QImage::imageFormat(m_lastName); |
122 | odebug << "Image type = " << itype << oendl; | 122 | odebug << "Image type = " << itype << oendl; |
123 | if (itype == "JPEG") { | 123 | if (itype == "JPEG") { |
124 | setImageIsJpeg(true); | 124 | setImageIsJpeg(true); |
125 | loadJpeg(); | 125 | loadJpeg(); |
126 | } else { | 126 | } else { |
127 | setImageIsJpeg(false); | 127 | setImageIsJpeg(false); |
128 | _original_data.load(path); | 128 | _original_data.load(path); |
129 | _original_data.convertDepth(QPixmap::defaultDepth()); | 129 | _original_data.convertDepth(QPixmap::defaultDepth()); |
130 | _original_data.setAlphaBuffer(false); | 130 | _original_data.setAlphaBuffer(false); |
131 | } | 131 | } |
132 | _image_data = QImage(); | 132 | _image_data = QImage(); |
133 | if (FirstResizeDone()) { | 133 | if (FirstResizeDone()) { |
134 | generateImage(); | 134 | generateImage(); |
135 | if (isVisible()) viewport()->repaint(true); | 135 | if (isVisible()) viewport()->repaint(true); |
136 | } | 136 | } |
137 | } | 137 | } |
138 | 138 | ||
139 | /* should be called every time the QImage changed it content */ | 139 | /* should be called every time the QImage changed it content */ |
140 | void OImageScrollView::init() | 140 | void OImageScrollView::init() |
141 | { | 141 | { |
142 | odebug << "init " << oendl; | 142 | odebug << "init " << oendl; |
143 | 143 | ||
144 | /* | 144 | /* |
145 | * create the zoomer | 145 | * create the zoomer |
146 | * and connect ther various signals | 146 | * and connect ther various signals |
147 | */ | 147 | */ |
148 | _zoomer = new Opie::MM::OImageZoomer( this, "The Zoomer" ); | 148 | _zoomer = new Opie::MM::OImageZoomer( this, "The Zoomer" ); |
149 | connect(_zoomer, SIGNAL( zoomAreaRel(int,int)), | 149 | connect(_zoomer, SIGNAL( zoomAreaRel(int,int)), |
150 | this, SLOT(scrollBy(int,int)) ); | 150 | this, SLOT(scrollBy(int,int)) ); |
151 | connect(_zoomer, SIGNAL( zoomArea(int,int)), | 151 | connect(_zoomer, SIGNAL( zoomArea(int,int)), |
152 | this, SLOT(center(int,int)) ); | 152 | this, SLOT(center(int,int)) ); |
153 | connect(this,SIGNAL(contentsMoving(int,int)), | 153 | connect(this,SIGNAL(contentsMoving(int,int)), |
154 | _zoomer, (SLOT(setVisiblePoint(int,int))) ); | 154 | _zoomer, (SLOT(setVisiblePoint(int,int))) ); |
155 | connect(this,SIGNAL(imageSizeChanged(const QSize&)), | 155 | connect(this,SIGNAL(imageSizeChanged(const QSize&)), |
156 | _zoomer, SLOT(setImageSize(const QSize&)) ); | 156 | _zoomer, SLOT(setImageSize(const QSize&)) ); |
157 | connect(this,SIGNAL(viewportSizeChanged(const QSize&)), | 157 | connect(this,SIGNAL(viewportSizeChanged(const QSize&)), |
158 | _zoomer, SLOT(setViewPortSize(const QSize&)) ); | 158 | _zoomer, SLOT(setViewPortSize(const QSize&)) ); |
159 | 159 | ||
160 | viewport()->setBackgroundColor(white); | 160 | setBackgroundColor(white); |
161 | setFocusPolicy(QWidget::StrongFocus); | 161 | setFocusPolicy(QWidget::StrongFocus); |
162 | setImageScaledLoaded(false); | 162 | setImageScaledLoaded(false); |
163 | setImageIsJpeg(false); | 163 | setImageIsJpeg(false); |
164 | if (FirstResizeDone()) { | 164 | if (FirstResizeDone()) { |
165 | m_last_rot = Rotate0; | 165 | m_last_rot = Rotate0; |
166 | generateImage(); | 166 | generateImage(); |
167 | } else if (_original_data.size().isValid()) { | 167 | } else if (_original_data.size().isValid()) { |
168 | if (image_fit_into(_original_data.size()) || !ShowZoomer()) _zoomer->hide(); | 168 | if (image_fit_into(_original_data.size()) || !ShowZoomer()) _zoomer->hide(); |
169 | resizeContents(_original_data.width(),_original_data.height()); | 169 | resizeContents(_original_data.width(),_original_data.height()); |
170 | } | 170 | } |
171 | } | 171 | } |
172 | 172 | ||
173 | void OImageScrollView::setAutoRotate(bool how) | 173 | void OImageScrollView::setAutoRotate(bool how) |
174 | { | 174 | { |
175 | /* to avoid double repaints */ | 175 | /* to avoid double repaints */ |
176 | if (AutoRotate() != how) { | 176 | if (AutoRotate() != how) { |
177 | m_states.setBit(AUTO_ROTATE,how); | 177 | m_states.setBit(AUTO_ROTATE,how); |
178 | _image_data = QImage(); | 178 | _image_data = QImage(); |
179 | generateImage(); | 179 | generateImage(); |
180 | } | 180 | } |
181 | } | 181 | } |
182 | 182 | ||
183 | bool OImageScrollView::AutoRotate()const | 183 | bool OImageScrollView::AutoRotate()const |
184 | { | 184 | { |
185 | return m_states.testBit(AUTO_ROTATE); | 185 | return m_states.testBit(AUTO_ROTATE); |
186 | } | 186 | } |
187 | 187 | ||
188 | void OImageScrollView::setAutoScaleRotate(bool scale, bool rotate) | 188 | void OImageScrollView::setAutoScaleRotate(bool scale, bool rotate) |
189 | { | 189 | { |
190 | m_states.setBit(AUTO_ROTATE,rotate); | 190 | m_states.setBit(AUTO_ROTATE,rotate); |
191 | setAutoScale(scale); | 191 | setAutoScale(scale); |
192 | } | 192 | } |
193 | 193 | ||
194 | void OImageScrollView::setAutoScale(bool how) | 194 | void OImageScrollView::setAutoScale(bool how) |
195 | { | 195 | { |
196 | m_states.setBit(AUTO_SCALE,how); | 196 | m_states.setBit(AUTO_SCALE,how); |
197 | _image_data = QImage(); | 197 | _image_data = QImage(); |
198 | if (ImageIsJpeg() && how == false && ImageScaledLoaded()==true) { | 198 | if (ImageIsJpeg() && how == false && ImageScaledLoaded()==true) { |
199 | loadJpeg(true); | 199 | loadJpeg(true); |
200 | } | 200 | } |
201 | generateImage(); | 201 | generateImage(); |
202 | } | 202 | } |
203 | 203 | ||
204 | bool OImageScrollView::AutoScale()const | 204 | bool OImageScrollView::AutoScale()const |
205 | { | 205 | { |
206 | return m_states.testBit(AUTO_SCALE); | 206 | return m_states.testBit(AUTO_SCALE); |
207 | } | 207 | } |
208 | 208 | ||
209 | OImageScrollView::~OImageScrollView() | 209 | OImageScrollView::~OImageScrollView() |
210 | { | 210 | { |
211 | } | 211 | } |
212 | 212 | ||
213 | void OImageScrollView::rescaleImage(int w, int h) | 213 | void OImageScrollView::rescaleImage(int w, int h) |
214 | { | 214 | { |
215 | if (_image_data.width()==w && _image_data.height()==h) { | 215 | if (_image_data.width()==w && _image_data.height()==h) { |
216 | return; | 216 | return; |
217 | } | 217 | } |
218 | double hs = (double)h / (double)_image_data.height() ; | 218 | double hs = (double)h / (double)_image_data.height() ; |
219 | double ws = (double)w / (double)_image_data.width() ; | 219 | double ws = (double)w / (double)_image_data.width() ; |
220 | double scaleFactor = (hs > ws) ? ws : hs; | 220 | double scaleFactor = (hs > ws) ? ws : hs; |
221 | int smoothW = (int)(scaleFactor * _image_data.width()); | 221 | int smoothW = (int)(scaleFactor * _image_data.width()); |
222 | int smoothH = (int)(scaleFactor * _image_data.height()); | 222 | int smoothH = (int)(scaleFactor * _image_data.height()); |
223 | _image_data = _image_data.smoothScale(smoothW,smoothH); | 223 | _image_data = _image_data.smoothScale(smoothW,smoothH); |
224 | } | 224 | } |
@@ -290,233 +290,237 @@ void OImageScrollView::rotate_into_data(Rotation r) | |||
290 | { | 290 | { |
291 | srcData = (unsigned char *)_original_data.scanLine(y); | 291 | srcData = (unsigned char *)_original_data.scanLine(y); |
292 | for ( x=0; x < _original_data.width(); ++x ) | 292 | for ( x=0; x < _original_data.width(); ++x ) |
293 | { | 293 | { |
294 | destData = (unsigned char *)dest.scanLine(x); | 294 | destData = (unsigned char *)dest.scanLine(x); |
295 | destData[_original_data.height()-y-1] = srcData[x]; | 295 | destData[_original_data.height()-y-1] = srcData[x]; |
296 | } | 296 | } |
297 | } | 297 | } |
298 | break; | 298 | break; |
299 | case Rotate180: | 299 | case Rotate180: |
300 | dest.create(_original_data.width(), _original_data.height(), _original_data.depth()); | 300 | dest.create(_original_data.width(), _original_data.height(), _original_data.depth()); |
301 | dest.setNumColors(_original_data.numColors()); | 301 | dest.setNumColors(_original_data.numColors()); |
302 | srcTable = (unsigned int *)_original_data.colorTable(); | 302 | srcTable = (unsigned int *)_original_data.colorTable(); |
303 | destTable = (unsigned int *)dest.colorTable(); | 303 | destTable = (unsigned int *)dest.colorTable(); |
304 | for ( x=0; x < _original_data.numColors(); ++x ) | 304 | for ( x=0; x < _original_data.numColors(); ++x ) |
305 | destTable[x] = srcTable[x]; | 305 | destTable[x] = srcTable[x]; |
306 | for ( y=0; y < _original_data.height(); ++y ) | 306 | for ( y=0; y < _original_data.height(); ++y ) |
307 | { | 307 | { |
308 | srcData = (unsigned char *)_original_data.scanLine(y); | 308 | srcData = (unsigned char *)_original_data.scanLine(y); |
309 | destData = (unsigned char *)dest.scanLine(_original_data.height()-y-1); | 309 | destData = (unsigned char *)dest.scanLine(_original_data.height()-y-1); |
310 | for ( x=0; x < _original_data.width(); ++x ) | 310 | for ( x=0; x < _original_data.width(); ++x ) |
311 | destData[_original_data.width()-x-1] = srcData[x]; | 311 | destData[_original_data.width()-x-1] = srcData[x]; |
312 | } | 312 | } |
313 | break; | 313 | break; |
314 | case Rotate270: | 314 | case Rotate270: |
315 | dest.create(_original_data.height(), _original_data.width(), _original_data.depth()); | 315 | dest.create(_original_data.height(), _original_data.width(), _original_data.depth()); |
316 | dest.setNumColors(_original_data.numColors()); | 316 | dest.setNumColors(_original_data.numColors()); |
317 | srcTable = (unsigned int *)_original_data.colorTable(); | 317 | srcTable = (unsigned int *)_original_data.colorTable(); |
318 | destTable = (unsigned int *)dest.colorTable(); | 318 | destTable = (unsigned int *)dest.colorTable(); |
319 | for ( x=0; x < _original_data.numColors(); ++x ) | 319 | for ( x=0; x < _original_data.numColors(); ++x ) |
320 | destTable[x] = srcTable[x]; | 320 | destTable[x] = srcTable[x]; |
321 | for ( y=0; y < _original_data.height(); ++y ) | 321 | for ( y=0; y < _original_data.height(); ++y ) |
322 | { | 322 | { |
323 | srcData = (unsigned char *)_original_data.scanLine(y); | 323 | srcData = (unsigned char *)_original_data.scanLine(y); |
324 | for ( x=0; x < _original_data.width(); ++x ) | 324 | for ( x=0; x < _original_data.width(); ++x ) |
325 | { | 325 | { |
326 | destData = (unsigned char *)dest.scanLine(_original_data.width()-x-1); | 326 | destData = (unsigned char *)dest.scanLine(_original_data.width()-x-1); |
327 | destData[y] = srcData[x]; | 327 | destData[y] = srcData[x]; |
328 | } | 328 | } |
329 | } | 329 | } |
330 | break; | 330 | break; |
331 | default: | 331 | default: |
332 | dest = _original_data; | 332 | dest = _original_data; |
333 | break; | 333 | break; |
334 | } | 334 | } |
335 | 335 | ||
336 | } | 336 | } |
337 | _image_data = dest; | 337 | _image_data = dest; |
338 | } | 338 | } |
339 | 339 | ||
340 | void OImageScrollView::generateImage() | 340 | void OImageScrollView::generateImage() |
341 | { | 341 | { |
342 | Rotation r = Rotate0; | 342 | Rotation r = Rotate0; |
343 | _pdata = QPixmap(); | 343 | _pdata = QPixmap(); |
344 | if (_original_data.isNull()) { | 344 | if (_original_data.isNull()) { |
345 | emit imageSizeChanged( _image_data.size() ); | 345 | emit imageSizeChanged( _image_data.size() ); |
346 | if (_zoomer) _zoomer->setImage( _image_data ); | 346 | if (_zoomer) _zoomer->setImage( _image_data ); |
347 | return; | 347 | return; |
348 | } | 348 | } |
349 | if (width()>height()&&_original_data.width()<_original_data.height() || | 349 | if (width()>height()&&_original_data.width()<_original_data.height() || |
350 | width()<height()&&_original_data.width()>_original_data.height()) { | 350 | width()<height()&&_original_data.width()>_original_data.height()) { |
351 | if (AutoRotate()) r = Rotate90; | 351 | if (AutoRotate()) r = Rotate90; |
352 | } | 352 | } |
353 | 353 | ||
354 | 354 | int twidth,theight; | |
355 | odebug << " r = " << r << oendl; | 355 | odebug << " r = " << r << oendl; |
356 | if (AutoScale() && (_original_data.width()>width() || _original_data.height() > height()) ) { | 356 | if (AutoScale() && (_original_data.width()>width() || _original_data.height() > height()) ) { |
357 | if (!_image_data.size().isValid()||width()>_image_data.width()||height()>_image_data.height()) { | 357 | if (!_image_data.size().isValid()||width()>_image_data.width()||height()>_image_data.height()) { |
358 | odebug << "Rescaling data" << oendl; | 358 | odebug << "Rescaling data" << oendl; |
359 | if (r==Rotate0) { | 359 | if (r==Rotate0) { |
360 | _image_data = _original_data; | 360 | _image_data = _original_data; |
361 | } else { | 361 | } else { |
362 | rotate_into_data(r); | 362 | rotate_into_data(r); |
363 | } | 363 | } |
364 | } | 364 | } |
365 | rescaleImage(width(),height()); | 365 | rescaleImage(width(),height()); |
366 | resizeContents(_image_data.width(),_image_data.height()); | ||
367 | } else if (!FirstResizeDone()||r!=m_last_rot||_image_data.width()==0) { | 366 | } else if (!FirstResizeDone()||r!=m_last_rot||_image_data.width()==0) { |
368 | if (r==Rotate0) { | 367 | if (r==Rotate0) { |
369 | _image_data = _original_data; | 368 | _image_data = _original_data; |
370 | } else { | 369 | } else { |
371 | rotate_into_data(r); | 370 | rotate_into_data(r); |
372 | } | 371 | } |
373 | m_last_rot = r; | 372 | m_last_rot = r; |
374 | resizeContents(_image_data.width(),_image_data.height()); | ||
375 | } | 373 | } |
376 | _pdata.convertFromImage(_image_data); | 374 | _pdata.convertFromImage(_image_data); |
375 | twidth = _image_data.width(); | ||
376 | theight = _image_data.height(); | ||
377 | 377 | ||
378 | /* | 378 | /* |
379 | * update the zoomer | 379 | * update the zoomer |
380 | */ | 380 | */ |
381 | check_zoomer(); | 381 | check_zoomer(); |
382 | emit imageSizeChanged( _image_data.size() ); | 382 | emit imageSizeChanged( _image_data.size() ); |
383 | rescaleImage( 128, 128 ); | 383 | rescaleImage( 128, 128 ); |
384 | resizeContents(twidth,theight); | ||
384 | /* | 385 | /* |
385 | * move scrollbar | 386 | * move scrollbar |
386 | */ | 387 | */ |
387 | if (_zoomer) { | 388 | if (_zoomer) { |
388 | _zoomer->setGeometry( viewport()->width()-_image_data.width()/2, viewport()->height()-_image_data.height()/2, | 389 | _zoomer->setGeometry( viewport()->width()-_image_data.width()/2, viewport()->height()-_image_data.height()/2, |
389 | _image_data.width()/2, _image_data.height()/2 ); | 390 | _image_data.width()/2, _image_data.height()/2 ); |
390 | _zoomer->setImage( _image_data ); | 391 | _zoomer->setImage( _image_data ); |
391 | } | 392 | } |
392 | /* | 393 | /* |
393 | * invalidate | 394 | * invalidate |
394 | */ | 395 | */ |
395 | _image_data=QImage(); | 396 | _image_data=QImage(); |
397 | if (isVisible()) { | ||
398 | updateContents(contentsX(),contentsY(),width(),height()); | ||
399 | } | ||
396 | } | 400 | } |
397 | 401 | ||
398 | void OImageScrollView::resizeEvent(QResizeEvent * e) | 402 | void OImageScrollView::resizeEvent(QResizeEvent * e) |
399 | { | 403 | { |
400 | odebug << "OImageScrollView resizeEvent" << oendl; | 404 | odebug << "OImageScrollView resizeEvent" << oendl; |
401 | QScrollView::resizeEvent(e); | 405 | QScrollView::resizeEvent(e); |
402 | generateImage(); | 406 | generateImage(); |
403 | setFirstResizeDone(true); | 407 | setFirstResizeDone(true); |
404 | emit viewportSizeChanged( viewport()->size() ); | 408 | emit viewportSizeChanged( viewport()->size() ); |
405 | 409 | ||
406 | } | 410 | } |
407 | 411 | ||
408 | void OImageScrollView::keyPressEvent(QKeyEvent * e) | 412 | void OImageScrollView::keyPressEvent(QKeyEvent * e) |
409 | { | 413 | { |
410 | if (!e) return; | 414 | if (!e) return; |
411 | int dx = horizontalScrollBar()->lineStep(); | 415 | int dx = horizontalScrollBar()->lineStep(); |
412 | int dy = verticalScrollBar()->lineStep(); | 416 | int dy = verticalScrollBar()->lineStep(); |
413 | if (e->key()==Qt::Key_Right) { | 417 | if (e->key()==Qt::Key_Right) { |
414 | scrollBy(dx,0); | 418 | scrollBy(dx,0); |
415 | e->accept(); | 419 | e->accept(); |
416 | } else if (e->key()==Qt::Key_Left) { | 420 | } else if (e->key()==Qt::Key_Left) { |
417 | scrollBy(0-dx,0); | 421 | scrollBy(0-dx,0); |
418 | e->accept(); | 422 | e->accept(); |
419 | } else if (e->key()==Qt::Key_Up) { | 423 | } else if (e->key()==Qt::Key_Up) { |
420 | scrollBy(0,0-dy); | 424 | scrollBy(0,0-dy); |
421 | e->accept(); | 425 | e->accept(); |
422 | } else if (e->key()==Qt::Key_Down) { | 426 | } else if (e->key()==Qt::Key_Down) { |
423 | scrollBy(0,dy); | 427 | scrollBy(0,dy); |
424 | e->accept(); | 428 | e->accept(); |
425 | } else { | 429 | } else { |
426 | e->ignore(); | 430 | e->ignore(); |
427 | } | 431 | } |
428 | QScrollView::keyPressEvent(e); | 432 | QScrollView::keyPressEvent(e); |
429 | } | 433 | } |
430 | 434 | ||
431 | void OImageScrollView::drawContents(QPainter * p, int clipx, int clipy, int clipw, int cliph) | 435 | void OImageScrollView::drawContents(QPainter * p, int clipx, int clipy, int clipw, int cliph) |
432 | { | 436 | { |
433 | int w = clipw; | 437 | int w = clipw; |
434 | int h = cliph; | 438 | int h = cliph; |
435 | int x = clipx; | 439 | int x = clipx; |
436 | int y = clipy; | 440 | int y = clipy; |
437 | bool erase = false; | 441 | bool erase = false; |
438 | 442 | ||
439 | if (!_pdata.size().isValid()) { | 443 | if (!_pdata.size().isValid()) { |
440 | p->fillRect(clipx,clipy,clipw,cliph,white); | 444 | p->fillRect(clipx,clipy,clipw,cliph, backgroundColor()); |
441 | return; | 445 | return; |
442 | } | 446 | } |
443 | if (w>_pdata.width()) { | 447 | if (w>_pdata.width()) { |
444 | w=_pdata.width(); | 448 | w=_pdata.width(); |
445 | x = 0; | 449 | x = 0; |
446 | erase = true; | 450 | erase = true; |
447 | } else if (x+w>_pdata.width()){ | 451 | } else if (x+w>_pdata.width()){ |
448 | x = _pdata.width()-w; | 452 | x = _pdata.width()-w; |
449 | } | 453 | } |
450 | if (h>_pdata.height()) { | 454 | if (h>_pdata.height()) { |
451 | h=_pdata.height(); | 455 | h=_pdata.height(); |
452 | y = 0; | 456 | y = 0; |
453 | erase = true; | 457 | erase = true; |
454 | } else if (y+h>_pdata.height()){ | 458 | } else if (y+h>_pdata.height()){ |
455 | y = _pdata.height()-h; | 459 | y = _pdata.height()-h; |
456 | } | 460 | } |
457 | if (erase||_original_data.hasAlphaBuffer()) { | 461 | if (erase||_original_data.hasAlphaBuffer()) { |
458 | p->fillRect(clipx,clipy,clipw,cliph,white); | 462 | p->fillRect(clipx,clipy,clipw,cliph, backgroundColor()); |
459 | } | 463 | } |
460 | p->drawPixmap(clipx,clipy,_pdata,x,y,w,h); | 464 | p->drawPixmap(clipx,clipy,_pdata,x,y,w,h); |
461 | } | 465 | } |
462 | 466 | ||
463 | /* using the real geometry points and not the translated points is wanted! */ | 467 | /* using the real geometry points and not the translated points is wanted! */ |
464 | void OImageScrollView::viewportMouseMoveEvent(QMouseEvent* e) | 468 | void OImageScrollView::viewportMouseMoveEvent(QMouseEvent* e) |
465 | { | 469 | { |
466 | int mx, my; | 470 | int mx, my; |
467 | mx = e->x(); | 471 | mx = e->x(); |
468 | my = e->y(); | 472 | my = e->y(); |
469 | if (_mouseStartPosX!=-1 && _mouseStartPosY!=-1) { | 473 | if (_mouseStartPosX!=-1 && _mouseStartPosY!=-1) { |
470 | int diffx = _mouseStartPosX-mx; | 474 | int diffx = _mouseStartPosX-mx; |
471 | int diffy = _mouseStartPosY-my; | 475 | int diffy = _mouseStartPosY-my; |
472 | scrollBy(diffx,diffy); | 476 | scrollBy(diffx,diffy); |
473 | } | 477 | } |
474 | _mouseStartPosX=mx; | 478 | _mouseStartPosX=mx; |
475 | _mouseStartPosY=my; | 479 | _mouseStartPosY=my; |
476 | } | 480 | } |
477 | 481 | ||
478 | void OImageScrollView::contentsMousePressEvent ( QMouseEvent * e) | 482 | void OImageScrollView::contentsMousePressEvent ( QMouseEvent * e) |
479 | { | 483 | { |
480 | odebug << " X and Y " << e->x() << " " << e->y() << oendl; | 484 | odebug << " X and Y " << e->x() << " " << e->y() << oendl; |
481 | /* this marks the beginning of a possible mouse move. Due internal reasons of QT | 485 | /* this marks the beginning of a possible mouse move. Due internal reasons of QT |
482 | the geometry values here may real differ from that set in MoveEvent (I don't know | 486 | the geometry values here may real differ from that set in MoveEvent (I don't know |
483 | why). For getting them in real context, we use the first move-event to set the start | 487 | why). For getting them in real context, we use the first move-event to set the start |
484 | position ;) | 488 | position ;) |
485 | */ | 489 | */ |
486 | _mouseStartPosX = -1; | 490 | _mouseStartPosX = -1; |
487 | _mouseStartPosY = -1; | 491 | _mouseStartPosY = -1; |
488 | } | 492 | } |
489 | 493 | ||
490 | void OImageScrollView::setDestructiveClose() { | 494 | void OImageScrollView::setDestructiveClose() { |
491 | WFlags fl = getWFlags(); | 495 | WFlags fl = getWFlags(); |
492 | /* clear it just in case */ | 496 | /* clear it just in case */ |
493 | fl &= ~WDestructiveClose; | 497 | fl &= ~WDestructiveClose; |
494 | fl |= WDestructiveClose; | 498 | fl |= WDestructiveClose; |
495 | setWFlags( fl ); | 499 | setWFlags( fl ); |
496 | } | 500 | } |
497 | 501 | ||
498 | bool OImageScrollView::image_fit_into(const QSize&s ) | 502 | bool OImageScrollView::image_fit_into(const QSize&s ) |
499 | { | 503 | { |
500 | if (s.width()>width()||s.height()>height()) { | 504 | if (s.width()>width()||s.height()>height()) { |
501 | return false; | 505 | return false; |
502 | } | 506 | } |
503 | return true; | 507 | return true; |
504 | } | 508 | } |
505 | 509 | ||
506 | void OImageScrollView::setShowZoomer(bool how) | 510 | void OImageScrollView::setShowZoomer(bool how) |
507 | { | 511 | { |
508 | m_states.setBit(SHOW_ZOOMER,how); | 512 | m_states.setBit(SHOW_ZOOMER,how); |
509 | check_zoomer(); | 513 | check_zoomer(); |
510 | } | 514 | } |
511 | 515 | ||
512 | bool OImageScrollView::ShowZoomer()const | 516 | bool OImageScrollView::ShowZoomer()const |
513 | { | 517 | { |
514 | return m_states.testBit(SHOW_ZOOMER); | 518 | return m_states.testBit(SHOW_ZOOMER); |
515 | } | 519 | } |
516 | 520 | ||
517 | void OImageScrollView::check_zoomer() | 521 | void OImageScrollView::check_zoomer() |
518 | { | 522 | { |
519 | if (!_zoomer) return; | 523 | if (!_zoomer) return; |
520 | if ( (!ShowZoomer()||image_fit_into(_pdata.size()) ) && _zoomer->isVisible()) { | 524 | if ( (!ShowZoomer()||image_fit_into(_pdata.size()) ) && _zoomer->isVisible()) { |
521 | _zoomer->hide(); | 525 | _zoomer->hide(); |
522 | } else if ( ShowZoomer() && !image_fit_into(_pdata.size()) && _zoomer->isHidden()){ | 526 | } else if ( ShowZoomer() && !image_fit_into(_pdata.size()) && _zoomer->isHidden()){ |