-rw-r--r-- | libopie/oticker.cpp | 25 |
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 @@ -79,5 +79,20 @@ void OTicker::setText( const QString& text ) { scrollText = text; - - int pixelLen = fontMetrics().width( text ); - QPixmap pm( pixelLen, contentsRect().height() ); +qDebug(scrollText); + + int pixelLen = 0; + bool bigger = false; + int contWidth = contentsRect().width(); + int contHeight = contentsRect().height(); + int pixelTextLen = fontMetrics().width( text ); + printf("<<<<<<<height %d, width %d, text width %d %d\n", contHeight, contWidth, pixelTextLen, scrollText.length()); + if( pixelTextLen < contWidth) + { + pixelLen = contWidth; + } + else + { + bigger = true; + pixelLen = pixelTextLen; + } + QPixmap pm( pixelLen, contHeight); // pm.fill( QColor( 167, 212, 167 )); @@ -87,3 +102,3 @@ void OTicker::setText( const QString& text ) { pmp.setPen(foregroundcolor ); - pmp.drawText( 0, 0, pixelLen, contentsRect().height(), AlignVCenter, scrollText ); + pmp.drawText( 0, 0, pixelTextLen, contHeight, AlignVCenter, scrollText ); pmp.end(); @@ -93,3 +108,3 @@ void OTicker::setText( const QString& text ) { // qDebug("Scrollupdate %d", updateTimerTime); - if ( pixelLen > contentsRect().width() ) + if ( bigger /*pixelTextLen > contWidth*/ ) startTimer( updateTimerTime); |