-rw-r--r-- | noncore/multimedia/opieplayer2/mediaplayer.cpp | 106 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/xinecontrol.cpp | 6 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/xinecontrol.h | 5 |
3 files changed, 85 insertions, 32 deletions
diff --git a/noncore/multimedia/opieplayer2/mediaplayer.cpp b/noncore/multimedia/opieplayer2/mediaplayer.cpp index a3238f0..51fbb8b 100644 --- a/noncore/multimedia/opieplayer2/mediaplayer.cpp +++ b/noncore/multimedia/opieplayer2/mediaplayer.cpp @@ -13,2 +13,3 @@ #include "audiowidget.h" +#include "videowidget.h" #include "volumecontrol.h" @@ -20,2 +21,3 @@ extern AudioWidget *audioUI; +extern VideoWidget *videoUI; extern PlayListWidget *playList; @@ -44,2 +46,7 @@ MediaPlayer::MediaPlayer( QObject *parent, const char *name ) + connect( videoUI, SIGNAL( moreClicked() ), this, SLOT( startIncreasingVolume() ) ); + connect( videoUI, SIGNAL( lessClicked() ), this, SLOT( startDecreasingVolume() ) ); + connect( videoUI, SIGNAL( moreReleased() ), this, SLOT( stopChangingVolume() ) ); + connect( videoUI, SIGNAL( lessReleased() ), this, SLOT( stopChangingVolume() ) ); + volControl = new VolumeControl; @@ -153,5 +160,13 @@ void MediaPlayer::stopChangingVolume() { onScreenDisplayVolume = 0; - int w = audioUI->width(); - int h = audioUI->height(); - audioUI->repaint( (w - 200) / 2, h - yoff, 200 + 9, 70, FALSE ); + int w=0; + int h=0; + if( !xineControl->hasVideo()) { + w = audioUI->width(); + h = audioUI->height(); + audioUI->repaint( (w - 200) / 2, h - yoff, 200 + 9, 70, FALSE ); + } else { + w = videoUI->width(); + h = videoUI->height(); + videoUI->repaint( (w - 200) / 2, h - yoff, 200 + 9, 70, FALSE ); + } } @@ -167,3 +182,3 @@ void MediaPlayer::timerEvent( QTimerEvent * ) { - // TODO FIXME + // TODO FIXME int v; @@ -172,33 +187,62 @@ void MediaPlayer::timerEvent( QTimerEvent * ) { - if ( drawnOnScreenDisplay && onScreenDisplayVolume == v ) { - return; - } - - int w = audioUI->width(); - int h = audioUI->height(); - - if ( drawnOnScreenDisplay ) { - if ( onScreenDisplayVolume > v ) { - audioUI->repaint( (w - 200) / 2 + v * 20 + 0, h - yoff + 40, (onScreenDisplayVolume - v) * 20 + 9, 30, FALSE ); - } + if ( drawnOnScreenDisplay && onScreenDisplayVolume == v ) { + return; } - drawnOnScreenDisplay = TRUE; - onScreenDisplayVolume = v; + int w=0; int h=0; + if( !xineControl->hasVideo()) { + w = audioUI->width(); + h = audioUI->height(); - QPainter p( audioUI ); - p.setPen( QColor( 0x10, 0xD0, 0x10 ) ); - p.setBrush( QColor( 0x10, 0xD0, 0x10 ) ); - - QFont f; - f.setPixelSize( 20 ); - f.setBold( TRUE ); - p.setFont( f ); - p.drawText( (w - 200) / 2, h - yoff + 20, tr("Volume") ); + if ( drawnOnScreenDisplay ) { + if ( onScreenDisplayVolume > v ) { + audioUI->repaint( (w - 200) / 2 + v * 20 + 0, h - yoff + 40, (onScreenDisplayVolume - v) * 20 + 9, 30, FALSE ); + } + } + drawnOnScreenDisplay = TRUE; + onScreenDisplayVolume = v; + QPainter p( audioUI ); + p.setPen( QColor( 0x10, 0xD0, 0x10 ) ); + p.setBrush( QColor( 0x10, 0xD0, 0x10 ) ); + + QFont f; + f.setPixelSize( 20 ); + f.setBold( TRUE ); + p.setFont( f ); + p.drawText( (w - 200) / 2, h - yoff + 20, tr("Volume") ); + + for ( unsigned int i = 0; i < 10; i++ ) { + if ( v > i ) { + p.drawRect( (w - 200) / 2 + i * 20 + 0, h - yoff + 40, 9, 30 ); + } else { + p.drawRect( (w - 200) / 2 + i * 20 + 3, h - yoff + 50, 3, 10 ); + } + } + } else { + w = videoUI->width(); + h = videoUI->height(); - for ( unsigned int i = 0; i < 10; i++ ) { - if ( v > i ) { - p.drawRect( (w - 200) / 2 + i * 20 + 0, h - yoff + 40, 9, 30 ); - } else { - p.drawRect( (w - 200) / 2 + i * 20 + 3, h - yoff + 50, 3, 10 ); + if ( drawnOnScreenDisplay ) { + if ( onScreenDisplayVolume > v ) { + videoUI->repaint( (w - 200) / 2 + v * 20 + 0, h - yoff + 40, (onScreenDisplayVolume - v) * 20 + 9, 30, FALSE ); + } + } + drawnOnScreenDisplay = TRUE; + onScreenDisplayVolume = v; + QPainter p( videoUI ); + p.setPen( QColor( 0x10, 0xD0, 0x10 ) ); + p.setBrush( QColor( 0x10, 0xD0, 0x10 ) ); + + QFont f; + f.setPixelSize( 20 ); + f.setBold( TRUE ); + p.setFont( f ); + p.drawText( (w - 200) / 2, h - yoff + 20, tr("Volume") ); + + for ( unsigned int i = 0; i < 10; i++ ) { + if ( v > i ) { + p.drawRect( (w - 200) / 2 + i * 20 + 0, h - yoff + 40, 9, 30 ); + } else { + p.drawRect( (w - 200) / 2 + i * 20 + 3, h - yoff + 50, 3, 10 ); + } } diff --git a/noncore/multimedia/opieplayer2/xinecontrol.cpp b/noncore/multimedia/opieplayer2/xinecontrol.cpp index 84ef3f3..17112a2 100644 --- a/noncore/multimedia/opieplayer2/xinecontrol.cpp +++ b/noncore/multimedia/opieplayer2/xinecontrol.cpp @@ -70,2 +70,4 @@ XineControl::~XineControl() { void XineControl::play( const QString& fileName ) { + hasVideoChannel=FALSE; + hasAudioChannel=FALSE; m_fileName = fileName; @@ -83,4 +85,6 @@ void XineControl::play( const QString& fileName ) { libXine->setShowVideo( false ); + hasAudioChannel=TRUE; } else { libXine->setShowVideo( true ); + hasVideoChannel=TRUE; } @@ -194,3 +198,3 @@ void XineControl::seekTo( long second ) { void XineControl::videoResized ( const QSize &s ) { - libXine-> resize ( s ); + libXine-> resize ( s ); } diff --git a/noncore/multimedia/opieplayer2/xinecontrol.h b/noncore/multimedia/opieplayer2/xinecontrol.h index 9ad221e..88458be 100644 --- a/noncore/multimedia/opieplayer2/xinecontrol.h +++ b/noncore/multimedia/opieplayer2/xinecontrol.h @@ -47,2 +47,5 @@ public: + bool hasVideo() const { return hasVideoChannel; } + bool hasAudio() const { return hasAudioChannel; } + public slots: @@ -67,2 +70,4 @@ private: bool disabledSuspendScreenSaver; + bool hasVideoChannel; + bool hasAudioChannel; signals: |