-rw-r--r-- | core/multimedia/opieplayer/audiowidget.cpp | 26 | ||||
-rw-r--r-- | core/multimedia/opieplayer/audiowidget.h | 3 | ||||
-rw-r--r-- | core/multimedia/opieplayer/inputDialog.cpp | 29 | ||||
-rw-r--r-- | core/multimedia/opieplayer/inputDialog.h | 7 | ||||
-rw-r--r-- | core/multimedia/opieplayer/opieplayer.pro | 2 | ||||
-rw-r--r-- | core/multimedia/opieplayer/playlistwidget.cpp | 71 | ||||
-rw-r--r-- | core/multimedia/opieplayer/playlistwidget.h | 6 | ||||
-rw-r--r-- | core/multimedia/opieplayer/videowidget.cpp | 21 |
8 files changed, 97 insertions, 68 deletions
diff --git a/core/multimedia/opieplayer/audiowidget.cpp b/core/multimedia/opieplayer/audiowidget.cpp index 94b979f..aa48961 100644 --- a/core/multimedia/opieplayer/audiowidget.cpp +++ b/core/multimedia/opieplayer/audiowidget.cpp | |||
@@ -1,185 +1,193 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | #include <qpe/qpeapplication.h> | 20 | #include <qpe/qpeapplication.h> |
21 | #include <qpe/resource.h> | 21 | #include <qpe/resource.h> |
22 | #include <qpe/config.h> | ||
22 | 23 | ||
23 | #include <qwidget.h> | 24 | #include <qwidget.h> |
24 | #include <qpixmap.h> | 25 | #include <qpixmap.h> |
25 | #include <qbutton.h> | 26 | #include <qbutton.h> |
26 | #include <qpainter.h> | 27 | #include <qpainter.h> |
27 | #include <qframe.h> | 28 | #include <qframe.h> |
28 | #include <qlayout.h> | 29 | #include <qlayout.h> |
29 | 30 | ||
30 | #include "audiowidget.h" | 31 | #include "audiowidget.h" |
31 | #include "mediaplayerstate.h" | 32 | #include "mediaplayerstate.h" |
32 | 33 | ||
33 | extern MediaPlayerState *mediaPlayerState; | 34 | extern MediaPlayerState *mediaPlayerState; |
34 | 35 | ||
35 | 36 | ||
36 | static const int xo = -2; // movable x offset | 37 | static const int xo = -2; // movable x offset |
37 | static const int yo = 22; // movable y offset | 38 | static const int yo = 22; // movable y offset |
38 | 39 | ||
39 | 40 | ||
40 | struct MediaButton { | 41 | struct MediaButton { |
41 | int xPos, yPos; | 42 | int xPos, yPos; |
42 | int color; | 43 | int color; |
43 | bool isToggle, isBig, isHeld, isDown; | 44 | bool isToggle, isBig, isHeld, isDown; |
44 | }; | 45 | }; |
45 | 46 | ||
46 | 47 | ||
47 | // Layout information for the audioButtons (and if it is a toggle button or not) | 48 | // Layout information for the audioButtons (and if it is a toggle button or not) |
48 | MediaButton audioButtons[] = { | 49 | MediaButton audioButtons[] = { |
49 | { 3*30-15+xo, 3*30-13+yo, 0, TRUE, TRUE, FALSE, FALSE }, // play | 50 | { 3*30-15+xo, 3*30-13+yo, 0, TRUE, TRUE, FALSE, FALSE }, // play |
50 | { 1*30+xo, 5*30+yo, 2, FALSE, FALSE, FALSE, FALSE }, // stop | 51 | { 1*30+xo, 5*30+yo, 2, FALSE, FALSE, FALSE, FALSE }, // stop |
51 | { 5*30+xo, 5*30+yo, 2, TRUE, FALSE, FALSE, FALSE }, // pause | 52 | { 5*30+xo, 5*30+yo, 2, TRUE, FALSE, FALSE, FALSE }, // pause |
52 | { 6*30-5+xo, 3*30+yo, 1, FALSE, FALSE, FALSE, FALSE }, // next | 53 | { 6*30-5+xo, 3*30+yo, 1, FALSE, FALSE, FALSE, FALSE }, // next |
53 | { 0*30+5+xo, 3*30+yo, 1, FALSE, FALSE, FALSE, FALSE }, // previous | 54 | { 0*30+5+xo, 3*30+yo, 1, FALSE, FALSE, FALSE, FALSE }, // previous |
54 | { 3*30+xo, 0*30+5+yo, 3, FALSE, FALSE, FALSE, FALSE }, // volume up | 55 | { 3*30+xo, 0*30+5+yo, 3, FALSE, FALSE, FALSE, FALSE }, // volume up |
55 | { 3*30+xo, 6*30-5+yo, 3, FALSE, FALSE, FALSE, FALSE }, // volume down | 56 | { 3*30+xo, 6*30-5+yo, 3, FALSE, FALSE, FALSE, FALSE }, // volume down |
56 | { 5*30+xo, 1*30+yo, 0, TRUE, FALSE, FALSE, FALSE }, // repeat/loop | 57 | { 5*30+xo, 1*30+yo, 0, TRUE, FALSE, FALSE, FALSE }, // repeat/loop |
57 | { 1*30+xo, 1*30+yo, 0, FALSE, FALSE, FALSE, FALSE } // playlist | 58 | { 1*30+xo, 1*30+yo, 0, FALSE, FALSE, FALSE, FALSE } // playlist |
58 | }; | 59 | }; |
59 | 60 | ||
60 | 61 | ||
61 | static const int numButtons = (sizeof(audioButtons)/sizeof(MediaButton)); | 62 | static const int numButtons = (sizeof(audioButtons)/sizeof(MediaButton)); |
62 | 63 | ||
63 | 64 | ||
64 | AudioWidget::AudioWidget(QWidget* parent, const char* name, WFlags f) : | 65 | AudioWidget::AudioWidget(QWidget* parent, const char* name, WFlags f) : |
65 | QWidget( parent, name, f ) | 66 | QWidget( parent, name, f ) |
66 | { | 67 | { |
67 | setCaption( tr("OpiePlayer") ); | 68 | setCaption( tr("OpiePlayer") ); |
68 | 69 | Config cfg("OpiePlayer"); | |
70 | cfg.setGroup("AudioWidget"); | ||
69 | // QGridLayout *layout = new QGridLayout( this ); | 71 | // QGridLayout *layout = new QGridLayout( this ); |
70 | // layout->setSpacing( 2); | 72 | // layout->setSpacing( 2); |
71 | // layout->setMargin( 2); | 73 | // layout->setMargin( 2); |
72 | 74 | QString backgroundPix, buttonsAllPix, buttonsBigPix, controlsPix, animatedPix; | |
73 | setBackgroundPixmap( Resource::loadPixmap( "opieplayer/metalFinish" ) ); | 75 | backgroundPix=cfg.readEntry( " backgroundPix", "opieplayer/metalFinish"); |
74 | pixmaps[0] = new QPixmap( Resource::loadPixmap( "opieplayer/mediaButtonsAll" ) ); | 76 | buttonsAllPix=cfg.readEntry( "buttonsAllPix","opieplayer/mediaButtonsAll"); |
75 | pixmaps[1] = new QPixmap( Resource::loadPixmap( "opieplayer/mediaButtonsBig" ) ); | 77 | buttonsBigPix=cfg.readEntry( "buttonsBigPix","opieplayer/mediaButtonsBig"); |
76 | pixmaps[2] = new QPixmap( Resource::loadPixmap( "opieplayer/mediaControls" ) ); | 78 | controlsPix=cfg.readEntry( "controlsPix","opieplayer/mediaControls"); |
77 | pixmaps[3] = new QPixmap( Resource::loadPixmap( "opieplayer/animatedButton" ) ); | 79 | animatedPix=cfg.readEntry( "animatedPix", "opieplayer/animatedButton"); |
80 | |||
81 | setBackgroundPixmap( Resource::loadPixmap( backgroundPix) ); | ||
82 | pixmaps[0] = new QPixmap( Resource::loadPixmap( buttonsAllPix ) ); | ||
83 | pixmaps[1] = new QPixmap( Resource::loadPixmap( buttonsBigPix ) ); | ||
84 | pixmaps[2] = new QPixmap( Resource::loadPixmap( controlsPix ) ); | ||
85 | pixmaps[3] = new QPixmap( Resource::loadPixmap( animatedPix) ); | ||
78 | 86 | ||
79 | songInfo = new Ticker( this ); | 87 | songInfo = new Ticker( this ); |
80 | songInfo->setFocusPolicy( QWidget::NoFocus ); | 88 | songInfo->setFocusPolicy( QWidget::NoFocus ); |
81 | songInfo->setGeometry( QRect( 7, 3, 220, 20 ) ); | 89 | songInfo->setGeometry( QRect( 7, 3, 220, 20 ) ); |
82 | // layout->addMultiCellWidget( songInfo, 0, 0, 0, 2 ); | 90 | // layout->addMultiCellWidget( songInfo, 0, 0, 0, 2 ); |
83 | 91 | ||
84 | slider = new QSlider( Qt::Horizontal, this ); | 92 | slider = new QSlider( Qt::Horizontal, this ); |
85 | slider->setFixedWidth( 220 ); | 93 | slider->setFixedWidth( 220 ); |
86 | slider->setFixedHeight( 20 ); | 94 | slider->setFixedHeight( 20 ); |
87 | slider->setMinValue( 0 ); | 95 | slider->setMinValue( 0 ); |
88 | slider->setMaxValue( 1 ); | 96 | slider->setMaxValue( 1 ); |
89 | slider->setBackgroundPixmap( Resource::loadPixmap( "opieplayer/metalFinish" ) ); | 97 | slider->setBackgroundPixmap( Resource::loadPixmap( backgroundPix ) ); |
90 | slider->setFocusPolicy( QWidget::NoFocus ); | 98 | slider->setFocusPolicy( QWidget::NoFocus ); |
91 | slider->setGeometry( QRect( 7, 262, 220, 20 ) ); | 99 | slider->setGeometry( QRect( 7, 262, 220, 20 ) ); |
92 | // layout->addMultiCellWidget( slider, 4, 4, 0, 2 ); | 100 | // layout->addMultiCellWidget( slider, 4, 4, 0, 2 ); |
93 | 101 | ||
94 | connect( slider, SIGNAL( sliderPressed() ), this, SLOT( sliderPressed() ) ); | 102 | connect( slider, SIGNAL( sliderPressed() ), this, SLOT( sliderPressed() ) ); |
95 | connect( slider, SIGNAL( sliderReleased() ), this, SLOT( sliderReleased() ) ); | 103 | connect( slider, SIGNAL( sliderReleased() ), this, SLOT( sliderReleased() ) ); |
96 | 104 | ||
97 | connect( mediaPlayerState, SIGNAL( lengthChanged(long) ), this, SLOT( setLength(long) ) ); | 105 | connect( mediaPlayerState, SIGNAL( lengthChanged(long) ), this, SLOT( setLength(long) ) ); |
98 | connect( mediaPlayerState, SIGNAL( viewChanged(char) ), this, SLOT( setView(char) ) ); | 106 | connect( mediaPlayerState, SIGNAL( viewChanged(char) ), this, SLOT( setView(char) ) ); |
99 | connect( mediaPlayerState, SIGNAL( loopingToggled(bool) ), this, SLOT( setLooping(bool) ) ); | 107 | connect( mediaPlayerState, SIGNAL( loopingToggled(bool) ), this, SLOT( setLooping(bool) ) ); |
100 | connect( mediaPlayerState, SIGNAL( pausedToggled(bool) ), this, SLOT( setPaused(bool) ) ); | 108 | connect( mediaPlayerState, SIGNAL( pausedToggled(bool) ), this, SLOT( setPaused(bool) ) ); |
101 | connect( mediaPlayerState, SIGNAL( playingToggled(bool) ), this, SLOT( setPlaying(bool) ) ); | 109 | connect( mediaPlayerState, SIGNAL( playingToggled(bool) ), this, SLOT( setPlaying(bool) ) ); |
102 | 110 | ||
103 | // Intialise state | 111 | // Intialise state |
104 | setLength( mediaPlayerState->length() ); | 112 | setLength( mediaPlayerState->length() ); |
105 | setPosition( mediaPlayerState->position() ); | 113 | setPosition( mediaPlayerState->position() ); |
106 | setLooping( mediaPlayerState->fullscreen() ); | 114 | setLooping( mediaPlayerState->fullscreen() ); |
107 | setPaused( mediaPlayerState->paused() ); | 115 | setPaused( mediaPlayerState->paused() ); |
108 | setPlaying( mediaPlayerState->playing() ); | 116 | setPlaying( mediaPlayerState->playing() ); |
109 | 117 | ||
110 | } | 118 | } |
111 | 119 | ||
112 | 120 | ||
113 | AudioWidget::~AudioWidget() { | 121 | AudioWidget::~AudioWidget() { |
114 | mediaPlayerState->isStreaming = FALSE; | 122 | mediaPlayerState->isStreaming = FALSE; |
115 | for ( int i = 0; i < 4; i++ ) | 123 | for ( int i = 0; i < 4; i++ ) |
116 | delete pixmaps[i]; | 124 | delete pixmaps[i]; |
117 | } | 125 | } |
118 | 126 | ||
119 | 127 | ||
120 | static bool audioSliderBeingMoved = FALSE; | 128 | static bool audioSliderBeingMoved = FALSE; |
121 | 129 | ||
122 | 130 | ||
123 | void AudioWidget::sliderPressed() { | 131 | void AudioWidget::sliderPressed() { |
124 | audioSliderBeingMoved = TRUE; | 132 | audioSliderBeingMoved = TRUE; |
125 | } | 133 | } |
126 | 134 | ||
127 | 135 | ||
128 | void AudioWidget::sliderReleased() { | 136 | void AudioWidget::sliderReleased() { |
129 | audioSliderBeingMoved = FALSE; | 137 | audioSliderBeingMoved = FALSE; |
130 | if ( slider->width() == 0 ) | 138 | if ( slider->width() == 0 ) |
131 | return; | 139 | return; |
132 | long val = long((double)slider->value() * mediaPlayerState->length() / slider->width()); | 140 | long val = long((double)slider->value() * mediaPlayerState->length() / slider->width()); |
133 | mediaPlayerState->setPosition( val ); | 141 | mediaPlayerState->setPosition( val ); |
134 | } | 142 | } |
135 | 143 | ||
136 | 144 | ||
137 | void AudioWidget::setPosition( long i ) { | 145 | void AudioWidget::setPosition( long i ) { |
138 | updateSlider( i, mediaPlayerState->length() ); | 146 | updateSlider( i, mediaPlayerState->length() ); |
139 | } | 147 | } |
140 | 148 | ||
141 | 149 | ||
142 | void AudioWidget::setLength( long max ) { | 150 | void AudioWidget::setLength( long max ) { |
143 | updateSlider( mediaPlayerState->position(), max ); | 151 | updateSlider( mediaPlayerState->position(), max ); |
144 | } | 152 | } |
145 | 153 | ||
146 | 154 | ||
147 | void AudioWidget::setView( char view ) { | 155 | void AudioWidget::setView( char view ) { |
148 | 156 | ||
149 | if (mediaPlayerState->isStreaming) { | 157 | if (mediaPlayerState->isStreaming) { |
150 | if( !slider->isHidden()) slider->hide(); | 158 | if( !slider->isHidden()) slider->hide(); |
151 | disconnect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); | 159 | disconnect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); |
152 | disconnect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); | 160 | disconnect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); |
153 | } else { | 161 | } else { |
154 | // this stops the slider from being moved, thus | 162 | // this stops the slider from being moved, thus |
155 | // does not stop stream when it reaches the end | 163 | // does not stop stream when it reaches the end |
156 | slider->show(); | 164 | slider->show(); |
157 | connect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); | 165 | connect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); |
158 | connect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); | 166 | connect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); |
159 | } | 167 | } |
160 | 168 | ||
161 | if ( view == 'a' ) { | 169 | if ( view == 'a' ) { |
162 | startTimer( 150 ); | 170 | startTimer( 150 ); |
163 | // show(); | 171 | // show(); |
164 | showMaximized(); | 172 | showMaximized(); |
165 | } else { | 173 | } else { |
166 | killTimers(); | 174 | killTimers(); |
167 | hide(); | 175 | hide(); |
168 | } | 176 | } |
169 | } | 177 | } |
170 | 178 | ||
171 | 179 | ||
172 | void AudioWidget::updateSlider( long i, long max ) { | 180 | void AudioWidget::updateSlider( long i, long max ) { |
173 | if ( max == 0 ) | 181 | if ( max == 0 ) |
174 | return; | 182 | return; |
175 | // Will flicker too much if we don't do this | 183 | // Will flicker too much if we don't do this |
176 | // Scale to something reasonable | 184 | // Scale to something reasonable |
177 | int width = slider->width(); | 185 | int width = slider->width(); |
178 | int val = int((double)i * width / max); | 186 | int val = int((double)i * width / max); |
179 | if ( !audioSliderBeingMoved ) { | 187 | if ( !audioSliderBeingMoved ) { |
180 | if ( slider->value() != val ) | 188 | if ( slider->value() != val ) |
181 | slider->setValue( val ); | 189 | slider->setValue( val ); |
182 | if ( slider->maxValue() != width ) | 190 | if ( slider->maxValue() != width ) |
183 | slider->setMaxValue( width ); | 191 | slider->setMaxValue( width ); |
184 | } | 192 | } |
185 | } | 193 | } |
diff --git a/core/multimedia/opieplayer/audiowidget.h b/core/multimedia/opieplayer/audiowidget.h index 41ae4b6..b3d39bf 100644 --- a/core/multimedia/opieplayer/audiowidget.h +++ b/core/multimedia/opieplayer/audiowidget.h | |||
@@ -29,117 +29,118 @@ | |||
29 | #include <qslider.h> | 29 | #include <qslider.h> |
30 | #include <qframe.h> | 30 | #include <qframe.h> |
31 | 31 | ||
32 | 32 | ||
33 | class QPixmap; | 33 | class QPixmap; |
34 | 34 | ||
35 | 35 | ||
36 | enum AudioButtons { | 36 | enum AudioButtons { |
37 | AudioPlay, | 37 | AudioPlay, |
38 | AudioStop, | 38 | AudioStop, |
39 | AudioPause, | 39 | AudioPause, |
40 | AudioNext, | 40 | AudioNext, |
41 | AudioPrevious, | 41 | AudioPrevious, |
42 | AudioVolumeUp, | 42 | AudioVolumeUp, |
43 | AudioVolumeDown, | 43 | AudioVolumeDown, |
44 | AudioLoop, | 44 | AudioLoop, |
45 | AudioPlayList | 45 | AudioPlayList |
46 | }; | 46 | }; |
47 | 47 | ||
48 | 48 | ||
49 | #define USE_DBLBUF | 49 | #define USE_DBLBUF |
50 | 50 | ||
51 | 51 | ||
52 | class Ticker : public QFrame { | 52 | class Ticker : public QFrame { |
53 | Q_OBJECT | 53 | Q_OBJECT |
54 | public: | 54 | public: |
55 | Ticker( QWidget* parent=0 ) : QFrame( parent ) { | 55 | Ticker( QWidget* parent=0 ) : QFrame( parent ) { |
56 | setFrameStyle( WinPanel | Sunken ); | 56 | setFrameStyle( WinPanel | Sunken ); |
57 | setText( "No Song" ); | 57 | setText( "No Song" ); |
58 | } | 58 | } |
59 | ~Ticker() { } | 59 | ~Ticker() { } |
60 | void setText( const QString& text ) { | 60 | void setText( const QString& text ) { |
61 | pos = 0; // reset it everytime the text is changed | 61 | pos = 0; // reset it everytime the text is changed |
62 | scrollText = text; | 62 | scrollText = text; |
63 | pixelLen = fontMetrics().width( scrollText ); | 63 | pixelLen = fontMetrics().width( scrollText ); |
64 | killTimers(); | 64 | killTimers(); |
65 | if ( pixelLen > width() ) | 65 | if ( pixelLen > width() ) |
66 | startTimer( 50 ); | 66 | startTimer( 50 ); |
67 | update(); | 67 | update(); |
68 | } | 68 | } |
69 | protected: | 69 | protected: |
70 | void timerEvent( QTimerEvent * ) { | 70 | void timerEvent( QTimerEvent * ) { |
71 | pos = ( pos + 1 > pixelLen ) ? 0 : pos + 1; | 71 | pos = ( pos + 1 > pixelLen ) ? 0 : pos + 1; |
72 | #ifndef USE_DBLBUF | 72 | #ifndef USE_DBLBUF |
73 | scroll( -1, 0, contentsRect() ); | 73 | scroll( -1, 0, contentsRect() ); |
74 | #else | 74 | #else |
75 | repaint( FALSE ); | 75 | repaint( FALSE ); |
76 | #endif | 76 | #endif |
77 | } | 77 | } |
78 | void drawContents( QPainter *p ) { | 78 | void drawContents( QPainter *p ) { |
79 | #ifndef USE_DBLBUF | 79 | #ifndef USE_DBLBUF |
80 | for ( int i = 0; i - pos < width() && (i < 1 || pixelLen > width()); i += pixelLen ) | 80 | for ( int i = 0; i - pos < width() && (i < 1 || pixelLen > width()); i += pixelLen ) |
81 | p->drawText( i - pos, 0, INT_MAX, height(), AlignVCenter, scrollText ); | 81 | p->drawText( i - pos, 0, INT_MAX, height(), AlignVCenter, scrollText ); |
82 | #else | 82 | #else |
83 | // Double buffering code. | 83 | // Double buffering code. |
84 | // Looks like qvfb makes it look like it flickers but I don't think it really is | 84 | // Looks like qvfb makes it look like it flickers but I don't think it really is |
85 | QPixmap pm( width(), height() ); | 85 | QPixmap pm( width(), height() ); |
86 | pm.fill( colorGroup().base() ); | 86 | pm.fill( colorGroup().base() ); |
87 | QPainter pmp( &pm ); | 87 | QPainter pmp( &pm ); |
88 | for ( int i = 0; i - pos < width() && (i < 1 || pixelLen > width()); i += pixelLen ) | 88 | for ( int i = 0; i - pos < width() && (i < 1 || pixelLen > width()); i += pixelLen ) |
89 | pmp.drawText( i - pos, 0, INT_MAX, height(), AlignVCenter, scrollText ); | 89 | pmp.drawText( i - pos, 0, INT_MAX, height(), AlignVCenter, scrollText ); |
90 | p->drawPixmap( 0, 0, pm ); | 90 | p->drawPixmap( 0, 0, pm ); |
91 | #endif | 91 | #endif |
92 | } | 92 | } |
93 | private: | 93 | private: |
94 | QString scrollText; | 94 | QString scrollText; |
95 | int pos, pixelLen; | 95 | int pos, pixelLen; |
96 | }; | 96 | }; |
97 | 97 | ||
98 | 98 | ||
99 | class AudioWidget : public QWidget { | 99 | class AudioWidget : public QWidget { |
100 | Q_OBJECT | 100 | Q_OBJECT |
101 | public: | 101 | public: |
102 | AudioWidget( QWidget* parent=0, const char* name=0, WFlags f=0 ); | 102 | AudioWidget( QWidget* parent=0, const char* name=0, WFlags f=0 ); |
103 | ~AudioWidget(); | 103 | ~AudioWidget(); |
104 | void setTickerText( const QString &text ) { songInfo->setText( text ); } | 104 | void setTickerText( const QString &text ) { songInfo->setText( text ); } |
105 | bool isStreaming; | 105 | bool isStreaming; |
106 | public slots: | 106 | public slots: |
107 | void updateSlider( long, long ); | 107 | void updateSlider( long, long ); |
108 | void sliderPressed( ); | 108 | void sliderPressed( ); |
109 | void sliderReleased( ); | 109 | void sliderReleased( ); |
110 | void setPaused( bool b) { setToggleButton( AudioPause, b ); } | 110 | void setPaused( bool b) { setToggleButton( AudioPause, b ); } |
111 | void setLooping( bool b) { setToggleButton( AudioLoop, b ); } | 111 | void setLooping( bool b) { setToggleButton( AudioLoop, b ); } |
112 | void setPlaying( bool b) { setToggleButton( AudioPlay, b ); } | 112 | void setPlaying( bool b) { setToggleButton( AudioPlay, b ); } |
113 | void setPosition( long ); | 113 | void setPosition( long ); |
114 | void setLength( long ); | 114 | void setLength( long ); |
115 | void setView( char ); | 115 | void setView( char ); |
116 | 116 | ||
117 | signals: | 117 | signals: |
118 | void moreClicked(); | 118 | void moreClicked(); |
119 | void lessClicked(); | 119 | void lessClicked(); |
120 | void moreReleased(); | 120 | void moreReleased(); |
121 | void lessReleased(); | 121 | void lessReleased(); |
122 | void sliderMoved(long); | 122 | void sliderMoved(long); |
123 | 123 | ||
124 | protected: | 124 | protected: |
125 | void doBlank(); | ||
126 | void doUnblank(); | ||
125 | void paintEvent( QPaintEvent *pe ); | 127 | void paintEvent( QPaintEvent *pe ); |
126 | void showEvent( QShowEvent *se ); | 128 | void showEvent( QShowEvent *se ); |
127 | void mouseMoveEvent( QMouseEvent *event ); | 129 | void mouseMoveEvent( QMouseEvent *event ); |
128 | void mousePressEvent( QMouseEvent *event ); | 130 | void mousePressEvent( QMouseEvent *event ); |
129 | void mouseReleaseEvent( QMouseEvent *event ); | 131 | void mouseReleaseEvent( QMouseEvent *event ); |
130 | void timerEvent( QTimerEvent *event ); | 132 | void timerEvent( QTimerEvent *event ); |
131 | void closeEvent( QCloseEvent *event ); | 133 | void closeEvent( QCloseEvent *event ); |
132 | void keyReleaseEvent( QKeyEvent *e); | 134 | void keyReleaseEvent( QKeyEvent *e); |
133 | void showMe(); | ||
134 | private: | 135 | private: |
135 | void toggleButton( int ); | 136 | void toggleButton( int ); |
136 | void setToggleButton( int, bool ); | 137 | void setToggleButton( int, bool ); |
137 | void paintButton( QPainter *p, int i ); | 138 | void paintButton( QPainter *p, int i ); |
138 | QPixmap *pixmaps[4]; | 139 | QPixmap *pixmaps[4]; |
139 | Ticker *songInfo; | 140 | Ticker *songInfo; |
140 | QSlider *slider; | 141 | QSlider *slider; |
141 | }; | 142 | }; |
142 | 143 | ||
143 | 144 | ||
144 | #endif // AUDIO_WIDGET_H | 145 | #endif // AUDIO_WIDGET_H |
145 | 146 | ||
diff --git a/core/multimedia/opieplayer/inputDialog.cpp b/core/multimedia/opieplayer/inputDialog.cpp index b443747..b80d129 100644 --- a/core/multimedia/opieplayer/inputDialog.cpp +++ b/core/multimedia/opieplayer/inputDialog.cpp | |||
@@ -1,45 +1,52 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | ** Form implementation generated from reading ui file 'inputDialog.ui' | 2 | ** Form implementation generated from reading ui file 'inputDialog.ui' |
3 | ** | 3 | ** |
4 | ** Created: Sat Mar 2 07:55:03 2002 | 4 | ** Created: Sat Mar 2 07:55:03 2002 |
5 | ** by: The User Interface Compiler (uic) | 5 | ** by: The User Interface Compiler (uic) |
6 | ** | 6 | ** |
7 | ** WARNING! All changes made in this file will be lost! | 7 | ** WARNING! All changes made in this file will be lost! |
8 | ****************************************************************************/ | 8 | ****************************************************************************/ |
9 | #include "inputDialog.h" | 9 | #include "inputDialog.h" |
10 | 10 | ||
11 | #include <qpe/resource.h> | ||
12 | |||
13 | #include <opie/ofiledialog.h> | ||
14 | |||
11 | #include <qlineedit.h> | 15 | #include <qlineedit.h> |
12 | #include <qlayout.h> | 16 | #include <qlayout.h> |
13 | #include <qvariant.h> | 17 | #include <qvariant.h> |
14 | #include <qtooltip.h> | 18 | #include <qpushbutton.h> |
15 | #include <qwhatsthis.h> | 19 | #include <qwhatsthis.h> |
16 | 20 | ||
17 | /* | ||
18 | * Constructs a InputDialog which is a child of 'parent', with the | ||
19 | * name 'name' and widget flags set to 'f' | ||
20 | * | ||
21 | * The dialog will by default be modeless, unless you set 'modal' to | ||
22 | * TRUE to construct a modal dialog. | ||
23 | */ | ||
24 | InputDialog::InputDialog( QWidget* parent, const char* name, bool modal, WFlags fl ) | 21 | InputDialog::InputDialog( QWidget* parent, const char* name, bool modal, WFlags fl ) |
25 | : QDialog( parent, name, modal, fl ) | 22 | : QDialog( parent, name, modal, fl ) |
26 | { | 23 | { |
27 | if ( !name ) | 24 | if ( !name ) |
28 | setName( "InputDialog" ); | 25 | setName( "InputDialog" ); |
29 | resize( 234, 50 ); | 26 | resize( 234, 115); |
30 | setMaximumSize( QSize( 240, 50 ) ); | 27 | setMaximumSize( QSize( 240, 40)); |
31 | setCaption( tr(name ) ); | 28 | setCaption( tr(name ) ); |
32 | 29 | ||
30 | QPushButton *browserButton; | ||
31 | browserButton = new QPushButton( Resource::loadIconSet("fileopen"),"",this,"BrowseButton"); | ||
32 | browserButton->setGeometry( QRect( 205, 10, 22, 22)); | ||
33 | connect( browserButton, SIGNAL(released()),this,SLOT(browse())); | ||
33 | LineEdit1 = new QLineEdit( this, "LineEdit1" ); | 34 | LineEdit1 = new QLineEdit( this, "LineEdit1" ); |
34 | LineEdit1->setGeometry( QRect( 10, 10, 216, 22 ) ); | 35 | LineEdit1->setGeometry( QRect( 4, 10, 190, 22 ) ); |
35 | } | 36 | } |
36 | 37 | ||
37 | /* | 38 | /* |
38 | * Destroys the object and frees any allocated resources | 39 | * Destroys the object and frees any allocated resources |
39 | */ | 40 | */ |
40 | InputDialog::~InputDialog() | 41 | InputDialog::~InputDialog() |
41 | { | 42 | { |
42 | inputText= LineEdit1->text(); | 43 | inputText= LineEdit1->text(); |
43 | 44 | ||
44 | } | 45 | } |
45 | 46 | ||
47 | void InputDialog::browse() { | ||
48 | |||
49 | QString str = OFileDialog::getOpenFileName( 1,"/","", "playlist/plain", 0 ); | ||
50 | LineEdit1->setText(str); | ||
51 | } | ||
52 | |||
diff --git a/core/multimedia/opieplayer/inputDialog.h b/core/multimedia/opieplayer/inputDialog.h index 26d5cd0..3e3e36f 100644 --- a/core/multimedia/opieplayer/inputDialog.h +++ b/core/multimedia/opieplayer/inputDialog.h | |||
@@ -1,31 +1,30 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | ** Form interface generated from reading ui file 'inputDialog.ui' | 2 | ** Form interface generated from reading ui file 'inputDialog.ui' |
3 | ** | 3 | ** |
4 | ** Created: Sat Mar 2 07:54:46 2002 | 4 | ** Created: Sat Mar 2 07:54:46 2002 |
5 | ** by: The User Interface Compiler (uic) | 5 | ** by: The User Interface Compiler (uic) |
6 | ** | 6 | ** |
7 | ** WARNING! All changes made in this file will be lost! | 7 | ** WARNING! All changes made in this file will be lost! |
8 | ****************************************************************************/ | 8 | ****************************************************************************/ |
9 | #ifndef INPUTDIALOG_H | 9 | #ifndef INPUTDIALOG_H |
10 | #define INPUTDIALOG_H | 10 | #define INPUTDIALOG_H |
11 | 11 | ||
12 | #include <qvariant.h> | 12 | #include <qvariant.h> |
13 | #include <qdialog.h> | 13 | #include <qdialog.h> |
14 | class QVBoxLayout; | 14 | |
15 | class QHBoxLayout; | ||
16 | class QGridLayout; | ||
17 | class QLineEdit; | 15 | class QLineEdit; |
18 | 16 | ||
19 | class InputDialog : public QDialog | 17 | class InputDialog : public QDialog |
20 | { | 18 | { |
21 | Q_OBJECT | 19 | Q_OBJECT |
22 | 20 | ||
23 | public: | 21 | public: |
24 | InputDialog( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 ); | 22 | InputDialog( QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags fl = 0 ); |
25 | ~InputDialog(); | 23 | ~InputDialog(); |
26 | QString inputText; | 24 | QString inputText; |
27 | QLineEdit* LineEdit1; | 25 | QLineEdit* LineEdit1; |
28 | 26 | protected slots: | |
27 | void browse(); | ||
29 | }; | 28 | }; |
30 | 29 | ||
31 | #endif // INPUTDIALOG_H | 30 | #endif // INPUTDIALOG_H |
diff --git a/core/multimedia/opieplayer/opieplayer.pro b/core/multimedia/opieplayer/opieplayer.pro index 4cef319..6409bab 100644 --- a/core/multimedia/opieplayer/opieplayer.pro +++ b/core/multimedia/opieplayer/opieplayer.pro | |||
@@ -1,24 +1,24 @@ | |||
1 | TEMPLATE = app | 1 | TEMPLATE = app |
2 | CONFIG = qt warn_on release | 2 | CONFIG = qt warn_on release |
3 | #release | 3 | #release |
4 | DESTDIR = $(OPIEDIR)/bin | 4 | DESTDIR = $(OPIEDIR)/bin |
5 | HEADERS = loopcontrol.h mediaplayerplugininterface.h playlistselection.h mediaplayerstate.h \ | 5 | HEADERS = loopcontrol.h mediaplayerplugininterface.h playlistselection.h mediaplayerstate.h \ |
6 | videowidget.h audiowidget.h playlistwidget.h mediaplayer.h audiodevice.h inputDialog.h | 6 | videowidget.h audiowidget.h playlistwidget.h mediaplayer.h audiodevice.h inputDialog.h |
7 | SOURCES = main.cpp \ | 7 | SOURCES = main.cpp \ |
8 | loopcontrol.cpp playlistselection.cpp mediaplayerstate.cpp \ | 8 | loopcontrol.cpp playlistselection.cpp mediaplayerstate.cpp \ |
9 | videowidget.cpp audiowidget.cpp playlistwidget.cpp mediaplayer.cpp audiodevice.cpp inputDialog.cpp | 9 | videowidget.cpp audiowidget.cpp playlistwidget.cpp mediaplayer.cpp audiodevice.cpp inputDialog.cpp |
10 | TARGET = opieplayer | 10 | TARGET = opieplayer |
11 | INCLUDEPATH += $(OPIEDIR)/include | 11 | INCLUDEPATH += $(OPIEDIR)/include |
12 | DEPENDPATH += $(OPIEDIR)/include | 12 | DEPENDPATH += $(OPIEDIR)/include |
13 | LIBS += -lqpe -lpthread | 13 | LIBS += -lqpe -lpthread -lopie |
14 | 14 | ||
15 | # INTERFACES = | 15 | # INTERFACES = |
16 | # INCLUDEPATH += $(OPIEDIR)/include | 16 | # INCLUDEPATH += $(OPIEDIR)/include |
17 | # CONFIG+=static | 17 | # CONFIG+=static |
18 | # TMAKE_CXXFLAGS += -DQPIM_STANDALONE | 18 | # TMAKE_CXXFLAGS += -DQPIM_STANDALONE |
19 | # LIBS += libmpeg3/libmpeg3.a -lpthread | 19 | # LIBS += libmpeg3/libmpeg3.a -lpthread |
20 | # LIBS += $(OPIEDIR)/plugins/codecs/liblibmadplugin.so | 20 | # LIBS += $(OPIEDIR)/plugins/codecs/liblibmadplugin.so |
21 | 21 | ||
22 | INCLUDEPATH += $(OPIEDIR)/include | 22 | INCLUDEPATH += $(OPIEDIR)/include |
23 | DEPENDPATH += $(OPIEDIR)/include | 23 | DEPENDPATH += $(OPIEDIR)/include |
24 | 24 | ||
diff --git a/core/multimedia/opieplayer/playlistwidget.cpp b/core/multimedia/opieplayer/playlistwidget.cpp index 70b7cef..2118051 100644 --- a/core/multimedia/opieplayer/playlistwidget.cpp +++ b/core/multimedia/opieplayer/playlistwidget.cpp | |||
@@ -534,201 +534,192 @@ const DocLnk *PlayListWidget::current() { // this is fugly | |||
534 | case 2: // video | 534 | case 2: // video |
535 | { | 535 | { |
536 | qDebug("videoView"); | 536 | qDebug("videoView"); |
537 | // Global::findDocuments(&vFiles, "video/*"); | 537 | // Global::findDocuments(&vFiles, "video/*"); |
538 | QListIterator<DocLnk> Vdit( vFiles.children() ); | 538 | QListIterator<DocLnk> Vdit( vFiles.children() ); |
539 | for ( ; Vdit.current(); ++Vdit ) { | 539 | for ( ; Vdit.current(); ++Vdit ) { |
540 | if( Vdit.current()->name() == videoView->currentItem()->text(0) && !insanityBool) { | 540 | if( Vdit.current()->name() == videoView->currentItem()->text(0) && !insanityBool) { |
541 | insanityBool=TRUE; | 541 | insanityBool=TRUE; |
542 | return Vdit; | 542 | return Vdit; |
543 | } | 543 | } |
544 | } | 544 | } |
545 | } | 545 | } |
546 | break; | 546 | break; |
547 | }; | 547 | }; |
548 | return 0; | 548 | return 0; |
549 | } | 549 | } |
550 | 550 | ||
551 | bool PlayListWidget::prev() { | 551 | bool PlayListWidget::prev() { |
552 | if ( mediaPlayerState->playlist() ) { | 552 | if ( mediaPlayerState->playlist() ) { |
553 | if ( mediaPlayerState->shuffled() ) { | 553 | if ( mediaPlayerState->shuffled() ) { |
554 | const DocLnk *cur = current(); | 554 | const DocLnk *cur = current(); |
555 | int j = 1 + (int)(97.0 * rand() / (RAND_MAX + 1.0)); | 555 | int j = 1 + (int)(97.0 * rand() / (RAND_MAX + 1.0)); |
556 | for ( int i = 0; i < j; i++ ) { | 556 | for ( int i = 0; i < j; i++ ) { |
557 | if ( !d->selectedFiles->next() ) | 557 | if ( !d->selectedFiles->next() ) |
558 | d->selectedFiles->first(); | 558 | d->selectedFiles->first(); |
559 | } | 559 | } |
560 | if ( cur == current() ) | 560 | if ( cur == current() ) |
561 | if ( !d->selectedFiles->next() ) | 561 | if ( !d->selectedFiles->next() ) |
562 | d->selectedFiles->first(); | 562 | d->selectedFiles->first(); |
563 | return TRUE; | 563 | return TRUE; |
564 | } else { | 564 | } else { |
565 | if ( !d->selectedFiles->prev() ) { | 565 | if ( !d->selectedFiles->prev() ) { |
566 | if ( mediaPlayerState->looping() ) { | 566 | if ( mediaPlayerState->looping() ) { |
567 | return d->selectedFiles->last(); | 567 | return d->selectedFiles->last(); |
568 | } else { | 568 | } else { |
569 | return FALSE; | 569 | return FALSE; |
570 | } | 570 | } |
571 | } | 571 | } |
572 | return TRUE; | 572 | return TRUE; |
573 | } | 573 | } |
574 | } else { | 574 | } else { |
575 | return mediaPlayerState->looping(); | 575 | return mediaPlayerState->looping(); |
576 | } | 576 | } |
577 | } | 577 | } |
578 | 578 | ||
579 | 579 | ||
580 | bool PlayListWidget::next() { | 580 | bool PlayListWidget::next() { |
581 | if ( mediaPlayerState->playlist() ) { | 581 | if ( mediaPlayerState->playlist() ) { |
582 | if ( mediaPlayerState->shuffled() ) { | 582 | if ( mediaPlayerState->shuffled() ) { |
583 | return prev(); | 583 | return prev(); |
584 | } else { | 584 | } else { |
585 | if ( !d->selectedFiles->next() ) { | 585 | if ( !d->selectedFiles->next() ) { |
586 | if ( mediaPlayerState->looping() ) { | 586 | if ( mediaPlayerState->looping() ) { |
587 | return d->selectedFiles->first(); | 587 | return d->selectedFiles->first(); |
588 | } else { | 588 | } else { |
589 | return FALSE; | 589 | return FALSE; |
590 | } | 590 | } |
591 | } | 591 | } |
592 | return TRUE; | 592 | return TRUE; |
593 | } | 593 | } |
594 | } else { | 594 | } else { |
595 | return mediaPlayerState->looping(); | 595 | return mediaPlayerState->looping(); |
596 | } | 596 | } |
597 | } | 597 | } |
598 | 598 | ||
599 | 599 | ||
600 | bool PlayListWidget::first() { | 600 | bool PlayListWidget::first() { |
601 | if ( mediaPlayerState->playlist() ) | 601 | if ( mediaPlayerState->playlist() ) |
602 | return d->selectedFiles->first(); | 602 | return d->selectedFiles->first(); |
603 | else | 603 | else |
604 | return mediaPlayerState->looping(); | 604 | return mediaPlayerState->looping(); |
605 | } | 605 | } |
606 | 606 | ||
607 | 607 | ||
608 | bool PlayListWidget::last() { | 608 | bool PlayListWidget::last() { |
609 | if ( mediaPlayerState->playlist() ) | 609 | if ( mediaPlayerState->playlist() ) |
610 | return d->selectedFiles->last(); | 610 | return d->selectedFiles->last(); |
611 | else | 611 | else |
612 | return mediaPlayerState->looping(); | 612 | return mediaPlayerState->looping(); |
613 | } | 613 | } |
614 | 614 | ||
615 | 615 | ||
616 | void PlayListWidget::saveList() { | 616 | void PlayListWidget::saveList() { |
617 | 617 | ||
618 | QString filename; | 618 | QString filename; |
619 | InputDialog *fileDlg; | 619 | InputDialog *fileDlg; |
620 | fileDlg = new InputDialog(this,tr("Save Playlist"),TRUE, 0); | 620 | fileDlg = new InputDialog(this,tr("Save Playlist"),TRUE, 0); |
621 | fileDlg->exec(); | 621 | fileDlg->exec(); |
622 | if( fileDlg->result() == 1 ) { | 622 | if( fileDlg->result() == 1 ) { |
623 | if ( d->current ) | 623 | if ( d->current ) |
624 | delete d->current; | 624 | delete d->current; |
625 | filename = fileDlg->LineEdit1->text();//+".playlist"; | 625 | filename = fileDlg->LineEdit1->text();//+".playlist"; |
626 | // qDebug("saving playlist "+filename+".playlist"); | 626 | // qDebug("saving playlist "+filename+".playlist"); |
627 | Config cfg( filename +".playlist"); | 627 | Config cfg( filename +".playlist"); |
628 | writeConfig( cfg ); | 628 | writeConfig( cfg ); |
629 | 629 | ||
630 | // qDebug("same name so delete lnk??"); | ||
631 | // if( playLists->selected()->name() == filename) { | ||
632 | |||
633 | // qDebug("same name so delete lnk"); | ||
634 | // QFile().remove(playLists->selected()->file()); | ||
635 | // QFile().remove(playLists->selected()->linkFile()); | ||
636 | // playLists->reread(); | ||
637 | // } | ||
638 | // qDebug("new doclnk"); | ||
639 | DocLnk lnk; | 630 | DocLnk lnk; |
640 | // lnk.setComment( ""); | 631 | // lnk.setComment( ""); |
641 | lnk.setFile(QDir::homeDirPath()+"/Settings/"+filename+".playlist.conf"); //sets File property | 632 | lnk.setFile(QDir::homeDirPath()+"/Settings/"+filename+".playlist.conf"); //sets File property |
642 | lnk.setType("playlist/plain");// hey is this a REGISTERED mime type?!?!? ;D | 633 | lnk.setType("playlist/plain");// hey is this a REGISTERED mime type?!?!? ;D |
643 | lnk.setIcon("opieplayer/playlist2"); | 634 | lnk.setIcon("opieplayer/playlist2"); |
644 | lnk.setName( filename); //sets file name | 635 | lnk.setName( filename); //sets file name |
645 | // qDebug(filename); | 636 | // qDebug(filename); |
646 | if(!lnk.writeLink()) | 637 | if(!lnk.writeLink()) |
647 | qDebug("Writing doclink did not work"); | 638 | qDebug("Writing doclink did not work"); |
648 | } | 639 | } |
649 | Config config( "OpiePlayer" ); | 640 | Config config( "OpiePlayer" ); |
650 | config.writeEntry("CurrentPlaylist",filename); | 641 | config.writeEntry("CurrentPlaylist",filename); |
651 | setCaption(tr("OpiePlayer: ")+filename); | 642 | setCaption(tr("OpiePlayer: ")+filename); |
652 | d->selectedFiles->first(); | 643 | d->selectedFiles->first(); |
653 | if(fileDlg) | 644 | if(fileDlg) |
654 | delete fileDlg; | 645 | delete fileDlg; |
655 | } | 646 | } |
656 | 647 | ||
657 | void PlayListWidget::loadList( const DocLnk & lnk) { | 648 | void PlayListWidget::loadList( const DocLnk & lnk) { |
658 | QString name= lnk.name(); | 649 | QString name= lnk.name(); |
659 | // qDebug("currentList is "+name); | 650 | // qDebug("currentList is "+name); |
660 | if( name.length()>1) { | 651 | if( name.length()>1) { |
661 | setCaption("OpiePlayer: "+name); | 652 | setCaption("OpiePlayer: "+name); |
662 | // qDebug("load list "+ name+".playlist"); | 653 | // qDebug("load list "+ name+".playlist"); |
663 | clearList(); | 654 | clearList(); |
664 | Config cfg( name+".playlist"); | 655 | Config cfg( name+".playlist"); |
665 | readConfig(cfg); | 656 | readConfig(cfg); |
666 | 657 | ||
667 | tabWidget->setCurrentPage(0); | 658 | tabWidget->setCurrentPage(0); |
668 | 659 | ||
669 | Config config( "OpiePlayer" ); | 660 | Config config( "OpiePlayer" ); |
670 | config.writeEntry("CurrentPlaylist", name); | 661 | config.writeEntry("CurrentPlaylist", name); |
671 | // d->selectedFiles->first(); | 662 | // d->selectedFiles->first(); |
672 | } | 663 | } |
673 | 664 | ||
674 | } | 665 | } |
675 | 666 | ||
676 | void PlayListWidget::setPlaylist( bool shown ) { | 667 | void PlayListWidget::setPlaylist( bool shown ) { |
677 | if ( shown ) | 668 | if ( shown ) |
678 | d->playListFrame->show(); | 669 | d->playListFrame->show(); |
679 | else | 670 | else |
680 | d->playListFrame->hide(); | 671 | d->playListFrame->hide(); |
681 | } | 672 | } |
682 | 673 | ||
683 | void PlayListWidget::setView( char view ) { | 674 | void PlayListWidget::setView( char view ) { |
684 | if ( view == 'l' ) | 675 | if ( view == 'l' ) |
685 | showMaximized(); | 676 | showMaximized(); |
686 | else | 677 | else |
687 | hide(); | 678 | hide(); |
688 | } | 679 | } |
689 | 680 | ||
690 | void PlayListWidget::addSelected() { | 681 | void PlayListWidget::addSelected() { |
691 | 682 | ||
692 | Config cfg( "OpiePlayer" ); | 683 | Config cfg( "OpiePlayer" ); |
693 | cfg.setGroup("PlayList"); | 684 | cfg.setGroup("PlayList"); |
694 | QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); | 685 | QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); |
695 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); | 686 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); |
696 | 687 | ||
697 | switch (tabWidget->currentPageIndex()) { | 688 | switch (tabWidget->currentPageIndex()) { |
698 | case 0: //playlist | 689 | case 0: //playlist |
699 | break; | 690 | break; |
700 | case 1: { //audio | 691 | case 1: { //audio |
701 | // QString entryName; | 692 | // QString entryName; |
702 | // entryName.sprintf( "File%i", i + 1 ); | 693 | // entryName.sprintf( "File%i", i + 1 ); |
703 | // QString linkFile = cfg.readEntry( entryName ); | 694 | // QString linkFile = cfg.readEntry( entryName ); |
704 | QListViewItemIterator it( audioView ); | 695 | QListViewItemIterator it( audioView ); |
705 | // iterate through all items of the listview | 696 | // iterate through all items of the listview |
706 | for ( ; it.current(); ++it ) { | 697 | for ( ; it.current(); ++it ) { |
707 | if ( it.current()->isSelected() ) { | 698 | if ( it.current()->isSelected() ) { |
708 | QListIterator<DocLnk> dit( files.children() ); | 699 | QListIterator<DocLnk> dit( files.children() ); |
709 | for ( ; dit.current(); ++dit ) { | 700 | for ( ; dit.current(); ++dit ) { |
710 | if( dit.current()->name() == it.current()->text(0) ) { | 701 | if( dit.current()->name() == it.current()->text(0) ) { |
711 | d->selectedFiles->addToSelection( **dit ); | 702 | d->selectedFiles->addToSelection( **dit ); |
712 | } | 703 | } |
713 | } | 704 | } |
714 | audioView->setSelected( it.current(),FALSE); | 705 | audioView->setSelected( it.current(),FALSE); |
715 | } | 706 | } |
716 | } | 707 | } |
717 | tabWidget->setCurrentPage(0); | 708 | tabWidget->setCurrentPage(0); |
718 | } | 709 | } |
719 | break; | 710 | break; |
720 | case 2: { // video | 711 | case 2: { // video |
721 | QListViewItemIterator it( videoView ); | 712 | QListViewItemIterator it( videoView ); |
722 | // iterate through all items of the listview | 713 | // iterate through all items of the listview |
723 | for ( ; it.current(); ++it ) { | 714 | for ( ; it.current(); ++it ) { |
724 | if ( it.current()->isSelected() ) { | 715 | if ( it.current()->isSelected() ) { |
725 | QListIterator<DocLnk> dit( vFiles.children() ); | 716 | QListIterator<DocLnk> dit( vFiles.children() ); |
726 | for ( ; dit.current(); ++dit ) { | 717 | for ( ; dit.current(); ++dit ) { |
727 | if( dit.current()->name() == it.current()->text(0) ) { | 718 | if( dit.current()->name() == it.current()->text(0) ) { |
728 | d->selectedFiles->addToSelection( **dit ); | 719 | d->selectedFiles->addToSelection( **dit ); |
729 | } | 720 | } |
730 | } | 721 | } |
731 | 722 | ||
732 | videoView->setSelected( it.current(),FALSE); | 723 | videoView->setSelected( it.current(),FALSE); |
733 | } | 724 | } |
734 | } | 725 | } |
@@ -754,354 +745,362 @@ void PlayListWidget::addSelected() { | |||
754 | void PlayListWidget::removeSelected() { | 745 | void PlayListWidget::removeSelected() { |
755 | d->selectedFiles->removeSelected( ); | 746 | d->selectedFiles->removeSelected( ); |
756 | } | 747 | } |
757 | 748 | ||
758 | void PlayListWidget::playIt( QListViewItem *it) { | 749 | void PlayListWidget::playIt( QListViewItem *it) { |
759 | // d->setDocumentUsed = FALSE; | 750 | // d->setDocumentUsed = FALSE; |
760 | mediaPlayerState->setPlaying(FALSE); | 751 | mediaPlayerState->setPlaying(FALSE); |
761 | mediaPlayerState->setPlaying(TRUE); | 752 | mediaPlayerState->setPlaying(TRUE); |
762 | d->selectedFiles->unSelect(); | 753 | d->selectedFiles->unSelect(); |
763 | } | 754 | } |
764 | 755 | ||
765 | void PlayListWidget::addToSelection( QListViewItem *it) { | 756 | void PlayListWidget::addToSelection( QListViewItem *it) { |
766 | d->setDocumentUsed = FALSE; | 757 | d->setDocumentUsed = FALSE; |
767 | 758 | ||
768 | if(it) { | 759 | if(it) { |
769 | switch (tabWidget->currentPageIndex()) { | 760 | switch (tabWidget->currentPageIndex()) { |
770 | case 1: { | 761 | case 1: { |
771 | QListIterator<DocLnk> dit( files.children() ); | 762 | QListIterator<DocLnk> dit( files.children() ); |
772 | for ( ; dit.current(); ++dit ) { | 763 | for ( ; dit.current(); ++dit ) { |
773 | if( dit.current()->name() == it->text(0)) { | 764 | if( dit.current()->name() == it->text(0)) { |
774 | d->selectedFiles->addToSelection( **dit ); | 765 | d->selectedFiles->addToSelection( **dit ); |
775 | } | 766 | } |
776 | } | 767 | } |
777 | } | 768 | } |
778 | break; | 769 | break; |
779 | case 2: { | 770 | case 2: { |
780 | QListIterator<DocLnk> dit( vFiles.children() ); | 771 | QListIterator<DocLnk> dit( vFiles.children() ); |
781 | for ( ; dit.current(); ++dit ) { | 772 | for ( ; dit.current(); ++dit ) { |
782 | if( dit.current()->name() == it->text(0)) { | 773 | if( dit.current()->name() == it->text(0)) { |
783 | d->selectedFiles->addToSelection( **dit ); | 774 | d->selectedFiles->addToSelection( **dit ); |
784 | } | 775 | } |
785 | } | 776 | } |
786 | } | 777 | } |
787 | break; | 778 | break; |
788 | case 0: | 779 | case 0: |
789 | break; | 780 | break; |
790 | }; | 781 | }; |
791 | tabWidget->setCurrentPage(0); | 782 | tabWidget->setCurrentPage(0); |
792 | } | 783 | } |
793 | } | 784 | } |
794 | 785 | ||
795 | void PlayListWidget::tabChanged(QWidget *widg) { | 786 | void PlayListWidget::tabChanged(QWidget *widg) { |
796 | 787 | ||
797 | switch ( tabWidget->currentPageIndex()) { | 788 | switch ( tabWidget->currentPageIndex()) { |
798 | case 0: | 789 | case 0: |
799 | { | 790 | { |
800 | if( !tbDeletePlaylist->isHidden()) | 791 | if( !tbDeletePlaylist->isHidden()) |
801 | tbDeletePlaylist->hide(); | 792 | tbDeletePlaylist->hide(); |
802 | d->tbRemoveFromList->setEnabled(TRUE); | 793 | d->tbRemoveFromList->setEnabled(TRUE); |
803 | d->tbAddToList->setEnabled(FALSE); | 794 | d->tbAddToList->setEnabled(FALSE); |
804 | } | 795 | } |
805 | break; | 796 | break; |
806 | case 1: | 797 | case 1: |
807 | { | 798 | { |
808 | if( !tbDeletePlaylist->isHidden()) | 799 | if( !tbDeletePlaylist->isHidden()) |
809 | tbDeletePlaylist->hide(); | 800 | tbDeletePlaylist->hide(); |
810 | d->tbRemoveFromList->setEnabled(FALSE); | 801 | d->tbRemoveFromList->setEnabled(FALSE); |
811 | d->tbAddToList->setEnabled(TRUE); | 802 | d->tbAddToList->setEnabled(TRUE); |
812 | } | 803 | } |
813 | break; | 804 | break; |
814 | case 2: | 805 | case 2: |
815 | { | 806 | { |
816 | if( !tbDeletePlaylist->isHidden()) | 807 | if( !tbDeletePlaylist->isHidden()) |
817 | tbDeletePlaylist->hide(); | 808 | tbDeletePlaylist->hide(); |
818 | d->tbRemoveFromList->setEnabled(FALSE); | 809 | d->tbRemoveFromList->setEnabled(FALSE); |
819 | d->tbAddToList->setEnabled(TRUE); | 810 | d->tbAddToList->setEnabled(TRUE); |
820 | } | 811 | } |
821 | break; | 812 | break; |
822 | case 3: | 813 | case 3: |
823 | { | 814 | { |
824 | if( tbDeletePlaylist->isHidden()) | 815 | if( tbDeletePlaylist->isHidden()) |
825 | tbDeletePlaylist->show(); | 816 | tbDeletePlaylist->show(); |
826 | playLists->reread(); | 817 | playLists->reread(); |
827 | } | 818 | } |
828 | break; | 819 | break; |
829 | }; | 820 | }; |
830 | } | 821 | } |
831 | 822 | ||
832 | 823 | ||
833 | 824 | ||
834 | void PlayListWidget::btnPlay(bool b) { | 825 | void PlayListWidget::btnPlay(bool b) { |
835 | 826 | ||
836 | // mediaPlayerState->setPlaying(b); | 827 | // mediaPlayerState->setPlaying(b); |
837 | switch ( tabWidget->currentPageIndex()) { | 828 | switch ( tabWidget->currentPageIndex()) { |
838 | case 0: | 829 | case 0: |
839 | { | 830 | { |
840 | mediaPlayerState->setPlaying(b); | 831 | mediaPlayerState->setPlaying(b); |
841 | } | 832 | } |
842 | break; | 833 | break; |
843 | case 1: | 834 | case 1: |
844 | { | 835 | { |
845 | addToSelection( audioView->selectedItem() ); | 836 | addToSelection( audioView->selectedItem() ); |
846 | mediaPlayerState->setPlaying(b); | 837 | mediaPlayerState->setPlaying(b); |
847 | d->selectedFiles->removeSelected( ); | 838 | d->selectedFiles->removeSelected( ); |
848 | tabWidget->setCurrentPage(1); | 839 | tabWidget->setCurrentPage(1); |
849 | d->selectedFiles->unSelect(); | 840 | d->selectedFiles->unSelect(); |
841 | insanityBool=FALSE; | ||
850 | // audioView->clearSelection(); | 842 | // audioView->clearSelection(); |
851 | } | 843 | } |
852 | break; | 844 | break; |
853 | case 2: | 845 | case 2: |
854 | { | 846 | { |
855 | addToSelection( videoView->selectedItem() ); | 847 | addToSelection( videoView->selectedItem() ); |
856 | mediaPlayerState->setPlaying(b); | 848 | mediaPlayerState->setPlaying(b); |
857 | qApp->processEvents(); | 849 | qApp->processEvents(); |
858 | d->selectedFiles->removeSelected( ); | 850 | d->selectedFiles->removeSelected( ); |
859 | tabWidget->setCurrentPage(2); | 851 | tabWidget->setCurrentPage(2); |
860 | d->selectedFiles->unSelect(); | 852 | d->selectedFiles->unSelect(); |
853 | insanityBool=FALSE; | ||
861 | // videoView->clearSelection(); | 854 | // videoView->clearSelection(); |
862 | } | 855 | } |
863 | break; | 856 | break; |
864 | }; | 857 | }; |
865 | } | 858 | } |
866 | 859 | ||
867 | void PlayListWidget::deletePlaylist() { | 860 | void PlayListWidget::deletePlaylist() { |
868 | switch( QMessageBox::information( this, (tr("Remove Playlist?")), | 861 | switch( QMessageBox::information( this, (tr("Remove Playlist?")), |
869 | (tr("You really want to delete\nthis playlist?")), | 862 | (tr("You really want to delete\nthis playlist?")), |
870 | (tr("Yes")), (tr("No")), 0 )){ | 863 | (tr("Yes")), (tr("No")), 0 )){ |
871 | case 0: // Yes clicked, | 864 | case 0: // Yes clicked, |
872 | QFile().remove(playLists->selected()->file()); | 865 | QFile().remove(playLists->selected()->file()); |
873 | QFile().remove(playLists->selected()->linkFile()); | 866 | QFile().remove(playLists->selected()->linkFile()); |
874 | playLists->reread(); | 867 | playLists->reread(); |
875 | break; | 868 | break; |
876 | case 1: // Cancel | 869 | case 1: // Cancel |
877 | break; | 870 | break; |
878 | }; | 871 | }; |
879 | 872 | ||
880 | } | 873 | } |
881 | 874 | ||
882 | void PlayListWidget::viewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) | 875 | void PlayListWidget::viewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) |
883 | { | 876 | { |
884 | switch (mouse) { | 877 | switch (mouse) { |
885 | case 1: | 878 | case 1: |
886 | break; | 879 | break; |
887 | case 2:{ | 880 | case 2:{ |
888 | QPopupMenu m; | 881 | QPopupMenu m; |
889 | m.insertItem( tr( "Play" ), this, SLOT( playSelected() )); | 882 | m.insertItem( tr( "Play" ), this, SLOT( playSelected() )); |
890 | m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() )); | 883 | m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() )); |
891 | m.insertSeparator(); | 884 | m.insertSeparator(); |
892 | m.insertItem( tr( "Properties" ), this, SLOT( listDelete() )); | 885 | m.insertItem( tr( "Properties" ), this, SLOT( listDelete() )); |
893 | m.exec( QCursor::pos() ); | 886 | m.exec( QCursor::pos() ); |
894 | } | 887 | } |
895 | break; | 888 | break; |
896 | }; | 889 | }; |
897 | } | 890 | } |
898 | 891 | ||
899 | void PlayListWidget::playSelected() | 892 | void PlayListWidget::playSelected() |
900 | { | 893 | { |
901 | btnPlay( TRUE); | 894 | btnPlay( TRUE); |
902 | d->selectedFiles->unSelect(); | 895 | // d->selectedFiles->unSelect(); |
903 | } | 896 | } |
904 | 897 | ||
905 | void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) | 898 | void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) |
906 | { | 899 | { |
907 | switch (mouse) { | 900 | switch (mouse) { |
908 | case 1: | 901 | case 1: |
909 | 902 | ||
910 | break; | 903 | break; |
911 | case 2:{ | 904 | case 2:{ |
912 | QPopupMenu m; | 905 | QPopupMenu m; |
913 | m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() )); | 906 | m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() )); |
914 | m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() )); | 907 | m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() )); |
915 | // m.insertSeparator(); | 908 | // m.insertSeparator(); |
916 | m.exec( QCursor::pos() ); | 909 | m.exec( QCursor::pos() ); |
917 | } | 910 | } |
918 | break; | 911 | break; |
919 | }; | 912 | }; |
920 | 913 | ||
921 | } | 914 | } |
922 | 915 | ||
923 | void PlayListWidget::listDelete() { | 916 | void PlayListWidget::listDelete() { |
924 | Config cfg( "OpiePlayer" ); | 917 | Config cfg( "OpiePlayer" ); |
925 | cfg.setGroup("PlayList"); | 918 | cfg.setGroup("PlayList"); |
926 | QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); | 919 | QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); |
927 | QString file; | 920 | QString file; |
928 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); | 921 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); |
929 | switch ( tabWidget->currentPageIndex()) { | 922 | switch ( tabWidget->currentPageIndex()) { |
930 | case 0: | 923 | case 0: |
931 | break; | 924 | break; |
932 | case 1: | 925 | case 1: |
933 | { | 926 | { |
934 | file = audioView->selectedItem()->text(0); | 927 | file = audioView->selectedItem()->text(0); |
935 | // Global::findDocuments(&files, "audio/*"); | 928 | // Global::findDocuments(&files, "audio/*"); |
936 | // AppLnkSet appFiles; | 929 | // AppLnkSet appFiles; |
937 | QListIterator<DocLnk> dit( files.children() ); | 930 | QListIterator<DocLnk> dit( files.children() ); |
938 | for ( ; dit.current(); ++dit ) { | 931 | for ( ; dit.current(); ++dit ) { |
939 | if( dit.current()->name() == file) { | 932 | if( dit.current()->name() == file) { |
940 | // qDebug(file); | 933 | // qDebug(file); |
941 | LnkProperties prop( dit.current() ); | 934 | LnkProperties prop( dit.current() ); |
942 | // connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); | 935 | // connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); |
943 | prop.showMaximized(); | 936 | prop.showMaximized(); |
944 | prop.exec(); | 937 | prop.exec(); |
945 | } | 938 | } |
946 | } | 939 | } |
947 | populateAudioView(); | 940 | populateAudioView(); |
948 | } | 941 | } |
949 | break; | 942 | break; |
950 | case 2: | 943 | case 2: |
951 | { | 944 | { |
952 | // file = videoView->selectedItem()->text(0); | 945 | // file = videoView->selectedItem()->text(0); |
953 | // for ( int i = 0; i < noOfFiles; i++ ) { | 946 | // for ( int i = 0; i < noOfFiles; i++ ) { |
954 | // QString entryName; | 947 | // QString entryName; |
955 | // entryName.sprintf( "File%i", i + 1 ); | 948 | // entryName.sprintf( "File%i", i + 1 ); |
956 | // QString linkFile = cfg.readEntry( entryName ); | 949 | // QString linkFile = cfg.readEntry( entryName ); |
957 | // AppLnk lnk( AppLnk(linkFile)); | 950 | // AppLnk lnk( AppLnk(linkFile)); |
958 | // if( lnk.name() == file ) { | 951 | // if( lnk.name() == file ) { |
959 | // LnkProperties prop( &lnk); | 952 | // LnkProperties prop( &lnk); |
960 | // // connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); | 953 | // // connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); |
961 | // prop.showMaximized(); | 954 | // prop.showMaximized(); |
962 | // prop.exec(); | 955 | // prop.exec(); |
963 | // } | 956 | // } |
964 | // } | 957 | // } |
965 | } | 958 | } |
966 | break; | 959 | break; |
967 | }; | 960 | }; |
968 | } | 961 | } |
969 | 962 | ||
970 | void PlayListWidget::populateAudioView() { | 963 | void PlayListWidget::populateAudioView() { |
971 | // if(files) | 964 | // if(files) |
972 | // files.~DocLnkSet(); | 965 | // files.~DocLnkSet(); |
973 | StorageInfo storageInfo; | 966 | StorageInfo storageInfo; |
974 | const QList<FileSystem> &fs = storageInfo.fileSystems(); | 967 | const QList<FileSystem> &fs = storageInfo.fileSystems(); |
975 | 968 | ||
976 | Global::findDocuments(&files, "audio/*"); | 969 | Global::findDocuments(&files, "audio/*"); |
977 | QListIterator<DocLnk> dit( files.children() ); | 970 | QListIterator<DocLnk> dit( files.children() ); |
978 | QListIterator<FileSystem> it ( fs ); | 971 | QListIterator<FileSystem> it ( fs ); |
979 | audioView->clear(); | 972 | audioView->clear(); |
980 | QString storage; | 973 | QString storage; |
981 | for ( ; dit.current(); ++dit ) { | 974 | for ( ; dit.current(); ++dit ) { |
982 | for( ; it.current(); ++it ){ | 975 | for( ; it.current(); ++it ){ |
983 | const QString name = (*it)->name(); | 976 | const QString name = (*it)->name(); |
984 | const QString path = (*it)->path(); | 977 | const QString path = (*it)->path(); |
985 | if(dit.current()->file().find(path) != -1 ) storage=name; | 978 | if(dit.current()->file().find(path) != -1 ) storage=name; |
986 | } | 979 | } |
987 | 980 | ||
988 | QListViewItem * newItem; | 981 | QListViewItem * newItem; |
989 | if ( QFile( dit.current()->file()).exists() ) { | 982 | if ( QFile( dit.current()->file()).exists() ) { |
990 | newItem= /*(void)*/ new QListViewItem( audioView, dit.current()->name(), QString::number( QFile( dit.current()->file()).size() ), storage); | 983 | newItem= /*(void)*/ new QListViewItem( audioView, dit.current()->name(), QString::number( QFile( dit.current()->file()).size() ), storage); |
991 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/musicfile" )); | 984 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/musicfile" )); |
992 | } | 985 | } |
993 | } | 986 | } |
994 | } | 987 | } |
995 | 988 | ||
996 | void PlayListWidget::populateVideoView() { | 989 | void PlayListWidget::populateVideoView() { |
997 | StorageInfo storageInfo; | 990 | StorageInfo storageInfo; |
998 | const QList<FileSystem> &fs = storageInfo.fileSystems(); | 991 | const QList<FileSystem> &fs = storageInfo.fileSystems(); |
999 | 992 | ||
1000 | Global::findDocuments(&vFiles, "video/*"); | 993 | Global::findDocuments(&vFiles, "video/*"); |
1001 | QListIterator<DocLnk> Vdit( vFiles.children() ); | 994 | QListIterator<DocLnk> Vdit( vFiles.children() ); |
1002 | QListIterator<FileSystem> it ( fs ); | 995 | QListIterator<FileSystem> it ( fs ); |
1003 | videoView->clear(); | 996 | videoView->clear(); |
1004 | QString storage; | 997 | QString storage; |
1005 | for ( ; Vdit.current(); ++Vdit ) { | 998 | for ( ; Vdit.current(); ++Vdit ) { |
1006 | for( ; it.current(); ++it ){ | 999 | for( ; it.current(); ++it ){ |
1007 | const QString name = (*it)->name(); | 1000 | const QString name = (*it)->name(); |
1008 | const QString path = (*it)->path(); | 1001 | const QString path = (*it)->path(); |
1009 | if( Vdit.current()->file().find(path) != -1 ) storage=name; | 1002 | if( Vdit.current()->file().find(path) != -1 ) storage=name; |
1010 | } | 1003 | } |
1011 | 1004 | ||
1012 | QListViewItem * newItem; | 1005 | QListViewItem * newItem; |
1013 | if ( QFile( Vdit.current()->file()).exists() ) { | 1006 | if ( QFile( Vdit.current()->file()).exists() ) { |
1014 | newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(), QString::number( QFile( Vdit.current()->file()).size() ), storage); | 1007 | newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(), QString::number( QFile( Vdit.current()->file()).size() ), storage); |
1015 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/videofile" )); | 1008 | newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/videofile" )); |
1016 | } | 1009 | } |
1017 | } | 1010 | } |
1018 | } | 1011 | } |
1019 | 1012 | ||
1020 | void PlayListWidget::openFile() { | 1013 | void PlayListWidget::openFile() { |
1021 | QString filename, name; | 1014 | QString filename, name; |
1022 | InputDialog *fileDlg; | 1015 | InputDialog *fileDlg; |
1023 | fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); | 1016 | fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); |
1024 | fileDlg->exec(); | 1017 | fileDlg->exec(); |
1025 | if( fileDlg->result() == 1 ) { | 1018 | if( fileDlg->result() == 1 ) { |
1026 | filename = fileDlg->LineEdit1->text(); | 1019 | filename = fileDlg->LineEdit1->text(); |
1027 | |||
1028 | // InputDialog *fileDlg2; | ||
1029 | // fileDlg2 = new InputDialog(this,tr("Name"),TRUE, 0); | ||
1030 | // fileDlg2->exec(); | ||
1031 | // if( fileDlg2->result() == 1 ) { | ||
1032 | // name = fileDlg2->LineEdit1->text(); | ||
1033 | // } | ||
1034 | //http://205.188.234.129:8030 | 1020 | //http://205.188.234.129:8030 |
1035 | // http://66.28.68.70:8000 | 1021 | // http://66.28.68.70:8000 |
1036 | qDebug(filename); | 1022 | qDebug(filename); |
1037 | DocLnk lnk; | 1023 | if(filename.right(3) == "m3u") |
1038 | // if(filename.left(7) == "http://") | 1024 | readm3u( filename); |
1039 | // name= filename.right(filename.length()-filename.find("http://")-7); | 1025 | else if(filename.right(3) == "pls") |
1040 | // else name = filename; | 1026 | readPls( filename); |
1041 | // qDebug("name is "+name); | 1027 | else { |
1042 | // lnk.setComment(filename); | 1028 | DocLnk lnk; |
1043 | lnk.setName(filename); //sets file name | 1029 | |
1044 | if(filename.right(1) != "/" && filename.right(3) != "mp3" && filename.right(3) != "MP3") | 1030 | lnk.setName(filename); //sets file name |
1045 | filename += "/"; | 1031 | if(filename.right(1) != "/" && filename.right(3) != "mp3" && filename.right(3) != "MP3") |
1046 | lnk.setFile(filename); //sets File property | 1032 | filename += "/"; |
1047 | 1033 | lnk.setFile(filename); //sets File property | |
1048 | lnk.setType("audio/x-mpegurl"); | 1034 | |
1049 | lnk.setExec("opieplayer"); | 1035 | lnk.setType("audio/x-mpegurl"); |
1050 | lnk.setIcon("opieplayer/MPEGPlayer"); | 1036 | lnk.setExec("opieplayer"); |
1051 | 1037 | lnk.setIcon("opieplayer/MPEGPlayer"); | |
1052 | if(!lnk.writeLink()) | 1038 | |
1053 | qDebug("Writing doclink did not work"); | 1039 | if(!lnk.writeLink()) |
1054 | d->selectedFiles->addToSelection( lnk); | 1040 | qDebug("Writing doclink did not work"); |
1041 | d->selectedFiles->addToSelection( lnk); | ||
1055 | // if(fileDlg2) | 1042 | // if(fileDlg2) |
1056 | // delete fileDlg2; | 1043 | // delete fileDlg2; |
1044 | } | ||
1057 | } | 1045 | } |
1058 | |||
1059 | if(fileDlg) | 1046 | if(fileDlg) |
1060 | delete fileDlg; | 1047 | delete fileDlg; |
1061 | } | 1048 | } |
1062 | 1049 | ||
1063 | void PlayListWidget::keyReleaseEvent( QKeyEvent *e) | 1050 | void PlayListWidget::keyReleaseEvent( QKeyEvent *e) |
1064 | { | 1051 | { |
1065 | switch ( e->key() ) { | 1052 | switch ( e->key() ) { |
1066 | ////////////////////////////// Zaurus keys | 1053 | ////////////////////////////// Zaurus keys |
1067 | case Key_F9: //activity | 1054 | case Key_F9: //activity |
1068 | // if(audioUI->isHidden()) | 1055 | // if(audioUI->isHidden()) |
1069 | // audioUI->showMaximized(); | 1056 | // audioUI->showMaximized(); |
1070 | break; | 1057 | break; |
1071 | case Key_F10: //contacts | 1058 | case Key_F10: //contacts |
1072 | // if( videoUI->isHidden()) | 1059 | // if( videoUI->isHidden()) |
1073 | // videoUI->showMaximized(); | 1060 | // videoUI->showMaximized(); |
1074 | break; | 1061 | break; |
1075 | case Key_F11: //menu | 1062 | case Key_F11: //menu |
1076 | break; | 1063 | break; |
1077 | case Key_F12: //home | 1064 | case Key_F12: //home |
1078 | // doBlank(); | 1065 | // doBlank(); |
1079 | break; | 1066 | break; |
1080 | case Key_F13: //mail | 1067 | case Key_F13: //mail |
1081 | // doUnblank(); | 1068 | // doUnblank(); |
1082 | break; | 1069 | break; |
1083 | 1070 | ||
1084 | } | 1071 | } |
1085 | } | 1072 | } |
1086 | 1073 | ||
1087 | void PlayListWidget::doBlank() { | 1074 | void PlayListWidget::doBlank() { |
1088 | qDebug("do blanking"); | 1075 | qDebug("do blanking"); |
1089 | fd=open("/dev/fb0",O_RDWR); | 1076 | fd=open("/dev/fb0",O_RDWR); |
1090 | if (fd != -1) { | 1077 | if (fd != -1) { |
1091 | ioctl(fd,FBIOBLANK,1); | 1078 | ioctl(fd,FBIOBLANK,1); |
1092 | // close(fd); | 1079 | // close(fd); |
1093 | } | 1080 | } |
1094 | } | 1081 | } |
1095 | 1082 | ||
1096 | void PlayListWidget::doUnblank() { | 1083 | void PlayListWidget::doUnblank() { |
1097 | // this crashes opieplayer with a segfault | 1084 | // this crashes opieplayer with a segfault |
1098 | // int fd; | 1085 | // int fd; |
1099 | // fd=open("/dev/fb0",O_RDWR); | 1086 | // fd=open("/dev/fb0",O_RDWR); |
1100 | qDebug("do unblanking"); | 1087 | qDebug("do unblanking"); |
1101 | if (fd != -1) { | 1088 | if (fd != -1) { |
1102 | ioctl(fd,FBIOBLANK,0); | 1089 | ioctl(fd,FBIOBLANK,0); |
1103 | close(fd); | 1090 | close(fd); |
1104 | } | 1091 | } |
1105 | QCopEnvelope h("QPE/System", "setBacklight(int)"); | 1092 | QCopEnvelope h("QPE/System", "setBacklight(int)"); |
1106 | h <<-3;// v[1]; // -3 Force on | 1093 | h <<-3;// v[1]; // -3 Force on |
1107 | } | 1094 | } |
1095 | |||
1096 | void PlayListWidget::readm3u(const QString &filename) { | ||
1097 | |||
1098 | } | ||
1099 | |||
1100 | void PlayListWidget::writem3u(const QString &filename) { | ||
1101 | |||
1102 | } | ||
1103 | |||
1104 | void PlayListWidget::readPls(const QString &filename) { | ||
1105 | |||
1106 | } | ||
diff --git a/core/multimedia/opieplayer/playlistwidget.h b/core/multimedia/opieplayer/playlistwidget.h index f22770f..c07d4f8 100644 --- a/core/multimedia/opieplayer/playlistwidget.h +++ b/core/multimedia/opieplayer/playlistwidget.h | |||
@@ -1,117 +1,121 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | #ifndef PLAY_LIST_WIDGET_H | 20 | #ifndef PLAY_LIST_WIDGET_H |
21 | #define PLAY_LIST_WIDGET_H | 21 | #define PLAY_LIST_WIDGET_H |
22 | 22 | ||
23 | #include <qmainwindow.h> | 23 | #include <qmainwindow.h> |
24 | #include <qpe/applnk.h> | 24 | #include <qpe/applnk.h> |
25 | #include <qtabwidget.h> | 25 | #include <qtabwidget.h> |
26 | #include <qpe/fileselector.h> | 26 | #include <qpe/fileselector.h> |
27 | #include <qpushbutton.h> | 27 | #include <qpushbutton.h> |
28 | 28 | ||
29 | /* #include <qtimer.h> */ | 29 | /* #include <qtimer.h> */ |
30 | 30 | ||
31 | 31 | ||
32 | class PlayListWidgetPrivate; | 32 | class PlayListWidgetPrivate; |
33 | class Config; | 33 | class Config; |
34 | class QListViewItem; | 34 | class QListViewItem; |
35 | class QListView; | 35 | class QListView; |
36 | class QPoint; | 36 | class QPoint; |
37 | class QAction; | 37 | class QAction; |
38 | class QLabel; | 38 | class QLabel; |
39 | 39 | ||
40 | class PlayListWidget : public QMainWindow { | 40 | class PlayListWidget : public QMainWindow { |
41 | Q_OBJECT | 41 | Q_OBJECT |
42 | public: | 42 | public: |
43 | PlayListWidget( QWidget* parent=0, const char* name=0, WFlags fl=0 ); | 43 | PlayListWidget( QWidget* parent=0, const char* name=0, WFlags fl=0 ); |
44 | ~PlayListWidget(); | 44 | ~PlayListWidget(); |
45 | QTabWidget * tabWidget; | 45 | QTabWidget * tabWidget; |
46 | QAction *fullScreenButton, *scaleButton; | 46 | QAction *fullScreenButton, *scaleButton; |
47 | DocLnkSet files; | 47 | DocLnkSet files; |
48 | DocLnkSet vFiles; | 48 | DocLnkSet vFiles; |
49 | QListView *audioView, *videoView, *playlistView; | 49 | QListView *audioView, *videoView, *playlistView; |
50 | QLabel *libString; | 50 | QLabel *libString; |
51 | bool fromSetDocument; | 51 | bool fromSetDocument; |
52 | bool insanityBool; | 52 | bool insanityBool; |
53 | QString setDocFileRef; | 53 | QString setDocFileRef; |
54 | // retrieve the current playlist entry (media file link) | 54 | // retrieve the current playlist entry (media file link) |
55 | const DocLnk *current(); | 55 | const DocLnk *current(); |
56 | void useSelectedDocument(); | 56 | void useSelectedDocument(); |
57 | /* QTimer * menuTimer; */ | 57 | /* QTimer * menuTimer; */ |
58 | FileSelector* playLists; | 58 | FileSelector* playLists; |
59 | QPushButton *tbDeletePlaylist; | 59 | QPushButton *tbDeletePlaylist; |
60 | int fd; | 60 | int fd; |
61 | public slots: | 61 | public slots: |
62 | bool first(); | 62 | bool first(); |
63 | bool last(); | 63 | bool last(); |
64 | bool next(); | 64 | bool next(); |
65 | bool prev(); | 65 | bool prev(); |
66 | /* void setFullScreen(); */ | 66 | /* void setFullScreen(); */ |
67 | /* void setScaled(); */ | 67 | /* void setScaled(); */ |
68 | protected: | 68 | protected: |
69 | /* void contentsMousePressEvent( QMouseEvent * e ); */ | 69 | /* void contentsMousePressEvent( QMouseEvent * e ); */ |
70 | /* void contentsMouseReleaseEvent( QMouseEvent * e ); */ | 70 | /* void contentsMouseReleaseEvent( QMouseEvent * e ); */ |
71 | void keyReleaseEvent( QKeyEvent *e); | 71 | void keyReleaseEvent( QKeyEvent *e); |
72 | private: | 72 | private: |
73 | void doBlank(); | 73 | void doBlank(); |
74 | void doUnblank(); | 74 | void doUnblank(); |
75 | 75 | void readm3u(const QString &); | |
76 | void writem3u(const QString &); | ||
77 | void readPls(const QString &); | ||
78 | |||
79 | |||
76 | void initializeStates(); | 80 | void initializeStates(); |
77 | void readConfig( Config& cfg ); | 81 | void readConfig( Config& cfg ); |
78 | void writeConfig( Config& cfg ) const; | 82 | void writeConfig( Config& cfg ) const; |
79 | PlayListWidgetPrivate *d; // Private implementation data | 83 | PlayListWidgetPrivate *d; // Private implementation data |
80 | void populateAudioView(); | 84 | void populateAudioView(); |
81 | void populateVideoView(); | 85 | void populateVideoView(); |
82 | private slots: | 86 | private slots: |
83 | void openFile(); | 87 | void openFile(); |
84 | void setDocument( const QString& fileref ); | 88 | void setDocument( const QString& fileref ); |
85 | void addToSelection( const DocLnk& ); // Add a media file to the playlist | 89 | void addToSelection( const DocLnk& ); // Add a media file to the playlist |
86 | void addToSelection( QListViewItem* ); // Add a media file to the playlist | 90 | void addToSelection( QListViewItem* ); // Add a media file to the playlist |
87 | void setActiveWindow(); // need to handle this to show the right view | 91 | void setActiveWindow(); // need to handle this to show the right view |
88 | void setPlaylist( bool ); // Show/Hide the playlist | 92 | void setPlaylist( bool ); // Show/Hide the playlist |
89 | void setView( char ); | 93 | void setView( char ); |
90 | void clearList(); | 94 | void clearList(); |
91 | void addAllToList(); | 95 | void addAllToList(); |
92 | void addAllMusicToList(); | 96 | void addAllMusicToList(); |
93 | void addAllVideoToList(); | 97 | void addAllVideoToList(); |
94 | void saveList(); // Save the playlist | 98 | void saveList(); // Save the playlist |
95 | void loadList( const DocLnk &); // Load a playlist | 99 | void loadList( const DocLnk &); // Load a playlist |
96 | void playIt( QListViewItem *); | 100 | void playIt( QListViewItem *); |
97 | 101 | ||
98 | void btnPlay(bool); | 102 | void btnPlay(bool); |
99 | void deletePlaylist(); | 103 | void deletePlaylist(); |
100 | void addSelected(); | 104 | void addSelected(); |
101 | void removeSelected(); | 105 | void removeSelected(); |
102 | void tabChanged(QWidget*); | 106 | void tabChanged(QWidget*); |
103 | void viewPressed( int, QListViewItem *, const QPoint&, int); | 107 | void viewPressed( int, QListViewItem *, const QPoint&, int); |
104 | void playlistViewPressed( int, QListViewItem *, const QPoint&, int); | 108 | void playlistViewPressed( int, QListViewItem *, const QPoint&, int); |
105 | void playSelected(); | 109 | void playSelected(); |
106 | void listDelete(); | 110 | void listDelete(); |
107 | 111 | ||
108 | protected slots: | 112 | protected slots: |
109 | /* void cancelMenuTimer(); */ | 113 | /* void cancelMenuTimer(); */ |
110 | /* void showFileMenu(); */ | 114 | /* void showFileMenu(); */ |
111 | 115 | ||
112 | 116 | ||
113 | }; | 117 | }; |
114 | 118 | ||
115 | 119 | ||
116 | #endif // PLAY_LIST_WIDGET_H | 120 | #endif // PLAY_LIST_WIDGET_H |
117 | 121 | ||
diff --git a/core/multimedia/opieplayer/videowidget.cpp b/core/multimedia/opieplayer/videowidget.cpp index 3bce996..97997f9 100644 --- a/core/multimedia/opieplayer/videowidget.cpp +++ b/core/multimedia/opieplayer/videowidget.cpp | |||
@@ -1,175 +1,186 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | #include <qpe/resource.h> | 20 | #include <qpe/resource.h> |
21 | #include <qpe/mediaplayerplugininterface.h> | 21 | #include <qpe/mediaplayerplugininterface.h> |
22 | #include <qpe/config.h> | ||
23 | |||
22 | #include <qwidget.h> | 24 | #include <qwidget.h> |
23 | #include <qpainter.h> | 25 | #include <qpainter.h> |
24 | #include <qpixmap.h> | 26 | #include <qpixmap.h> |
25 | #include <qslider.h> | 27 | #include <qslider.h> |
26 | #include <qdrawutil.h> | 28 | #include <qdrawutil.h> |
27 | #include "videowidget.h" | 29 | #include "videowidget.h" |
28 | #include "mediaplayerstate.h" | 30 | #include "mediaplayerstate.h" |
29 | 31 | ||
30 | 32 | ||
31 | #ifdef Q_WS_QWS | 33 | #ifdef Q_WS_QWS |
32 | # define USE_DIRECT_PAINTER | 34 | # define USE_DIRECT_PAINTER |
33 | # include <qdirectpainter_qws.h> | 35 | # include <qdirectpainter_qws.h> |
34 | # include <qgfxraster_qws.h> | 36 | # include <qgfxraster_qws.h> |
35 | #endif | 37 | #endif |
36 | 38 | ||
37 | 39 | ||
38 | extern MediaPlayerState *mediaPlayerState; | 40 | extern MediaPlayerState *mediaPlayerState; |
39 | 41 | ||
40 | 42 | ||
41 | static const int xo = 2; // movable x offset | 43 | static const int xo = 2; // movable x offset |
42 | static const int yo = 0; // movable y offset | 44 | static const int yo = 0; // movable y offset |
43 | 45 | ||
44 | 46 | ||
45 | struct MediaButton { | 47 | struct MediaButton { |
46 | int xPos, yPos; | 48 | int xPos, yPos; |
47 | bool isToggle, isHeld, isDown; | 49 | bool isToggle, isHeld, isDown; |
48 | int controlType; | 50 | int controlType; |
49 | }; | 51 | }; |
50 | 52 | ||
51 | 53 | ||
52 | // Layout information for the videoButtons (and if it is a toggle button or not) | 54 | // Layout information for the videoButtons (and if it is a toggle button or not) |
53 | MediaButton videoButtons[] = { | 55 | MediaButton videoButtons[] = { |
54 | { 5+0*32+xo, 200+yo, FALSE, FALSE, FALSE, 4 }, // previous | 56 | { 5+0*32+xo, 200+yo, FALSE, FALSE, FALSE, 4 }, // previous |
55 | { 5+1*32+xo, 200+yo, FALSE, FALSE, FALSE, 1 }, // stop | 57 | { 5+1*32+xo, 200+yo, FALSE, FALSE, FALSE, 1 }, // stop |
56 | { 5+2*32+xo, 200+yo, TRUE, FALSE, FALSE, 0 }, // play | 58 | { 5+2*32+xo, 200+yo, TRUE, FALSE, FALSE, 0 }, // play |
57 | { 5+3*32+xo, 200+yo, TRUE, FALSE, FALSE, 2 }, // pause | 59 | { 5+3*32+xo, 200+yo, TRUE, FALSE, FALSE, 2 }, // pause |
58 | { 5+4*32+xo, 200+yo, FALSE, FALSE, FALSE, 3 }, // next | 60 | { 5+4*32+xo, 200+yo, FALSE, FALSE, FALSE, 3 }, // next |
59 | { 5+5*32+xo, 200+yo, FALSE, FALSE, FALSE, 8 }, // playlist | 61 | { 5+5*32+xo, 200+yo, FALSE, FALSE, FALSE, 8 }, // playlist |
60 | { 5+6*32+xo, 200+yo, TRUE, FALSE, FALSE, 9 } // fullscreen | 62 | { 5+6*32+xo, 200+yo, TRUE, FALSE, FALSE, 9 } // fullscreen |
61 | }; | 63 | }; |
62 | 64 | ||
63 | 65 | ||
64 | static const int numButtons = (sizeof(videoButtons)/sizeof(MediaButton)); | 66 | static const int numButtons = (sizeof(videoButtons)/sizeof(MediaButton)); |
65 | 67 | ||
66 | 68 | ||
67 | VideoWidget::VideoWidget(QWidget* parent, const char* name, WFlags f) : | 69 | VideoWidget::VideoWidget(QWidget* parent, const char* name, WFlags f) : |
68 | QWidget( parent, name, f ), scaledWidth( 0 ), scaledHeight( 0 ) { | 70 | QWidget( parent, name, f ), scaledWidth( 0 ), scaledHeight( 0 ) { |
69 | setCaption( tr("OpiePlayer") ); | 71 | setCaption( tr("OpiePlayer") ); |
70 | setBackgroundPixmap( Resource::loadPixmap( "opieplayer/metalFinish" ) ); | 72 | Config cfg("OpiePlayer"); |
71 | pixmaps[0] = new QPixmap( Resource::loadPixmap( "opieplayer/mediaButton0a" ) ); | 73 | cfg.setGroup("VideoWidget"); |
72 | pixmaps[1] = new QPixmap( Resource::loadPixmap( "opieplayer/mediaButton0b" ) ); | 74 | |
73 | pixmaps[2] = new QPixmap( Resource::loadPixmap( "opieplayer/mediaControls0" ) ); | 75 | QString backgroundPix, Button0aPix, Button0bPix, controlsPix; |
76 | backgroundPix=cfg.readEntry( "backgroundPix", "opieplayer/metalFinish"); | ||
77 | Button0aPix=cfg.readEntry( "Button0aPix", "opieplayer/mediaButton0a"); | ||
78 | Button0bPix=cfg.readEntry( "Button0bPix","opieplayer/mediaButton0b"); | ||
79 | controlsPix=cfg.readEntry( "controlsPix","opieplayer/mediaControls0" ); | ||
80 | |||
81 | setBackgroundPixmap( Resource::loadPixmap( backgroundPix) ); | ||
82 | pixmaps[0] = new QPixmap( Resource::loadPixmap( Button0aPix ) ); | ||
83 | pixmaps[1] = new QPixmap( Resource::loadPixmap( Button0bPix ) ); | ||
84 | pixmaps[2] = new QPixmap( Resource::loadPixmap( controlsPix) ); | ||
74 | currentFrame = new QImage( 220 + 2, 160, (QPixmap::defaultDepth() == 16) ? 16 : 32 ); | 85 | currentFrame = new QImage( 220 + 2, 160, (QPixmap::defaultDepth() == 16) ? 16 : 32 ); |
75 | 86 | ||
76 | slider = new QSlider( Qt::Horizontal, this ); | 87 | slider = new QSlider( Qt::Horizontal, this ); |
77 | slider->setMinValue( 0 ); | 88 | slider->setMinValue( 0 ); |
78 | slider->setMaxValue( 1 ); | 89 | slider->setMaxValue( 1 ); |
79 | slider->setBackgroundPixmap( Resource::loadPixmap( "opieplayer/metalFinish" ) ); | 90 | slider->setBackgroundPixmap( Resource::loadPixmap( backgroundPix ) ); |
80 | slider->setFocusPolicy( QWidget::NoFocus ); | 91 | slider->setFocusPolicy( QWidget::NoFocus ); |
81 | slider->setGeometry( QRect( 7, 250, 220, 20 ) ); | 92 | slider->setGeometry( QRect( 7, 250, 220, 20 ) ); |
82 | 93 | ||
83 | connect( slider, SIGNAL( sliderPressed() ), this, SLOT( sliderPressed() ) ); | 94 | connect( slider, SIGNAL( sliderPressed() ), this, SLOT( sliderPressed() ) ); |
84 | connect( slider, SIGNAL( sliderReleased() ), this, SLOT( sliderReleased() ) ); | 95 | connect( slider, SIGNAL( sliderReleased() ), this, SLOT( sliderReleased() ) ); |
85 | 96 | ||
86 | connect( mediaPlayerState, SIGNAL( lengthChanged(long) ), this, SLOT( setLength(long) ) ); | 97 | connect( mediaPlayerState, SIGNAL( lengthChanged(long) ), this, SLOT( setLength(long) ) ); |
87 | connect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); | 98 | connect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); |
88 | connect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); | 99 | connect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); |
89 | connect( mediaPlayerState, SIGNAL( viewChanged(char) ), this, SLOT( setView(char) ) ); | 100 | connect( mediaPlayerState, SIGNAL( viewChanged(char) ), this, SLOT( setView(char) ) ); |
90 | connect( mediaPlayerState, SIGNAL( pausedToggled(bool) ), this, SLOT( setPaused(bool) ) ); | 101 | connect( mediaPlayerState, SIGNAL( pausedToggled(bool) ), this, SLOT( setPaused(bool) ) ); |
91 | connect( mediaPlayerState, SIGNAL( playingToggled(bool) ), this, SLOT( setPlaying(bool) ) ); | 102 | connect( mediaPlayerState, SIGNAL( playingToggled(bool) ), this, SLOT( setPlaying(bool) ) ); |
92 | 103 | ||
93 | // Intialise state | 104 | // Intialise state |
94 | setLength( mediaPlayerState->length() ); | 105 | setLength( mediaPlayerState->length() ); |
95 | setPosition( mediaPlayerState->position() ); | 106 | setPosition( mediaPlayerState->position() ); |
96 | setFullscreen( mediaPlayerState->fullscreen() ); | 107 | setFullscreen( mediaPlayerState->fullscreen() ); |
97 | setPaused( mediaPlayerState->paused() ); | 108 | setPaused( mediaPlayerState->paused() ); |
98 | setPlaying( mediaPlayerState->playing() ); | 109 | setPlaying( mediaPlayerState->playing() ); |
99 | } | 110 | } |
100 | 111 | ||
101 | 112 | ||
102 | VideoWidget::~VideoWidget() { | 113 | VideoWidget::~VideoWidget() { |
103 | for ( int i = 0; i < 3; i++ ) | 114 | for ( int i = 0; i < 3; i++ ) |
104 | delete pixmaps[i]; | 115 | delete pixmaps[i]; |
105 | delete currentFrame; | 116 | delete currentFrame; |
106 | } | 117 | } |
107 | 118 | ||
108 | 119 | ||
109 | static bool videoSliderBeingMoved = FALSE; | 120 | static bool videoSliderBeingMoved = FALSE; |
110 | 121 | ||
111 | 122 | ||
112 | void VideoWidget::sliderPressed() { | 123 | void VideoWidget::sliderPressed() { |
113 | videoSliderBeingMoved = TRUE; | 124 | videoSliderBeingMoved = TRUE; |
114 | } | 125 | } |
115 | 126 | ||
116 | 127 | ||
117 | void VideoWidget::sliderReleased() { | 128 | void VideoWidget::sliderReleased() { |
118 | videoSliderBeingMoved = FALSE; | 129 | videoSliderBeingMoved = FALSE; |
119 | if ( slider->width() == 0 ) | 130 | if ( slider->width() == 0 ) |
120 | return; | 131 | return; |
121 | long val = long((double)slider->value() * mediaPlayerState->length() / slider->width()); | 132 | long val = long((double)slider->value() * mediaPlayerState->length() / slider->width()); |
122 | mediaPlayerState->setPosition( val ); | 133 | mediaPlayerState->setPosition( val ); |
123 | } | 134 | } |
124 | 135 | ||
125 | 136 | ||
126 | void VideoWidget::setPosition( long i ) { | 137 | void VideoWidget::setPosition( long i ) { |
127 | updateSlider( i, mediaPlayerState->length() ); | 138 | updateSlider( i, mediaPlayerState->length() ); |
128 | } | 139 | } |
129 | 140 | ||
130 | 141 | ||
131 | void VideoWidget::setLength( long max ) { | 142 | void VideoWidget::setLength( long max ) { |
132 | updateSlider( mediaPlayerState->position(), max ); | 143 | updateSlider( mediaPlayerState->position(), max ); |
133 | } | 144 | } |
134 | 145 | ||
135 | 146 | ||
136 | void VideoWidget::setView( char view ) { | 147 | void VideoWidget::setView( char view ) { |
137 | if ( view == 'v' ) { | 148 | if ( view == 'v' ) { |
138 | makeVisible(); | 149 | makeVisible(); |
139 | } else { | 150 | } else { |
140 | // Effectively blank the view next time we show it so it looks nicer | 151 | // Effectively blank the view next time we show it so it looks nicer |
141 | scaledWidth = 0; | 152 | scaledWidth = 0; |
142 | scaledHeight = 0; | 153 | scaledHeight = 0; |
143 | hide(); | 154 | hide(); |
144 | } | 155 | } |
145 | } | 156 | } |
146 | 157 | ||
147 | 158 | ||
148 | void VideoWidget::updateSlider( long i, long max ) { | 159 | void VideoWidget::updateSlider( long i, long max ) { |
149 | // Will flicker too much if we don't do this | 160 | // Will flicker too much if we don't do this |
150 | if ( max == 0 ) | 161 | if ( max == 0 ) |
151 | return; | 162 | return; |
152 | int width = slider->width(); | 163 | int width = slider->width(); |
153 | int val = int((double)i * width / max); | 164 | int val = int((double)i * width / max); |
154 | if ( !mediaPlayerState->fullscreen() && !videoSliderBeingMoved ) { | 165 | if ( !mediaPlayerState->fullscreen() && !videoSliderBeingMoved ) { |
155 | if ( slider->value() != val ) | 166 | if ( slider->value() != val ) |
156 | slider->setValue( val ); | 167 | slider->setValue( val ); |
157 | if ( slider->maxValue() != width ) | 168 | if ( slider->maxValue() != width ) |
158 | slider->setMaxValue( width ); | 169 | slider->setMaxValue( width ); |
159 | } | 170 | } |
160 | } | 171 | } |
161 | 172 | ||
162 | 173 | ||
163 | void VideoWidget::setToggleButton( int i, bool down ) { | 174 | void VideoWidget::setToggleButton( int i, bool down ) { |
164 | if ( down != videoButtons[i].isDown ) | 175 | if ( down != videoButtons[i].isDown ) |
165 | toggleButton( i ); | 176 | toggleButton( i ); |
166 | } | 177 | } |
167 | 178 | ||
168 | 179 | ||
169 | void VideoWidget::toggleButton( int i ) { | 180 | void VideoWidget::toggleButton( int i ) { |
170 | videoButtons[i].isDown = !videoButtons[i].isDown; | 181 | videoButtons[i].isDown = !videoButtons[i].isDown; |
171 | QPainter p(this); | 182 | QPainter p(this); |
172 | paintButton ( &p, i ); | 183 | paintButton ( &p, i ); |
173 | } | 184 | } |
174 | 185 | ||
175 | 186 | ||