summaryrefslogtreecommitdiff
path: root/libopie2
authoralwin <alwin>2004-04-15 16:16:47 (UTC)
committer alwin <alwin>2004-04-15 16:16:47 (UTC)
commitaa0fce09fc2df5427c43b6a5f0539e725aad2828 (patch) (unidiff)
treeee9cd98bed9222fa994d89cab76a2f515b2cd45b /libopie2
parenta002be54e33d64e69c7edf2960d5e68a9a0609e4 (diff)
downloadopie-aa0fce09fc2df5427c43b6a5f0539e725aad2828.zip
opie-aa0fce09fc2df5427c43b6a5f0539e725aad2828.tar.gz
opie-aa0fce09fc2df5427c43b6a5f0539e725aad2828.tar.bz2
hopefull better repainting when switching the image while view is
visible
Diffstat (limited to 'libopie2') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiemm/oimagescrollview.cpp30
1 files changed, 11 insertions, 19 deletions
diff --git a/libopie2/opiemm/oimagescrollview.cpp b/libopie2/opiemm/oimagescrollview.cpp
index 68b06af..30a8fba 100644
--- a/libopie2/opiemm/oimagescrollview.cpp
+++ b/libopie2/opiemm/oimagescrollview.cpp
@@ -35,178 +35,180 @@ OImageScrollView::OImageScrollView( QWidget* parent, const char* name, WFlags f
35 init(); 35 init();
36} 36}
37 37
38OImageScrollView::OImageScrollView (const QImage&img, QWidget * parent, const char * name, WFlags f,bool always_scale,bool rfit) 38OImageScrollView::OImageScrollView (const QImage&img, QWidget * parent, const char * name, WFlags f,bool always_scale,bool rfit)
39 :QScrollView(parent,name,f|Qt::WRepaintNoErase),_image_data(),_original_data(img), 39 :QScrollView(parent,name,f|Qt::WRepaintNoErase),_image_data(),_original_data(img),
40 m_states(SCROLLVIEW_BITSET_SIZE),m_lastName("") 40 m_states(SCROLLVIEW_BITSET_SIZE),m_lastName("")
41{ 41{
42 _zoomer = 0; 42 _zoomer = 0;
43 m_states[AUTO_SCALE]=always_scale; 43 m_states[AUTO_SCALE]=always_scale;
44 m_states[AUTO_ROTATE]=rfit; 44 m_states[AUTO_ROTATE]=rfit;
45 m_states[FIRST_RESIZE_DONE]=false; 45 m_states[FIRST_RESIZE_DONE]=false;
46 m_states[IMAGE_IS_JPEG]=false; 46 m_states[IMAGE_IS_JPEG]=false;
47 m_states[IMAGE_SCALED_LOADED]=false; 47 m_states[IMAGE_SCALED_LOADED]=false;
48 m_states[SHOW_ZOOMER]=true; 48 m_states[SHOW_ZOOMER]=true;
49 _original_data.convertDepth(QPixmap::defaultDepth()); 49 _original_data.convertDepth(QPixmap::defaultDepth());
50 _original_data.setAlphaBuffer(false); 50 _original_data.setAlphaBuffer(false);
51 init(); 51 init();
52} 52}
53 53
54OImageScrollView::OImageScrollView (const QString&img, QWidget * parent, const char * name, WFlags f,bool always_scale,bool rfit) 54OImageScrollView::OImageScrollView (const QString&img, QWidget * parent, const char * name, WFlags f,bool always_scale,bool rfit)
55 :QScrollView(parent,name,f|Qt::WRepaintNoErase),_image_data(),_original_data(),m_states(SCROLLVIEW_BITSET_SIZE),m_lastName("") 55 :QScrollView(parent,name,f|Qt::WRepaintNoErase),_image_data(),_original_data(),m_states(SCROLLVIEW_BITSET_SIZE),m_lastName("")
56{ 56{
57 _zoomer = 0; 57 _zoomer = 0;
58 m_states.resize(SCROLLVIEW_BITSET_SIZE); 58 m_states.resize(SCROLLVIEW_BITSET_SIZE);
59 m_states[AUTO_SCALE]=always_scale; 59 m_states[AUTO_SCALE]=always_scale;
60 m_states[AUTO_ROTATE]=rfit; 60 m_states[AUTO_ROTATE]=rfit;
61 m_states[FIRST_RESIZE_DONE]=false; 61 m_states[FIRST_RESIZE_DONE]=false;
62 m_states[IMAGE_IS_JPEG]=false; 62 m_states[IMAGE_IS_JPEG]=false;
63 m_states[IMAGE_SCALED_LOADED]=false; 63 m_states[IMAGE_SCALED_LOADED]=false;
64 m_states[SHOW_ZOOMER]=true; 64 m_states[SHOW_ZOOMER]=true;
65 init(); 65 init();
66 setImage(img); 66 setImage(img);
67} 67}
68 68
69void OImageScrollView::setImage(const QImage&img) 69void OImageScrollView::setImage(const QImage&img)
70{ 70{
71 _image_data = QImage(); 71 _image_data = QImage();
72 _original_data=img; 72 _original_data=img;
73 _original_data.convertDepth(QPixmap::defaultDepth()); 73 _original_data.convertDepth(QPixmap::defaultDepth());
74 _original_data.setAlphaBuffer(false); 74 _original_data.setAlphaBuffer(false);
75 m_lastName = ""; 75 m_lastName = "";
76 setImageIsJpeg(false); 76 setImageIsJpeg(false);
77 setImageScaledLoaded(false); 77 setImageScaledLoaded(false);
78 if (FirstResizeDone()) { 78 if (FirstResizeDone()) {
79 generateImage(); 79 generateImage();
80 } 80 }
81} 81}
82 82
83void OImageScrollView::loadJpeg(bool interncall) 83void OImageScrollView::loadJpeg(bool interncall)
84{ 84{
85 if (m_lastName.isEmpty()) return; 85 if (m_lastName.isEmpty()) return;
86 QImageIO iio( m_lastName, 0l ); 86 QImageIO iio( m_lastName, 0l );
87 QString param; 87 QString param;
88 bool real_load = false; 88 bool real_load = false;
89 if (AutoScale()) { 89 if (AutoScale()) {
90 if (!interncall) { 90 if (!interncall) {
91 int wid, hei; 91 int wid, hei;
92 wid = QApplication::desktop()->width(); 92 wid = QApplication::desktop()->width();
93 hei = QApplication::desktop()->height(); 93 hei = QApplication::desktop()->height();
94 if (hei>wid) { 94 if (hei>wid) {
95 wid = hei; 95 wid = hei;
96 } else { 96 } else {
97 hei = wid; 97 hei = wid;
98 } 98 }
99 param = QString( "Fast Shrink( 3 ) Scale( %1, %2, ScaleFree)" ).arg( wid ).arg( hei ); 99 param = QString( "Fast Shrink( 3 ) Scale( %1, %2, ScaleMin)" ).arg( wid ).arg( hei );
100 odebug << "Load jpeg scaled \"" << param << "\"" << oendl; 100 odebug << "Load jpeg scaled \"" << param << "\"" << oendl;
101 iio.setParameters(param.latin1()); 101 iio.setParameters(param.latin1());
102 setImageScaledLoaded(true); 102 setImageScaledLoaded(true);
103 real_load = true; 103 real_load = true;
104 } 104 }
105 } else { 105 } else {
106 if (ImageScaledLoaded()||!interncall) { 106 if (ImageScaledLoaded()||!interncall) {
107 odebug << "Load jpeg unscaled" << oendl; 107 odebug << "Load jpeg unscaled" << oendl;
108 real_load = true; 108 real_load = true;
109 } 109 }
110 setImageScaledLoaded(false); 110 setImageScaledLoaded(false);
111 } 111 }
112 if (real_load) { 112 if (real_load) {
113 { 113 {
114 QCopEnvelope( "QPE/System", "busy()" ); 114 QCopEnvelope( "QPE/System", "busy()" );
115 } 115 }
116 _original_data = iio.read() ? iio.image() : QImage(); 116 _original_data = iio.read() ? iio.image() : QImage();
117 { 117 {
118 QCopEnvelope env( "QPE/System", "notBusy(QString)" ); 118 QCopEnvelope env( "QPE/System", "notBusy(QString)" );
119 env << "Image loaded"; 119 env << "Image loaded";
120 } 120 }
121 } 121 }
122} 122}
123 123
124void OImageScrollView::setImage( const QString& path ) { 124void OImageScrollView::setImage( const QString& path ) {
125 odebug << "load new image " << oendl; 125 odebug << "load new image " << oendl;
126 if (m_lastName == path) return; 126 if (m_lastName == path) return;
127 m_lastName = path; 127 m_lastName = path;
128 _original_data = QImage();
128 QString itype = QImage::imageFormat(m_lastName); 129 QString itype = QImage::imageFormat(m_lastName);
129 odebug << "Image type = " << itype << oendl; 130 odebug << "Image type = " << itype << oendl;
130 if (itype == "JPEG") { 131 if (itype == "JPEG") {
131 setImageIsJpeg(true); 132 setImageIsJpeg(true);
132 loadJpeg(); 133 loadJpeg();
133 } else { 134 } else {
134 { 135 {
135 QCopEnvelope( "QPE/System", "busy()" ); 136 QCopEnvelope( "QPE/System", "busy()" );
136 } 137 }
137 setImageIsJpeg(false); 138 setImageIsJpeg(false);
138 _original_data.load(path); 139 _original_data.load(path);
139 _original_data.convertDepth(QPixmap::defaultDepth()); 140 _original_data.convertDepth(QPixmap::defaultDepth());
140 _original_data.setAlphaBuffer(false); 141 _original_data.setAlphaBuffer(false);
141 { 142 {
142 QCopEnvelope env( "QPE/System", "notBusy(QString)" ); 143 QCopEnvelope env( "QPE/System", "notBusy(QString)" );
143 env << "Image loaded"; 144 env << "Image loaded";
144 } 145 }
145 } 146 }
146 _image_data = QImage(); 147 _image_data = QImage();
147 if (FirstResizeDone()) { 148 if (FirstResizeDone()) {
148 generateImage(); 149 generateImage();
150 if (isVisible()) viewport()->repaint(true);
149 } 151 }
150} 152}
151 153
152/* should be called every time the QImage changed it content */ 154/* should be called every time the QImage changed it content */
153void OImageScrollView::init() 155void OImageScrollView::init()
154{ 156{
155 odebug << "init " << oendl; 157 odebug << "init " << oendl;
156 158
157 /* 159 /*
158 * create the zoomer 160 * create the zoomer
159 * and connect ther various signals 161 * and connect ther various signals
160 */ 162 */
161 _zoomer = new Opie::MM::OImageZoomer( this, "The Zoomer" ); 163 _zoomer = new Opie::MM::OImageZoomer( this, "The Zoomer" );
162 connect(_zoomer, SIGNAL( zoomAreaRel(int,int)), 164 connect(_zoomer, SIGNAL( zoomAreaRel(int,int)),
163 this, SLOT(scrollBy(int,int)) ); 165 this, SLOT(scrollBy(int,int)) );
164 connect(_zoomer, SIGNAL( zoomArea(int,int)), 166 connect(_zoomer, SIGNAL( zoomArea(int,int)),
165 this, SLOT(center(int,int)) ); 167 this, SLOT(center(int,int)) );
166 connect(this,SIGNAL(contentsMoving(int,int)), 168 connect(this,SIGNAL(contentsMoving(int,int)),
167 _zoomer, (SLOT(setVisiblePoint(int,int))) ); 169 _zoomer, (SLOT(setVisiblePoint(int,int))) );
168 connect(this,SIGNAL(imageSizeChanged(const QSize&)), 170 connect(this,SIGNAL(imageSizeChanged(const QSize&)),
169 _zoomer, SLOT(setImageSize(const QSize&)) ); 171 _zoomer, SLOT(setImageSize(const QSize&)) );
170 connect(this,SIGNAL(viewportSizeChanged(const QSize&)), 172 connect(this,SIGNAL(viewportSizeChanged(const QSize&)),
171 _zoomer, SLOT(setViewPortSize(const QSize&)) ); 173 _zoomer, SLOT(setViewPortSize(const QSize&)) );
172 174
173 viewport()->setBackgroundColor(white); 175 viewport()->setBackgroundColor(white);
174 setFocusPolicy(QWidget::StrongFocus); 176 setFocusPolicy(QWidget::StrongFocus);
175 setImageScaledLoaded(false); 177 setImageScaledLoaded(false);
176 setImageIsJpeg(false); 178 setImageIsJpeg(false);
177 if (FirstResizeDone()) { 179 if (FirstResizeDone()) {
178 m_last_rot = Rotate0; 180 m_last_rot = Rotate0;
179 generateImage(); 181 generateImage();
180 } else if (_original_data.size().isValid()) { 182 } else if (_original_data.size().isValid()) {
181 if (image_fit_into(_original_data.size()) || !ShowZoomer()) _zoomer->hide(); 183 if (image_fit_into(_original_data.size()) || !ShowZoomer()) _zoomer->hide();
182 resizeContents(_original_data.width(),_original_data.height()); 184 resizeContents(_original_data.width(),_original_data.height());
183 } 185 }
184} 186}
185 187
186void OImageScrollView::setAutoRotate(bool how) 188void OImageScrollView::setAutoRotate(bool how)
187{ 189{
188 /* to avoid double repaints */ 190 /* to avoid double repaints */
189 if (AutoRotate() != how) { 191 if (AutoRotate() != how) {
190 m_states.setBit(AUTO_ROTATE,how); 192 m_states.setBit(AUTO_ROTATE,how);
191 _image_data = QImage(); 193 _image_data = QImage();
192 generateImage(); 194 generateImage();
193 } 195 }
194} 196}
195 197
196bool OImageScrollView::AutoRotate()const 198bool OImageScrollView::AutoRotate()const
197{ 199{
198 return m_states.testBit(AUTO_ROTATE); 200 return m_states.testBit(AUTO_ROTATE);
199} 201}
200 202
201void OImageScrollView::setAutoScale(bool how) 203void OImageScrollView::setAutoScale(bool how)
202{ 204{
203 m_states.setBit(AUTO_SCALE,how); 205 m_states.setBit(AUTO_SCALE,how);
204 if (!how) { 206 if (!how) {
205 setAutoRotate(false); 207 setAutoRotate(false);
206 } 208 }
207 _image_data = QImage(); 209 _image_data = QImage();
208 if (ImageIsJpeg() && how == false && ImageScaledLoaded()==true) { 210 if (ImageIsJpeg() && how == false && ImageScaledLoaded()==true) {
209 loadJpeg(true); 211 loadJpeg(true);
210 } 212 }
211 generateImage(); 213 generateImage();
212} 214}
@@ -289,274 +291,264 @@ void OImageScrollView::rotate_into_data(Rotation r)
289 unsigned int *srcTable, *destTable; 291 unsigned int *srcTable, *destTable;
290 switch ( r ) 292 switch ( r )
291 { 293 {
292 case Rotate90: 294 case Rotate90:
293 dest.create(_original_data.height(), _original_data.width(), _original_data.depth()); 295 dest.create(_original_data.height(), _original_data.width(), _original_data.depth());
294 dest.setNumColors(_original_data.numColors()); 296 dest.setNumColors(_original_data.numColors());
295 srcTable = (unsigned int *)_original_data.colorTable(); 297 srcTable = (unsigned int *)_original_data.colorTable();
296 destTable = (unsigned int *)dest.colorTable(); 298 destTable = (unsigned int *)dest.colorTable();
297 for ( x=0; x < _original_data.numColors(); ++x ) 299 for ( x=0; x < _original_data.numColors(); ++x )
298 destTable[x] = srcTable[x]; 300 destTable[x] = srcTable[x];
299 for ( y=0; y < _original_data.height(); ++y ) 301 for ( y=0; y < _original_data.height(); ++y )
300 { 302 {
301 srcData = (unsigned char *)_original_data.scanLine(y); 303 srcData = (unsigned char *)_original_data.scanLine(y);
302 for ( x=0; x < _original_data.width(); ++x ) 304 for ( x=0; x < _original_data.width(); ++x )
303 { 305 {
304 destData = (unsigned char *)dest.scanLine(x); 306 destData = (unsigned char *)dest.scanLine(x);
305 destData[_original_data.height()-y-1] = srcData[x]; 307 destData[_original_data.height()-y-1] = srcData[x];
306 } 308 }
307 } 309 }
308 break; 310 break;
309 case Rotate180: 311 case Rotate180:
310 dest.create(_original_data.width(), _original_data.height(), _original_data.depth()); 312 dest.create(_original_data.width(), _original_data.height(), _original_data.depth());
311 dest.setNumColors(_original_data.numColors()); 313 dest.setNumColors(_original_data.numColors());
312 srcTable = (unsigned int *)_original_data.colorTable(); 314 srcTable = (unsigned int *)_original_data.colorTable();
313 destTable = (unsigned int *)dest.colorTable(); 315 destTable = (unsigned int *)dest.colorTable();
314 for ( x=0; x < _original_data.numColors(); ++x ) 316 for ( x=0; x < _original_data.numColors(); ++x )
315 destTable[x] = srcTable[x]; 317 destTable[x] = srcTable[x];
316 for ( y=0; y < _original_data.height(); ++y ) 318 for ( y=0; y < _original_data.height(); ++y )
317 { 319 {
318 srcData = (unsigned char *)_original_data.scanLine(y); 320 srcData = (unsigned char *)_original_data.scanLine(y);
319 destData = (unsigned char *)dest.scanLine(_original_data.height()-y-1); 321 destData = (unsigned char *)dest.scanLine(_original_data.height()-y-1);
320 for ( x=0; x < _original_data.width(); ++x ) 322 for ( x=0; x < _original_data.width(); ++x )
321 destData[_original_data.width()-x-1] = srcData[x]; 323 destData[_original_data.width()-x-1] = srcData[x];
322 } 324 }
323 break; 325 break;
324 case Rotate270: 326 case Rotate270:
325 dest.create(_original_data.height(), _original_data.width(), _original_data.depth()); 327 dest.create(_original_data.height(), _original_data.width(), _original_data.depth());
326 dest.setNumColors(_original_data.numColors()); 328 dest.setNumColors(_original_data.numColors());
327 srcTable = (unsigned int *)_original_data.colorTable(); 329 srcTable = (unsigned int *)_original_data.colorTable();
328 destTable = (unsigned int *)dest.colorTable(); 330 destTable = (unsigned int *)dest.colorTable();
329 for ( x=0; x < _original_data.numColors(); ++x ) 331 for ( x=0; x < _original_data.numColors(); ++x )
330 destTable[x] = srcTable[x]; 332 destTable[x] = srcTable[x];
331 for ( y=0; y < _original_data.height(); ++y ) 333 for ( y=0; y < _original_data.height(); ++y )
332 { 334 {
333 srcData = (unsigned char *)_original_data.scanLine(y); 335 srcData = (unsigned char *)_original_data.scanLine(y);
334 for ( x=0; x < _original_data.width(); ++x ) 336 for ( x=0; x < _original_data.width(); ++x )
335 { 337 {
336 destData = (unsigned char *)dest.scanLine(_original_data.width()-x-1); 338 destData = (unsigned char *)dest.scanLine(_original_data.width()-x-1);
337 destData[y] = srcData[x]; 339 destData[y] = srcData[x];
338 } 340 }
339 } 341 }
340 break; 342 break;
341 default: 343 default:
342 dest = _original_data; 344 dest = _original_data;
343 break; 345 break;
344 } 346 }
345 347
346 } 348 }
347 _image_data = dest; 349 _image_data = dest;
348} 350}
349 351
350void OImageScrollView::generateImage() 352void OImageScrollView::generateImage()
351{ 353{
352 Rotation r = Rotate0; 354 Rotation r = Rotate0;
353 if (_original_data.isNull()) return; 355 _pdata = QPixmap();
356 if (_original_data.isNull()) {
357 emit imageSizeChanged( _image_data.size() );
358 if (_zoomer) _zoomer->setImage( _image_data );
359 return;
360 }
354 { 361 {
355 QCopEnvelope( "QPE/System", "busy()" ); 362 QCopEnvelope( "QPE/System", "busy()" );
356 } 363 }
357 if (width()>height()&&_original_data.width()<_original_data.height() || 364 if (width()>height()&&_original_data.width()<_original_data.height() ||
358 width()<height()&&_original_data.width()>_original_data.height()) { 365 width()<height()&&_original_data.width()>_original_data.height()) {
359 if (AutoRotate()) r = Rotate90; 366 if (AutoRotate()) r = Rotate90;
360 } 367 }
361 368
369
362 odebug << " r = " << r << oendl; 370 odebug << " r = " << r << oendl;
363 if (AutoScale()) { 371 if (AutoScale() && (_original_data.width()>width() || _original_data.height() > height()) ) {
364 if (!_image_data.size().isValid()||width()>_image_data.width()||height()>_image_data.height()) { 372 if (!_image_data.size().isValid()||width()>_image_data.width()||height()>_image_data.height()) {
365 odebug << "Rescaling data" << oendl; 373 odebug << "Rescaling data" << oendl;
366 if (r==Rotate0) { 374 if (r==Rotate0) {
367 _image_data = _original_data; 375 _image_data = _original_data;
368 } else { 376 } else {
369 rotate_into_data(r); 377 rotate_into_data(r);
370 } 378 }
371 } 379 }
372 rescaleImage(width(),height()); 380 rescaleImage(width(),height());
373 resizeContents(_image_data.width(),_image_data.height()); 381 resizeContents(_image_data.width(),_image_data.height());
374 } else if (!FirstResizeDone()||r!=m_last_rot||_image_data.width()==0) { 382 } else if (!FirstResizeDone()||r!=m_last_rot||_image_data.width()==0) {
375 if (r==Rotate0) { 383 if (r==Rotate0) {
376 _image_data = _original_data; 384 _image_data = _original_data;
377 } else { 385 } else {
378 rotate_into_data(r); 386 rotate_into_data(r);
379 } 387 }
380 m_last_rot = r; 388 m_last_rot = r;
381 resizeContents(_image_data.width(),_image_data.height()); 389 resizeContents(_image_data.width(),_image_data.height());
382 } 390 }
383 _pdata.convertFromImage(_image_data); 391 _pdata.convertFromImage(_image_data);
384 392
385
386 /* 393 /*
387 * update the zoomer 394 * update the zoomer
388 */ 395 */
389 check_zoomer(); 396 check_zoomer();
390 emit imageSizeChanged( _image_data.size() ); 397 emit imageSizeChanged( _image_data.size() );
391 rescaleImage( 128, 128 ); 398 rescaleImage( 128, 128 );
392 /* 399 /*
393 * move scrollbar 400 * move scrollbar
394 */ 401 */
395 if (_zoomer) { 402 if (_zoomer) {
396 _zoomer->setGeometry( viewport()->width()-_image_data.width()/2, viewport()->height()-_image_data.height()/2, 403 _zoomer->setGeometry( viewport()->width()-_image_data.width()/2, viewport()->height()-_image_data.height()/2,
397 _image_data.width()/2, _image_data.height()/2 ); 404 _image_data.width()/2, _image_data.height()/2 );
398 _zoomer->setImage( _image_data ); 405 _zoomer->setImage( _image_data );
399 } 406 }
400 /* 407 /*
401 * invalidate 408 * invalidate
402 */ 409 */
403 _image_data=QImage(); 410 _image_data=QImage();
404 { 411 {
405 QCopEnvelope env( "QPE/System", "notBusy(QString)" ); 412 QCopEnvelope env( "QPE/System", "notBusy(QString)" );
406 env << "Image generated"; 413 env << "Image generated";
407 } 414 }
408} 415}
409 416
410void OImageScrollView::resizeEvent(QResizeEvent * e) 417void OImageScrollView::resizeEvent(QResizeEvent * e)
411{ 418{
412 odebug << "OImageScrollView resizeEvent" << oendl; 419 odebug << "OImageScrollView resizeEvent" << oendl;
413 QScrollView::resizeEvent(e); 420 QScrollView::resizeEvent(e);
414 generateImage(); 421 generateImage();
415 setFirstResizeDone(true); 422 setFirstResizeDone(true);
416 emit viewportSizeChanged( viewport()->size() ); 423 emit viewportSizeChanged( viewport()->size() );
417 424
418} 425}
419 426
420void OImageScrollView::keyPressEvent(QKeyEvent * e) 427void OImageScrollView::keyPressEvent(QKeyEvent * e)
421{ 428{
422 if (!e) return; 429 if (!e) return;
423 int dx = horizontalScrollBar()->lineStep(); 430 int dx = horizontalScrollBar()->lineStep();
424 int dy = verticalScrollBar()->lineStep(); 431 int dy = verticalScrollBar()->lineStep();
425 if (e->key()==Qt::Key_Right) { 432 if (e->key()==Qt::Key_Right) {
426 scrollBy(dx,0); 433 scrollBy(dx,0);
427 e->accept(); 434 e->accept();
428 } else if (e->key()==Qt::Key_Left) { 435 } else if (e->key()==Qt::Key_Left) {
429 scrollBy(0-dx,0); 436 scrollBy(0-dx,0);
430 e->accept(); 437 e->accept();
431 } else if (e->key()==Qt::Key_Up) { 438 } else if (e->key()==Qt::Key_Up) {
432 scrollBy(0,0-dy); 439 scrollBy(0,0-dy);
433 e->accept(); 440 e->accept();
434 } else if (e->key()==Qt::Key_Down) { 441 } else if (e->key()==Qt::Key_Down) {
435 scrollBy(0,dy); 442 scrollBy(0,dy);
436 e->accept(); 443 e->accept();
437 } else { 444 } else {
438 e->ignore(); 445 e->ignore();
439 } 446 }
440 QScrollView::keyPressEvent(e); 447 QScrollView::keyPressEvent(e);
441} 448}
442 449
443void OImageScrollView::drawContents(QPainter * p, int clipx, int clipy, int clipw, int cliph) 450void OImageScrollView::drawContents(QPainter * p, int clipx, int clipy, int clipw, int cliph)
444{ 451{
445 int w = clipw; 452 int w = clipw;
446 int h = cliph; 453 int h = cliph;
447 int x = clipx; 454 int x = clipx;
448 int y = clipy; 455 int y = clipy;
449 bool erase = false; 456 bool erase = false;
450 457
451 if (!_pdata.size().isValid()) { 458 if (!_pdata.size().isValid()) {
452 p->fillRect(clipx,clipy,clipw,cliph,white); 459 p->fillRect(clipx,clipy,clipw,cliph,white);
453 return; 460 return;
454 } 461 }
455 if (w>_pdata.width()) { 462 if (w>_pdata.width()) {
456 w=_pdata.width(); 463 w=_pdata.width();
457 x = 0; 464 x = 0;
458 erase = true; 465 erase = true;
459 } else if (x+w>_pdata.width()){ 466 } else if (x+w>_pdata.width()){
460 x = _pdata.width()-w; 467 x = _pdata.width()-w;
461 } 468 }
462 if (h>_pdata.height()) { 469 if (h>_pdata.height()) {
463 h=_pdata.height(); 470 h=_pdata.height();
464 y = 0; 471 y = 0;
465 erase = true; 472 erase = true;
466 } else if (y+h>_pdata.height()){ 473 } else if (y+h>_pdata.height()){
467 y = _pdata.height()-h; 474 y = _pdata.height()-h;
468 } 475 }
469 if (erase||_original_data.hasAlphaBuffer()) { 476 if (erase||_original_data.hasAlphaBuffer()) {
470 p->fillRect(clipx,clipy,clipw,cliph,white); 477 p->fillRect(clipx,clipy,clipw,cliph,white);
471 } 478 }
472 p->drawPixmap(clipx,clipy,_pdata,x,y,w,h); 479 p->drawPixmap(clipx,clipy,_pdata,x,y,w,h);
473} 480}
474 481
475/* using the real geometry points and not the translated points is wanted! */ 482/* using the real geometry points and not the translated points is wanted! */
476void OImageScrollView::viewportMouseMoveEvent(QMouseEvent* e) 483void OImageScrollView::viewportMouseMoveEvent(QMouseEvent* e)
477{ 484{
478 odebug << "Move X and Y " << e->x() << " " << e->y() << oendl;
479 int mx, my; 485 int mx, my;
480 mx = e->x(); 486 mx = e->x();
481 my = e->y(); 487 my = e->y();
482 if (_mouseStartPosX!=-1 && _mouseStartPosY!=-1) { 488 if (_mouseStartPosX!=-1 && _mouseStartPosY!=-1) {
483 int diffx = _mouseStartPosX-mx; 489 int diffx = _mouseStartPosX-mx;
484 int diffy = _mouseStartPosY-my; 490 int diffy = _mouseStartPosY-my;
485#if 0
486 QScrollBar*xbar = horizontalScrollBar();
487 QScrollBar*ybar = verticalScrollBar();
488 if (xbar->value()+diffx>xbar->maxValue()) {
489 diffx = xbar->maxValue()-xbar->value();
490 } else if (xbar->value()+diffx<0) {
491 diffx=0-xbar->value();
492 }
493 if (ybar->value()+diffy>ybar->maxValue()) {
494 diffy = ybar->maxValue()-ybar->value();
495 } else if (ybar->value()+diffy<0) {
496 diffy=0-ybar->value();
497 }
498#endif
499 scrollBy(diffx,diffy); 491 scrollBy(diffx,diffy);
500 } 492 }
501 _mouseStartPosX=mx; 493 _mouseStartPosX=mx;
502 _mouseStartPosY=my; 494 _mouseStartPosY=my;
503} 495}
504 496
505void OImageScrollView::contentsMousePressEvent ( QMouseEvent * e) 497void OImageScrollView::contentsMousePressEvent ( QMouseEvent * e)
506{ 498{
507 odebug << " X and Y " << e->x() << " " << e->y() << oendl; 499 odebug << " X and Y " << e->x() << " " << e->y() << oendl;
508 /* this marks the beginning of a possible mouse move. Due internal reasons of QT 500 /* this marks the beginning of a possible mouse move. Due internal reasons of QT
509 the geometry values here may real differ from that set in MoveEvent (I don't know 501 the geometry values here may real differ from that set in MoveEvent (I don't know
510 why). For getting them in real context, we use the first move-event to set the start 502 why). For getting them in real context, we use the first move-event to set the start
511 position ;) 503 position ;)
512 */ 504 */
513 _mouseStartPosX = -1; 505 _mouseStartPosX = -1;
514 _mouseStartPosY = -1; 506 _mouseStartPosY = -1;
515} 507}
516 508
517void OImageScrollView::setDestructiveClose() { 509void OImageScrollView::setDestructiveClose() {
518 WFlags fl = getWFlags(); 510 WFlags fl = getWFlags();
519 /* clear it just in case */ 511 /* clear it just in case */
520 fl &= ~WDestructiveClose; 512 fl &= ~WDestructiveClose;
521 fl |= WDestructiveClose; 513 fl |= WDestructiveClose;
522 setWFlags( fl ); 514 setWFlags( fl );
523} 515}
524 516
525bool OImageScrollView::image_fit_into(const QSize&s ) 517bool OImageScrollView::image_fit_into(const QSize&s )
526{ 518{
527 if (s.width()>width()||s.height()>height()) { 519 if (s.width()>width()||s.height()>height()) {
528 return false; 520 return false;
529 } 521 }
530 return true; 522 return true;
531} 523}
532 524
533void OImageScrollView::setShowZoomer(bool how) 525void OImageScrollView::setShowZoomer(bool how)
534{ 526{
535 m_states.setBit(SHOW_ZOOMER,how); 527 m_states.setBit(SHOW_ZOOMER,how);
536 check_zoomer(); 528 check_zoomer();
537} 529}
538 530
539bool OImageScrollView::ShowZoomer()const 531bool OImageScrollView::ShowZoomer()const
540{ 532{
541 return m_states.testBit(SHOW_ZOOMER); 533 return m_states.testBit(SHOW_ZOOMER);
542} 534}
543 535
544void OImageScrollView::check_zoomer() 536void OImageScrollView::check_zoomer()
545{ 537{
546 if (!_zoomer) return; 538 if (!_zoomer) return;
547 if ( (!ShowZoomer()||image_fit_into(_pdata.size()) ) && _zoomer->isVisible()) { 539 if ( (!ShowZoomer()||image_fit_into(_pdata.size()) ) && _zoomer->isVisible()) {
548 _zoomer->hide(); 540 _zoomer->hide();
549 } else if ( ShowZoomer() && !image_fit_into(_pdata.size()) && _zoomer->isHidden()){ 541 } else if ( ShowZoomer() && !image_fit_into(_pdata.size()) && _zoomer->isHidden()){
550 _zoomer->show(); 542 _zoomer->show();
551 } 543 }
552} 544}
553 545
554bool OImageScrollView::FirstResizeDone()const 546bool OImageScrollView::FirstResizeDone()const
555{ 547{
556 return m_states.testBit(FIRST_RESIZE_DONE); 548 return m_states.testBit(FIRST_RESIZE_DONE);
557} 549}
558 550
559void OImageScrollView::setFirstResizeDone(bool how) 551void OImageScrollView::setFirstResizeDone(bool how)
560{ 552{
561 m_states.setBit(FIRST_RESIZE_DONE,how); 553 m_states.setBit(FIRST_RESIZE_DONE,how);
562} 554}