From 88539c74ca4a6b6699df2b050a498a81d22a0793 Mon Sep 17 00:00:00 2001 From: llornkcor Date: Sun, 03 Nov 2002 19:44:54 +0000 Subject: add oticker --- diff --git a/libopie/libopie.pro b/libopie/libopie.pro index f46a0b2..1787039 100644 --- a/libopie/libopie.pro +++ b/libopie/libopie.pro @@ -27,31 +27,33 @@ HEADERS = ofontmenu.h \ pim/otodoaccessvcal.h \ pim/orecur.h \ pim/opimstate.h \ - orecurrancewidget.h + orecurrancewidget.h \ + oticker.h # pim/otodoaccesssql.h \ SOURCES = ofontmenu.cc \ ocolorbutton.cpp \ - xmltree.cc \ - ofiledialog.cc ofileselector.cc \ + xmltree.cc \ + ofiledialog.cc ofileselector.cc \ ocheckitem.cpp tododb.cpp todoevent.cpp \ - todovcalresource.cpp colordialog.cpp \ - colorpopupmenu.cpp oclickablelabel.cpp \ - oprocctrl.cpp oprocess.cpp \ - odevice.cpp otimepicker.cpp \ - otabwidget.cpp otabbar.cpp \ + todovcalresource.cpp colordialog.cpp \ + colorpopupmenu.cpp oclickablelabel.cpp \ + oprocctrl.cpp oprocess.cpp \ + odevice.cpp otimepicker.cpp \ + otabwidget.cpp otabbar.cpp \ ofontselector.cpp \ pim/otodo.cpp \ pim/opimrecord.cpp \ - pim/otodoaccess.cpp \ - pim/otodoaccessbackend.cpp \ + pim/otodoaccess.cpp \ + pim/otodoaccessbackend.cpp \ pim/otodoaccessxml.cpp \ pim/ocontact.cpp \ pim/ocontactaccess.cpp \ - pim/otodoaccessvcal.cpp \ - pim/orecur.cpp \ - pim/opimstate.cpp \ - orecurrancewidget.cpp + pim/otodoaccessvcal.cpp \ + pim/orecur.cpp \ + pim/opimstate.cpp \ + orecurrancewidget.cpp \ + oticker.cpp # pim/otodoaccesssql.cpp \ TARGET = opie diff --git a/libopie/oticker.cpp b/libopie/oticker.cpp new file mode 100644 index 0000000..774a49d --- a/dev/null +++ b/libopie/oticker.cpp @@ -0,0 +1,94 @@ +/* +                This file is part of the Opie Project + Copyright (c) 2002 L. Potter + =. + .=l. +           .>+-= + _;:,     .>    :=|. This program is free software; you can +.> <`_,   >  .   <= redistribute it and/or modify it under +:`=1 )Y*s>-.--   : the terms of the GNU General Public +.="- .-=="i,     .._ License as published by the Free Software + - .   .-<_>     .<> Foundation; either version 2 of the License, +     ._= =}       : or (at your option) any later version. +    .%`+i>       _;_. +    .i_,=:_.      -`: PARTICULAR PURPOSE. See the GNU +..}^=.=       =       ; Library General Public License for more +++=   -.     .`     .: details. + :     =  ...= . :.=- + -.   .:....=;==+<; You should have received a copy of the GNU +  -_. . .   )=.  = Library General Public License along with +    --        :-=` this library; see the file COPYING.LIB. + If not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. + +*/ + +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "oticker.h" + +OTicker::OTicker( QWidget* parent=0 ) : QFrame( parent ) { + setFrameStyle( NoFrame/*WinPanel | Sunken */); +} + +OTicker::~OTicker() { +} + +void OTicker::setText( const QString& text ) { + Config cfg("qpe"); + cfg.setGroup("Appearance"); + + pos = 0; // reset it everytime the text is changed + scrollText = text; + + int pixelLen = fontMetrics().width( text ); + QPixmap pm( pixelLen, contentsRect().height() ); +// pm.fill( QColor( 167, 212, 167 )); + + pm.fill( QColor( cfg.readEntry( "Background", "#E5E1D5" ) )); + QPainter pmp( &pm ); + pmp.setPen( Qt::black ); + pmp.drawText( 0, 0, pixelLen, contentsRect().height(), AlignVCenter, scrollText ); + pmp.end(); + scrollTextPixmap = pm; + + killTimers(); + if ( pixelLen > contentsRect().width() ) + startTimer( 50 ); + update(); +} + + +void OTicker::timerEvent( QTimerEvent * ) { + pos = ( pos <= 0 ) ? scrollTextPixmap.width() : pos - 1; + repaint( FALSE ); +} + +void OTicker::drawContents( QPainter *p ) { + int pixelLen = scrollTextPixmap.width(); + p->drawPixmap( pos, contentsRect().y(), scrollTextPixmap ); + if ( pixelLen > contentsRect().width() ) // Scrolling + p->drawPixmap( pos - pixelLen, contentsRect().y(), scrollTextPixmap ); +} + +void OTicker::mouseReleaseEvent( QMouseEvent * e) { +// qDebug("<<<<<<<>>>>>>>>>"); + emit mousePressed(); +} diff --git a/libopie/oticker.h b/libopie/oticker.h new file mode 100644 index 0000000..4f0ed11 --- a/dev/null +++ b/libopie/oticker.h @@ -0,0 +1,32 @@ +#ifndef OTICKER_H +#define OTICKER_H + +#include +#include +#include +#include +#include +#include +#include +#include + +class OTicker : public QFrame { + Q_OBJECT + +public: + OTicker( QWidget* parent=0 ); + ~OTicker(); + void setText( const QString& text ) ; +signals: + void mousePressed(); +protected: + void timerEvent( QTimerEvent * ); + void drawContents( QPainter *p ); + void mouseReleaseEvent ( QMouseEvent *); +private: + QString scrollText; + QPixmap scrollTextPixmap; + int pos;//, pixelLen; +}; + +#endif -- cgit v0.9.0.2