summaryrefslogtreecommitdiff
authorllornkcor <llornkcor>2003-02-16 20:23:42 (UTC)
committer llornkcor <llornkcor>2003-02-16 20:23:42 (UTC)
commitb24a37c7e412cdf49f5d93c8ab51786b6cda24fb (patch) (unidiff)
tree3a4240d95dd2d2055a963e7a70703b69b19eb604
parent0a64464dc16e6167402590ea8c30d9d56d9e5c3f (diff)
downloadopie-b24a37c7e412cdf49f5d93c8ab51786b6cda24fb.zip
opie-b24a37c7e412cdf49f5d93c8ab51786b6cda24fb.tar.gz
opie-b24a37c7e412cdf49f5d93c8ab51786b6cda24fb.tar.bz2
attempt to fix bug. please test
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--libopie/oticker.cpp25
1 files changed, 20 insertions, 5 deletions
diff --git a/libopie/oticker.cpp b/libopie/oticker.cpp
index 6cd0dc8..9a7044d 100644
--- a/libopie/oticker.cpp
+++ b/libopie/oticker.cpp
@@ -77,21 +77,36 @@ void OTicker::setFrame(int frameStyle) {
77void OTicker::setText( const QString& text ) { 77void OTicker::setText( const QString& text ) {
78 pos = 0; // reset it everytime the text is changed 78 pos = 0; // reset it everytime the text is changed
79 scrollText = text; 79 scrollText = text;
80 80qDebug(scrollText);
81 int pixelLen = fontMetrics().width( text ); 81
82 QPixmap pm( pixelLen, contentsRect().height() ); 82 int pixelLen = 0;
83 bool bigger = false;
84 int contWidth = contentsRect().width();
85 int contHeight = contentsRect().height();
86 int pixelTextLen = fontMetrics().width( text );
87 printf("<<<<<<<height %d, width %d, text width %d %d\n", contHeight, contWidth, pixelTextLen, scrollText.length());
88 if( pixelTextLen < contWidth)
89 {
90 pixelLen = contWidth;
91 }
92 else
93 {
94 bigger = true;
95 pixelLen = pixelTextLen;
96 }
97 QPixmap pm( pixelLen, contHeight);
83// pm.fill( QColor( 167, 212, 167 )); 98// pm.fill( QColor( 167, 212, 167 ));
84 99
85 pm.fill(backgroundcolor); 100 pm.fill(backgroundcolor);
86 QPainter pmp( &pm ); 101 QPainter pmp( &pm );
87 pmp.setPen(foregroundcolor ); 102 pmp.setPen(foregroundcolor );
88 pmp.drawText( 0, 0, pixelLen, contentsRect().height(), AlignVCenter, scrollText ); 103 pmp.drawText( 0, 0, pixelTextLen, contHeight, AlignVCenter, scrollText );
89 pmp.end(); 104 pmp.end();
90 scrollTextPixmap = pm; 105 scrollTextPixmap = pm;
91 106
92 killTimers(); 107 killTimers();
93 // qDebug("Scrollupdate %d", updateTimerTime); 108 // qDebug("Scrollupdate %d", updateTimerTime);
94 if ( pixelLen > contentsRect().width() ) 109 if ( bigger /*pixelTextLen > contWidth*/ )
95 startTimer( updateTimerTime); 110 startTimer( updateTimerTime);
96 update(); 111 update();
97} 112}