summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/multimedia/opieplayer2/mediaplayer.cpp21
-rw-r--r--noncore/multimedia/opieplayer2/mediaplayerstate.cpp19
-rw-r--r--noncore/multimedia/opieplayer2/playlistwidget.cpp4
-rw-r--r--noncore/multimedia/opieplayer2/playlistwidget.h1
-rw-r--r--noncore/multimedia/opieplayer2/videowidget.cpp99
-rw-r--r--noncore/multimedia/opieplayer2/videowidget.h11
6 files changed, 105 insertions, 50 deletions
diff --git a/noncore/multimedia/opieplayer2/mediaplayer.cpp b/noncore/multimedia/opieplayer2/mediaplayer.cpp
index 8d8e4e5..a3238f0 100644
--- a/noncore/multimedia/opieplayer2/mediaplayer.cpp
+++ b/noncore/multimedia/opieplayer2/mediaplayer.cpp
@@ -1,238 +1,239 @@
1#include <qpe/qpeapplication.h> 1#include <qpe/qpeapplication.h>
2#include <qpe/qlibrary.h> 2#include <qpe/qlibrary.h>
3#include <qpe/resource.h> 3#include <qpe/resource.h>
4#include <qpe/config.h> 4#include <qpe/config.h>
5 5
6#include <qmainwindow.h> 6#include <qmainwindow.h>
7#include <qmessagebox.h> 7#include <qmessagebox.h>
8#include <qwidgetstack.h> 8#include <qwidgetstack.h>
9#include <qfile.h> 9#include <qfile.h>
10 10
11#include "mediaplayer.h" 11#include "mediaplayer.h"
12#include "playlistwidget.h" 12#include "playlistwidget.h"
13#include "audiowidget.h" 13#include "audiowidget.h"
14#include "volumecontrol.h" 14#include "volumecontrol.h"
15 15
16#include "mediaplayerstate.h" 16#include "mediaplayerstate.h"
17 17
18 18
19 19
20extern AudioWidget *audioUI; 20extern AudioWidget *audioUI;
21extern PlayListWidget *playList; 21extern PlayListWidget *playList;
22extern MediaPlayerState *mediaPlayerState; 22extern MediaPlayerState *mediaPlayerState;
23 23
24 24
25MediaPlayer::MediaPlayer( QObject *parent, const char *name ) 25MediaPlayer::MediaPlayer( QObject *parent, const char *name )
26 : QObject( parent, name ), volumeDirection( 0 ), currentFile( NULL ) { 26 : QObject( parent, name ), volumeDirection( 0 ), currentFile( NULL ) {
27 27
28 28
29 xineControl = new XineControl(); 29 xineControl = new XineControl();
30// QPEApplication::grabKeyboard(); // EVIL 30// QPEApplication::grabKeyboard(); // EVIL
31 connect( qApp,SIGNAL( aboutToQuit()),SLOT( cleanUp()) ); 31 connect( qApp,SIGNAL( aboutToQuit()),SLOT( cleanUp()) );
32 32
33 connect( mediaPlayerState, SIGNAL( playingToggled( bool ) ), this, SLOT( setPlaying( bool ) ) ); 33 connect( mediaPlayerState, SIGNAL( playingToggled( bool ) ), this, SLOT( setPlaying( bool ) ) );
34
34 connect( mediaPlayerState, SIGNAL( pausedToggled( bool ) ), this, SLOT( pauseCheck( bool ) ) ); 35 connect( mediaPlayerState, SIGNAL( pausedToggled( bool ) ), this, SLOT( pauseCheck( bool ) ) );
36
35 connect( mediaPlayerState, SIGNAL( next() ), this, SLOT( next() ) ); 37 connect( mediaPlayerState, SIGNAL( next() ), this, SLOT( next() ) );
36 connect( mediaPlayerState, SIGNAL( prev() ), this, SLOT( prev() ) ); 38 connect( mediaPlayerState, SIGNAL( prev() ), this, SLOT( prev() ) );
37 39
38 connect( audioUI, SIGNAL( moreClicked() ), this, SLOT( startIncreasingVolume() ) ); 40 connect( audioUI, SIGNAL( moreClicked() ), this, SLOT( startIncreasingVolume() ) );
39 connect( audioUI, SIGNAL( lessClicked() ), this, SLOT( startDecreasingVolume() ) ); 41 connect( audioUI, SIGNAL( lessClicked() ), this, SLOT( startDecreasingVolume() ) );
40 connect( audioUI, SIGNAL( moreReleased() ), this, SLOT( stopChangingVolume() ) ); 42 connect( audioUI, SIGNAL( moreReleased() ), this, SLOT( stopChangingVolume() ) );
41 connect( audioUI, SIGNAL( lessReleased() ), this, SLOT( stopChangingVolume() ) ); 43 connect( audioUI, SIGNAL( lessReleased() ), this, SLOT( stopChangingVolume() ) );
42 44
43 volControl = new VolumeControl; 45 volControl = new VolumeControl;
44 46
45} 47}
46 48
47MediaPlayer::~MediaPlayer() { 49MediaPlayer::~MediaPlayer() {
48 delete xineControl; 50 delete xineControl;
49 delete volControl; 51 delete volControl;
50} 52}
51 53
52void MediaPlayer::pauseCheck( bool b ) { 54void MediaPlayer::pauseCheck( bool b ) {
53 // Only pause if playing 55 if ( b && !mediaPlayerState->playing() ) {
54 if ( b && !mediaPlayerState->playing() ) { 56 mediaPlayerState->setPaused( FALSE );
55 mediaPlayerState->setPaused( FALSE ); 57 }
56 }
57} 58}
58 59
59void MediaPlayer::play() { 60void MediaPlayer::play() {
60 mediaPlayerState->setPlaying( FALSE ); 61 mediaPlayerState->setPlaying( FALSE );
61 mediaPlayerState->setPlaying( TRUE ); 62 mediaPlayerState->setPlaying( TRUE );
62} 63}
63 64
64void MediaPlayer::setPlaying( bool play ) { 65void MediaPlayer::setPlaying( bool play ) {
65 if ( !play ) { 66 if ( !play ) {
66 mediaPlayerState->setPaused( FALSE ); 67 mediaPlayerState->setPaused( FALSE );
67 return; 68 return;
68 } 69 }
69 70
70 if ( mediaPlayerState->paused() ) { 71 if ( mediaPlayerState->paused() ) {
71 mediaPlayerState->setPaused( FALSE ); 72 mediaPlayerState->setPaused( FALSE );
72 return; 73 return;
73 } 74 }
74 75
75 const DocLnk *playListCurrent = playList->current(); 76 const DocLnk *playListCurrent = playList->current();
76 if ( playListCurrent != NULL ) { 77 if ( playListCurrent != NULL ) {
77 currentFile = playListCurrent; 78 currentFile = playListCurrent;
78 } 79 }
79 80
80 xineControl->play( currentFile->file() ); 81 xineControl->play( currentFile->file() );
81 82
82 xineControl->length(); 83 xineControl->length();
83 long seconds = mediaPlayerState->length();// 84 long seconds = mediaPlayerState->length();//
84 QString time; time.sprintf("%li:%02i", seconds/60, (int)seconds%60 ); 85 QString time; time.sprintf("%li:%02i", seconds/60, (int)seconds%60 );
85 qDebug(time); 86 qDebug(time);
86 87
87 QString tickerText; 88 QString tickerText;
88 if( currentFile->file().left(4) == "http" ) 89 if( currentFile->file().left(4) == "http" )
89 tickerText= tr( " File: " ) + currentFile->name(); 90 tickerText= tr( " File: " ) + currentFile->name();
90 else 91 else
91 tickerText = tr( " File: " ) + currentFile->name() + tr(", Length: ") + time; 92 tickerText = tr( " File: " ) + currentFile->name() + tr(", Length: ") + time;
92 93
93// QString fileInfo = mediaPlayerState->curDecoder()->fileInfo(); 94// QString fileInfo = mediaPlayerState->curDecoder()->fileInfo();
94 95
95// if ( !fileInfo.isEmpty() ) 96// if ( !fileInfo.isEmpty() )
96// tickerText += ", " + fileInfo; 97// tickerText += ", " + fileInfo;
97// audioUI->setTickerText( tickerText + "." ); 98// audioUI->setTickerText( tickerText + "." );
98 99
99 audioUI->setTickerText( currentFile->file( ) ); 100 audioUI->setTickerText( currentFile->file( ) );
100 101
101} 102}
102 103
103 104
104void MediaPlayer::prev() { 105void MediaPlayer::prev() {
105 if ( playList->prev() ) { 106 if ( playList->prev() ) {
106 play(); 107 play();
107 } else if ( mediaPlayerState->looping() ) { 108 } else if ( mediaPlayerState->looping() ) {
108 if ( playList->last() ) { 109 if ( playList->last() ) {
109 play(); 110 play();
110 } 111 }
111 } else { 112 } else {
112 mediaPlayerState->setList(); 113 mediaPlayerState->setList();
113 } 114 }
114} 115}
115 116
116 117
117void MediaPlayer::next() { 118void MediaPlayer::next() {
118 if ( playList->next() ) { 119 if ( playList->next() ) {
119 play(); 120 play();
120 } else if ( mediaPlayerState->looping() ) { 121 } else if ( mediaPlayerState->looping() ) {
121 if ( playList->first() ) { 122 if ( playList->first() ) {
122 play(); 123 play();
123 } 124 }
124 } else { 125 } else {
125 mediaPlayerState->setList(); 126 mediaPlayerState->setList();
126 } 127 }
127} 128}
128 129
129 130
130void MediaPlayer::startDecreasingVolume() { 131void MediaPlayer::startDecreasingVolume() {
131 volumeDirection = -1; 132 volumeDirection = -1;
132 startTimer( 100 ); 133 startTimer( 100 );
133 volControl->decVol(2); 134 volControl->decVol(2);
134} 135}
135 136
136 137
137void MediaPlayer::startIncreasingVolume() { 138void MediaPlayer::startIncreasingVolume() {
138 volumeDirection = +1; 139 volumeDirection = +1;
139 startTimer( 100 ); 140 startTimer( 100 );
140 volControl->incVol(2); 141 volControl->incVol(2);
141} 142}
142 143
143 144
144bool drawnOnScreenDisplay = FALSE; 145bool drawnOnScreenDisplay = FALSE;
145unsigned int onScreenDisplayVolume = 0; 146unsigned int onScreenDisplayVolume = 0;
146const int yoff = 110; 147const int yoff = 110;
147 148
148void MediaPlayer::stopChangingVolume() { 149void MediaPlayer::stopChangingVolume() {
149 killTimers(); 150 killTimers();
150 // Get rid of the on-screen display stuff 151 // Get rid of the on-screen display stuff
151 drawnOnScreenDisplay = FALSE; 152 drawnOnScreenDisplay = FALSE;
152 onScreenDisplayVolume = 0; 153 onScreenDisplayVolume = 0;
153 int w = audioUI->width(); 154 int w = audioUI->width();
154 int h = audioUI->height(); 155 int h = audioUI->height();
155 audioUI->repaint( (w - 200) / 2, h - yoff, 200 + 9, 70, FALSE ); 156 audioUI->repaint( (w - 200) / 2, h - yoff, 200 + 9, 70, FALSE );
156} 157}
157 158
158 159
159void MediaPlayer::timerEvent( QTimerEvent * ) { 160void MediaPlayer::timerEvent( QTimerEvent * ) {
160 if ( volumeDirection == +1 ) { 161 if ( volumeDirection == +1 ) {
161 volControl->incVol(2); 162 volControl->incVol(2);
162 } else if ( volumeDirection == -1 ) { 163 } else if ( volumeDirection == -1 ) {
163 volControl->decVol(2); 164 volControl->decVol(2);
164 } 165 }
165 166
166 167
167 // TODO FIXME 168 // TODO FIXME
168 int v; 169 int v;
169 v = volControl->getVolume(); 170 v = volControl->getVolume();
170 v = v / 10; 171 v = v / 10;
171 172
172 if ( drawnOnScreenDisplay && onScreenDisplayVolume == v ) { 173 if ( drawnOnScreenDisplay && onScreenDisplayVolume == v ) {
173 return; 174 return;
174 } 175 }
175 176
176 int w = audioUI->width(); 177 int w = audioUI->width();
177 int h = audioUI->height(); 178 int h = audioUI->height();
178 179
179 if ( drawnOnScreenDisplay ) { 180 if ( drawnOnScreenDisplay ) {
180 if ( onScreenDisplayVolume > v ) { 181 if ( onScreenDisplayVolume > v ) {
181 audioUI->repaint( (w - 200) / 2 + v * 20 + 0, h - yoff + 40, (onScreenDisplayVolume - v) * 20 + 9, 30, FALSE ); 182 audioUI->repaint( (w - 200) / 2 + v * 20 + 0, h - yoff + 40, (onScreenDisplayVolume - v) * 20 + 9, 30, FALSE );
182 } 183 }
183 } 184 }
184 185
185 drawnOnScreenDisplay = TRUE; 186 drawnOnScreenDisplay = TRUE;
186 onScreenDisplayVolume = v; 187 onScreenDisplayVolume = v;
187 188
188 QPainter p( audioUI ); 189 QPainter p( audioUI );
189 p.setPen( QColor( 0x10, 0xD0, 0x10 ) ); 190 p.setPen( QColor( 0x10, 0xD0, 0x10 ) );
190 p.setBrush( QColor( 0x10, 0xD0, 0x10 ) ); 191 p.setBrush( QColor( 0x10, 0xD0, 0x10 ) );
191 192
192 QFont f; 193 QFont f;
193 f.setPixelSize( 20 ); 194 f.setPixelSize( 20 );
194 f.setBold( TRUE ); 195 f.setBold( TRUE );
195 p.setFont( f ); 196 p.setFont( f );
196 p.drawText( (w - 200) / 2, h - yoff + 20, tr("Volume") ); 197 p.drawText( (w - 200) / 2, h - yoff + 20, tr("Volume") );
197 198
198 for ( unsigned int i = 0; i < 10; i++ ) { 199 for ( unsigned int i = 0; i < 10; i++ ) {
199 if ( v > i ) { 200 if ( v > i ) {
200 p.drawRect( (w - 200) / 2 + i * 20 + 0, h - yoff + 40, 9, 30 ); 201 p.drawRect( (w - 200) / 2 + i * 20 + 0, h - yoff + 40, 9, 30 );
201 } else { 202 } else {
202 p.drawRect( (w - 200) / 2 + i * 20 + 3, h - yoff + 50, 3, 10 ); 203 p.drawRect( (w - 200) / 2 + i * 20 + 3, h - yoff + 50, 3, 10 );
203 } 204 }
204 } 205 }
205} 206}
206 207
207void MediaPlayer::keyReleaseEvent( QKeyEvent *e) { 208void MediaPlayer::keyReleaseEvent( QKeyEvent *e) {
208 switch ( e->key() ) { 209 switch ( e->key() ) {
209////////////////////////////// Zaurus keys 210////////////////////////////// Zaurus keys
210 case Key_Home: 211 case Key_Home:
211 break; 212 break;
212 case Key_F9: //activity 213 case Key_F9: //activity
213 break; 214 break;
214 case Key_F10: //contacts 215 case Key_F10: //contacts
215 break; 216 break;
216 case Key_F11: //menu 217 case Key_F11: //menu
217 break; 218 break;
218 case Key_F12: //home 219 case Key_F12: //home
219 qDebug("Blank here"); 220 qDebug("Blank here");
220 break; 221 break;
221 case Key_F13: //mail 222 case Key_F13: //mail
222 break; 223 break;
223 } 224 }
224} 225}
225 226
226void MediaPlayer::doBlank() { 227void MediaPlayer::doBlank() {
227 228
228} 229}
229 230
230void MediaPlayer::doUnblank() { 231void MediaPlayer::doUnblank() {
231 232
232} 233}
233 234
234void MediaPlayer::cleanUp() { 235void MediaPlayer::cleanUp() {
235// QPEApplication::grabKeyboard(); 236// QPEApplication::grabKeyboard();
236// QPEApplication::ungrabKeyboard(); 237// QPEApplication::ungrabKeyboard();
237 238
238} 239}
diff --git a/noncore/multimedia/opieplayer2/mediaplayerstate.cpp b/noncore/multimedia/opieplayer2/mediaplayerstate.cpp
index 57b1c81..bb8d905 100644
--- a/noncore/multimedia/opieplayer2/mediaplayerstate.cpp
+++ b/noncore/multimedia/opieplayer2/mediaplayerstate.cpp
@@ -1,272 +1,269 @@
1#include <qpe/qpeapplication.h> 1#include <qpe/qpeapplication.h>
2#include <qpe/qlibrary.h> 2#include <qpe/qlibrary.h>
3#include <qpe/config.h> 3#include <qpe/config.h>
4#include <qvaluelist.h> 4#include <qvaluelist.h>
5#include <qobject.h> 5#include <qobject.h>
6#include <qdir.h> 6#include <qdir.h>
7#include "mediaplayerstate.h" 7#include "mediaplayerstate.h"
8 8
9 9
10 10
11//#define MediaPlayerDebug(x) qDebug x 11//#define MediaPlayerDebug(x) qDebug x
12#define MediaPlayerDebug(x) 12#define MediaPlayerDebug(x)
13 13
14 14
15MediaPlayerState::MediaPlayerState( QObject *parent, const char *name ) 15MediaPlayerState::MediaPlayerState( QObject *parent, const char *name )
16 : QObject( parent, name ) { 16 : QObject( parent, name ) {
17 Config cfg( "OpiePlayer" ); 17 Config cfg( "OpiePlayer" );
18 readConfig( cfg ); 18 readConfig( cfg );
19 19
20} 20}
21 21
22 22
23MediaPlayerState::~MediaPlayerState() { 23MediaPlayerState::~MediaPlayerState() {
24 Config cfg( "OpiePlayer" ); 24 Config cfg( "OpiePlayer" );
25 writeConfig( cfg ); 25 writeConfig( cfg );
26 26
27} 27}
28 28
29 29
30void MediaPlayerState::readConfig( Config& cfg ) { 30void MediaPlayerState::readConfig( Config& cfg ) {
31 cfg.setGroup("Options"); 31 cfg.setGroup("Options");
32 isFullscreen = cfg.readBoolEntry( "FullScreen" ); 32 isFullscreen = cfg.readBoolEntry( "FullScreen" );
33 isScaled = cfg.readBoolEntry( "Scaling" ); 33 isScaled = cfg.readBoolEntry( "Scaling" );
34 isLooping = cfg.readBoolEntry( "Looping" ); 34 isLooping = cfg.readBoolEntry( "Looping" );
35 isShuffled = cfg.readBoolEntry( "Shuffle" ); 35 isShuffled = cfg.readBoolEntry( "Shuffle" );
36 usePlaylist = cfg.readBoolEntry( "UsePlayList" ); 36 usePlaylist = cfg.readBoolEntry( "UsePlayList" );
37 usePlaylist = TRUE; 37 usePlaylist = TRUE;
38 isPlaying = FALSE; 38 isPlaying = FALSE;
39 isPaused = FALSE; 39 isPaused = FALSE;
40 curPosition = 0; 40 curPosition = 0;
41 curLength = 0; 41 curLength = 0;
42 curView = 'l'; 42 curView = 'l';
43} 43}
44 44
45 45
46void MediaPlayerState::writeConfig( Config& cfg ) const { 46void MediaPlayerState::writeConfig( Config& cfg ) const {
47 cfg.setGroup("Options"); 47 cfg.setGroup("Options");
48 cfg.writeEntry("FullScreen", isFullscreen ); 48 cfg.writeEntry("FullScreen", isFullscreen );
49 cfg.writeEntry("Scaling", isScaled ); 49 cfg.writeEntry("Scaling", isScaled );
50 cfg.writeEntry("Looping", isLooping ); 50 cfg.writeEntry("Looping", isLooping );
51 cfg.writeEntry("Shuffle", isShuffled ); 51 cfg.writeEntry("Shuffle", isShuffled );
52 cfg.writeEntry("UsePlayList", usePlaylist ); 52 cfg.writeEntry("UsePlayList", usePlaylist );
53} 53}
54 54
55 55
56
57
58// public stuff 56// public stuff
59 57
60 58
61bool MediaPlayerState::streaming() { 59bool MediaPlayerState::streaming() {
62 return isStreaming; 60 return isStreaming;
63} 61}
64 62
65bool MediaPlayerState::fullscreen() { 63bool MediaPlayerState::fullscreen() {
66 return isFullscreen; 64 return isFullscreen;
67} 65}
68 66
69bool MediaPlayerState::scaled() { 67bool MediaPlayerState::scaled() {
70 return isScaled; 68 return isScaled;
71} 69}
72 70
73bool MediaPlayerState::looping() { 71bool MediaPlayerState::looping() {
74 return isLooping; 72 return isLooping;
75} 73}
76 74
77bool MediaPlayerState::shuffled() { 75bool MediaPlayerState::shuffled() {
78 return isShuffled; 76 return isShuffled;
79} 77}
80 78
81 79
82bool MediaPlayerState:: playlist() { 80bool MediaPlayerState:: playlist() {
83 return usePlaylist; 81 return usePlaylist;
84} 82}
85 83
86bool MediaPlayerState::paused() { 84bool MediaPlayerState::paused() {
87 return isPaused; 85 return isPaused;
88} 86}
89 87
90bool MediaPlayerState::playing() { 88bool MediaPlayerState::playing() {
91 return isPlaying; 89 return isPlaying;
92} 90}
93 91
94bool MediaPlayerState::stop() { 92bool MediaPlayerState::stop() {
95 return isStoped; 93 return isStoped;
96} 94}
97 95
98long MediaPlayerState::position() { 96long MediaPlayerState::position() {
99 return curPosition; 97 return curPosition;
100} 98}
101 99
102long MediaPlayerState::length() { 100long MediaPlayerState::length() {
103 return curLength; 101 return curLength;
104} 102}
105 103
106char MediaPlayerState::view() { 104char MediaPlayerState::view() {
107 return curView; 105 return curView;
108} 106}
109 107
110// slots 108// slots
111void MediaPlayerState::setIsStreaming( bool b ) { 109void MediaPlayerState::setIsStreaming( bool b ) {
112 110
113 if ( isStreaming == b ) { 111 if ( isStreaming == b ) {
114 return; 112 return;
115 } 113 }
116 isStreaming = b; 114 isStreaming = b;
117} 115}
118 116
119 117
120void MediaPlayerState::setFullscreen( bool b ) { 118void MediaPlayerState::setFullscreen( bool b ) {
121 if ( isFullscreen == b ) { 119 if ( isFullscreen == b ) {
122 return; 120 return;
123 } 121 }
124 isFullscreen = b; 122 isFullscreen = b;
125 emit fullscreenToggled(b); 123 emit fullscreenToggled(b);
126} 124}
127 125
128 126
129void MediaPlayerState::setScaled( bool b ) { 127void MediaPlayerState::setScaled( bool b ) {
130 if ( isScaled == b ) { 128 if ( isScaled == b ) {
131 return; 129 return;
132 } 130 }
133 isScaled = b; 131 isScaled = b;
134 emit scaledToggled(b); 132 emit scaledToggled(b);
135} 133}
136 134
137void MediaPlayerState::setLooping( bool b ) { 135void MediaPlayerState::setLooping( bool b ) {
138 if ( isLooping == b ) { 136 if ( isLooping == b ) {
139 return; 137 return;
140 } 138 }
141 isLooping = b; 139 isLooping = b;
142 emit loopingToggled(b); 140 emit loopingToggled(b);
143} 141}
144 142
145void MediaPlayerState::setShuffled( bool b ) { 143void MediaPlayerState::setShuffled( bool b ) {
146 if ( isShuffled == b ) { 144 if ( isShuffled == b ) {
147 return; 145 return;
148 } 146 }
149 isShuffled = b; 147 isShuffled = b;
150 emit shuffledToggled(b); 148 emit shuffledToggled(b);
151} 149}
152 150
153void MediaPlayerState::setPlaylist( bool b ) { 151void MediaPlayerState::setPlaylist( bool b ) {
154 if ( usePlaylist == b ) { 152 if ( usePlaylist == b ) {
155 return; 153 return;
156 } 154 }
157 usePlaylist = b; 155 usePlaylist = b;
158 emit playlistToggled(b); 156 emit playlistToggled(b);
159} 157}
160 158
161void MediaPlayerState::setPaused( bool b ) { 159void MediaPlayerState::setPaused( bool b ) {
162if(b) qDebug("setPaused true"); 160 if ( isPaused == b ) {
163 else qDebug("setPaused false"); 161 isPaused = FALSE;
164 162 emit pausedToggled(FALSE);
165 if ( isPaused == b ) { 163 return;
166 return; 164 }
167 } 165 isPaused = b;
168 isPaused = b; 166 emit pausedToggled(b);
169 emit pausedToggled(b);
170} 167}
171 168
172void MediaPlayerState::setPlaying( bool b ) { 169void MediaPlayerState::setPlaying( bool b ) {
173 if ( isPlaying == b ) { 170 if ( isPlaying == b ) {
174 return; 171 return;
175 } 172 }
176 isPlaying = b; 173 isPlaying = b;
177 isStoped = !b; 174 isStoped = !b;
178 emit playingToggled(b); 175 emit playingToggled(b);
179} 176}
180 177
181void MediaPlayerState::setStop( bool b ) { 178void MediaPlayerState::setStop( bool b ) {
182 if ( isStoped == b ) { 179 if ( isStoped == b ) {
183 return; 180 return;
184 } 181 }
185 isStoped = b; 182 isStoped = b;
186 emit stopToggled(b); 183 emit stopToggled(b);
187} 184}
188 185
189void MediaPlayerState::setPosition( long p ) { 186void MediaPlayerState::setPosition( long p ) {
190 if ( curPosition == p ) { 187 if ( curPosition == p ) {
191 return; 188 return;
192 } 189 }
193 curPosition = p; 190 curPosition = p;
194 emit positionChanged(p); 191 emit positionChanged(p);
195} 192}
196 193
197void MediaPlayerState::updatePosition( long p ){ 194void MediaPlayerState::updatePosition( long p ){
198 if ( curPosition == p ) { 195 if ( curPosition == p ) {
199 return; 196 return;
200 } 197 }
201 curPosition = p; 198 curPosition = p;
202 emit positionUpdated(p); 199 emit positionUpdated(p);
203} 200}
204 201
205void MediaPlayerState::setLength( long l ) { 202void MediaPlayerState::setLength( long l ) {
206 if ( curLength == l ) { 203 if ( curLength == l ) {
207 return; 204 return;
208 } 205 }
209 curLength = l; 206 curLength = l;
210 emit lengthChanged(l); 207 emit lengthChanged(l);
211} 208}
212 209
213void MediaPlayerState::setView( char v ) { 210void MediaPlayerState::setView( char v ) {
214 if ( curView == v ) { 211 if ( curView == v ) {
215 return; 212 return;
216 } 213 }
217 curView = v; 214 curView = v;
218 emit viewChanged(v); 215 emit viewChanged(v);
219} 216}
220 217
221void MediaPlayerState::setPrev(){ 218void MediaPlayerState::setPrev(){
222 emit prev(); 219 emit prev();
223} 220}
224 221
225void MediaPlayerState::setNext() { 222void MediaPlayerState::setNext() {
226 emit next(); 223 emit next();
227} 224}
228 225
229void MediaPlayerState::setList() { 226void MediaPlayerState::setList() {
230 setPlaying( FALSE ); 227 setPlaying( FALSE );
231 setView('l'); 228 setView('l');
232} 229}
233 230
234void MediaPlayerState::setVideo() { 231void MediaPlayerState::setVideo() {
235 setView('v'); 232 setView('v');
236} 233}
237 234
238void MediaPlayerState::setAudio() { 235void MediaPlayerState::setAudio() {
239 setView('a'); 236 setView('a');
240} 237}
241 238
242void MediaPlayerState::toggleFullscreen() { 239void MediaPlayerState::toggleFullscreen() {
243 setFullscreen( !isFullscreen ); 240 setFullscreen( !isFullscreen );
244} 241}
245 242
246void MediaPlayerState::toggleScaled() { 243void MediaPlayerState::toggleScaled() {
247 setScaled( !isScaled); 244 setScaled( !isScaled);
248} 245}
249 246
250void MediaPlayerState::toggleLooping() { 247void MediaPlayerState::toggleLooping() {
251 setLooping( !isLooping); 248 setLooping( !isLooping);
252} 249}
253 250
254void MediaPlayerState::toggleShuffled() { 251void MediaPlayerState::toggleShuffled() {
255 setShuffled( !isShuffled); 252 setShuffled( !isShuffled);
256} 253}
257 254
258void MediaPlayerState::togglePlaylist() { 255void MediaPlayerState::togglePlaylist() {
259 setPlaylist( !usePlaylist); 256 setPlaylist( !usePlaylist);
260} 257}
261 258
262void MediaPlayerState::togglePaused() { 259void MediaPlayerState::togglePaused() {
263 setPaused( !isPaused); 260 setPaused( !isPaused);
264} 261}
265 262
266void MediaPlayerState::togglePlaying() { 263void MediaPlayerState::togglePlaying() {
267 setPlaying( !isPlaying); 264 setPlaying( !isPlaying);
268} 265}
269 266
270 267
271 268
272 269
diff --git a/noncore/multimedia/opieplayer2/playlistwidget.cpp b/noncore/multimedia/opieplayer2/playlistwidget.cpp
index 65458e7..27db464 100644
--- a/noncore/multimedia/opieplayer2/playlistwidget.cpp
+++ b/noncore/multimedia/opieplayer2/playlistwidget.cpp
@@ -1,1236 +1,1236 @@
1 1
2#define QTOPIA_INTERNAL_FSLP 2#define QTOPIA_INTERNAL_FSLP
3#include <qpe/qcopenvelope_qws.h> 3#include <qpe/qcopenvelope_qws.h>
4 4
5#include <qpe/qpemenubar.h> 5#include <qpe/qpemenubar.h>
6#include <qpe/qpetoolbar.h> 6#include <qpe/qpetoolbar.h>
7#include <qpe/fileselector.h> 7#include <qpe/fileselector.h>
8#include <qpe/qpeapplication.h> 8#include <qpe/qpeapplication.h>
9#include <qpe/lnkproperties.h> 9#include <qpe/lnkproperties.h>
10#include <qpe/storage.h> 10#include <qpe/storage.h>
11 11
12#include <qpe/applnk.h> 12#include <qpe/applnk.h>
13#include <qpopupmenu.h> 13#include <qpopupmenu.h>
14#include <qpe/config.h> 14#include <qpe/config.h>
15#include <qpe/global.h> 15#include <qpe/global.h>
16#include <qpe/resource.h> 16#include <qpe/resource.h>
17#include <qaction.h> 17#include <qaction.h>
18#include <qcursor.h> 18#include <qcursor.h>
19#include <qimage.h> 19#include <qimage.h>
20#include <qfile.h> 20#include <qfile.h>
21#include <qdir.h> 21#include <qdir.h>
22#include <qlayout.h> 22#include <qlayout.h>
23#include <qlabel.h> 23#include <qlabel.h>
24#include <qlist.h> 24#include <qlist.h>
25#include <qlistbox.h> 25#include <qlistbox.h>
26#include <qmainwindow.h> 26#include <qmainwindow.h>
27#include <qmessagebox.h> 27#include <qmessagebox.h>
28#include <qtoolbutton.h> 28#include <qtoolbutton.h>
29#include <qtabwidget.h> 29#include <qtabwidget.h>
30#include <qlistview.h> 30#include <qlistview.h>
31#include <qpoint.h> 31#include <qpoint.h>
32#include <qlineedit.h> 32#include <qlineedit.h>
33#include <qpushbutton.h> 33#include <qpushbutton.h>
34#include <qregexp.h> 34#include <qregexp.h>
35#include <qtextstream.h> 35#include <qtextstream.h>
36 36
37 37
38#include "playlistselection.h" 38#include "playlistselection.h"
39#include "playlistwidget.h" 39#include "playlistwidget.h"
40#include "mediaplayerstate.h" 40#include "mediaplayerstate.h"
41 41
42#include "inputDialog.h" 42#include "inputDialog.h"
43 43
44#include <stdlib.h> 44#include <stdlib.h>
45#include "audiowidget.h" 45#include "audiowidget.h"
46#include "videowidget.h" 46#include "videowidget.h"
47 47
48#include <unistd.h> 48#include <unistd.h>
49#include <sys/file.h> 49#include <sys/file.h>
50#include <sys/ioctl.h> 50#include <sys/ioctl.h>
51#include <sys/soundcard.h> 51#include <sys/soundcard.h>
52 52
53// for setBacklight() 53// for setBacklight()
54#include <linux/fb.h> 54#include <linux/fb.h>
55#include <sys/types.h> 55#include <sys/types.h>
56#include <sys/stat.h> 56#include <sys/stat.h>
57#include <stdlib.h> 57#include <stdlib.h>
58 58
59#define BUTTONS_ON_TOOLBAR 59#define BUTTONS_ON_TOOLBAR
60#define SIDE_BUTTONS 60#define SIDE_BUTTONS
61#define CAN_SAVE_LOAD_PLAYLISTS 61#define CAN_SAVE_LOAD_PLAYLISTS
62 62
63extern MediaPlayerState *mediaPlayerState; 63extern MediaPlayerState *mediaPlayerState;
64 64
65 65
66class PlayListWidgetPrivate { 66class PlayListWidgetPrivate {
67public: 67public:
68 QToolButton *tbPlay, *tbFull, *tbLoop, *tbScale, *tbShuffle, *tbAddToList, *tbRemoveFromList, *tbMoveUp, *tbMoveDown, *tbRemove; 68 QToolButton *tbPlay, *tbFull, *tbLoop, *tbScale, *tbShuffle, *tbAddToList, *tbRemoveFromList, *tbMoveUp, *tbMoveDown, *tbRemove;
69 QFrame *playListFrame; 69 QFrame *playListFrame;
70 FileSelector *files; 70 FileSelector *files;
71 PlayListSelection *selectedFiles; 71 PlayListSelection *selectedFiles;
72 bool setDocumentUsed; 72 bool setDocumentUsed;
73 DocLnk *current; 73 DocLnk *current;
74}; 74};
75 75
76 76
77class ToolButton : public QToolButton { 77class ToolButton : public QToolButton {
78public: 78public:
79 ToolButton( QWidget *parent, const char *name, const QString& icon, QObject *handler, const QString& slot, bool t = FALSE ) 79 ToolButton( QWidget *parent, const char *name, const QString& icon, QObject *handler, const QString& slot, bool t = FALSE )
80 : QToolButton( parent, name ) { 80 : QToolButton( parent, name ) {
81 setTextLabel( name ); 81 setTextLabel( name );
82 setPixmap( Resource::loadPixmap( icon ) ); 82 setPixmap( Resource::loadPixmap( icon ) );
83 setAutoRaise( TRUE ); 83 setAutoRaise( TRUE );
84 setFocusPolicy( QWidget::NoFocus ); 84 setFocusPolicy( QWidget::NoFocus );
85 setToggleButton( t ); 85 setToggleButton( t );
86 connect( this, t ? SIGNAL( toggled(bool) ) : SIGNAL( clicked() ), handler, slot ); 86 connect( this, t ? SIGNAL( toggled(bool) ) : SIGNAL( clicked() ), handler, slot );
87 QPEMenuToolFocusManager::manager()->addWidget( this ); 87 QPEMenuToolFocusManager::manager()->addWidget( this );
88 } 88 }
89}; 89};
90 90
91 91
92class MenuItem : public QAction { 92class MenuItem : public QAction {
93public: 93public:
94 MenuItem( QWidget *parent, const QString& text, QObject *handler, const QString& slot ) 94 MenuItem( QWidget *parent, const QString& text, QObject *handler, const QString& slot )
95 : QAction( text, QString::null, 0, 0 ) { 95 : QAction( text, QString::null, 0, 0 ) {
96 connect( this, SIGNAL( activated() ), handler, slot ); 96 connect( this, SIGNAL( activated() ), handler, slot );
97 addTo( parent ); 97 addTo( parent );
98 } 98 }
99}; 99};
100 100
101 101
102PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl ) 102PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl )
103 : QMainWindow( parent, name, fl ) { 103 : QMainWindow( parent, name, fl ) {
104 104
105 d = new PlayListWidgetPrivate; 105 d = new PlayListWidgetPrivate;
106 d->setDocumentUsed = FALSE; 106 d->setDocumentUsed = FALSE;
107 d->current = NULL; 107 d->current = NULL;
108 fromSetDocument = FALSE; 108 fromSetDocument = FALSE;
109 insanityBool=FALSE; 109 insanityBool=FALSE;
110 audioScan = FALSE; 110 audioScan = FALSE;
111 videoScan = FALSE; 111 videoScan = FALSE;
112 112
113 setBackgroundMode( PaletteButton ); 113 setBackgroundMode( PaletteButton );
114 114
115 setCaption( tr("OpiePlayer") ); 115 setCaption( tr("OpiePlayer") );
116 setIcon( Resource::loadPixmap( "opieplayer/MPEGPlayer" ) ); 116 setIcon( Resource::loadPixmap( "opieplayer/MPEGPlayer" ) );
117 117
118 setToolBarsMovable( FALSE ); 118 setToolBarsMovable( FALSE );
119 119
120 // Create Toolbar 120 // Create Toolbar
121 QPEToolBar *toolbar = new QPEToolBar( this ); 121 QPEToolBar *toolbar = new QPEToolBar( this );
122 toolbar->setHorizontalStretchable( TRUE ); 122 toolbar->setHorizontalStretchable( TRUE );
123 123
124 // Create Menubar 124 // Create Menubar
125 QPEMenuBar *menu = new QPEMenuBar( toolbar ); 125 QPEMenuBar *menu = new QPEMenuBar( toolbar );
126 menu->setMargin( 0 ); 126 menu->setMargin( 0 );
127 127
128 QPEToolBar *bar = new QPEToolBar( this ); 128 QPEToolBar *bar = new QPEToolBar( this );
129 bar->setLabel( tr( "Play Operations" ) ); 129 bar->setLabel( tr( "Play Operations" ) );
130 130
131 tbDeletePlaylist = new QPushButton( Resource::loadIconSet("trash"),"",bar,"close"); 131 tbDeletePlaylist = new QPushButton( Resource::loadIconSet("trash"),"",bar,"close");
132 tbDeletePlaylist->setFlat(TRUE); 132 tbDeletePlaylist->setFlat(TRUE);
133 tbDeletePlaylist->setFixedSize(20,20); 133 tbDeletePlaylist->setFixedSize(20,20);
134 134
135 d->tbAddToList = new ToolButton( bar, tr( "Add to Playlist" ), "opieplayer/add_to_playlist", 135 d->tbAddToList = new ToolButton( bar, tr( "Add to Playlist" ), "opieplayer/add_to_playlist",
136 this , SLOT(addSelected()) ); 136 this , SLOT(addSelected()) );
137 d->tbRemoveFromList = new ToolButton( bar, tr( "Remove from Playlist" ), "opieplayer/remove_from_playlist", 137 d->tbRemoveFromList = new ToolButton( bar, tr( "Remove from Playlist" ), "opieplayer/remove_from_playlist",
138 this , SLOT(removeSelected()) ); 138 this , SLOT(removeSelected()) );
139 d->tbPlay = new ToolButton( bar, tr( "Play" ), "opieplayer/play", 139 d->tbPlay = new ToolButton( bar, tr( "Play" ), "opieplayer/play",
140 this , SLOT( btnPlay(bool) ), TRUE ); 140 this , SLOT( btnPlay(bool) ), TRUE );
141 d->tbShuffle = new ToolButton( bar, tr( "Randomize" ),"opieplayer/shuffle", 141 d->tbShuffle = new ToolButton( bar, tr( "Randomize" ),"opieplayer/shuffle",
142 mediaPlayerState, SLOT(setShuffled(bool)), TRUE ); 142 mediaPlayerState, SLOT(setShuffled(bool)), TRUE );
143 d->tbLoop = new ToolButton( bar, tr( "Loop" ),"opieplayer/loop", 143 d->tbLoop = new ToolButton( bar, tr( "Loop" ),"opieplayer/loop",
144 mediaPlayerState, SLOT(setLooping(bool)), TRUE ); 144 mediaPlayerState, SLOT(setLooping(bool)), TRUE );
145 tbDeletePlaylist->hide(); 145 tbDeletePlaylist->hide();
146 146
147 QPopupMenu *pmPlayList = new QPopupMenu( this ); 147 QPopupMenu *pmPlayList = new QPopupMenu( this );
148 menu->insertItem( tr( "File" ), pmPlayList ); 148 menu->insertItem( tr( "File" ), pmPlayList );
149 new MenuItem( pmPlayList, tr( "Clear List" ), this, SLOT( clearList() ) ); 149 new MenuItem( pmPlayList, tr( "Clear List" ), this, SLOT( clearList() ) );
150 new MenuItem( pmPlayList, tr( "Add all audio files" ), this, SLOT( addAllMusicToList() ) ); 150 new MenuItem( pmPlayList, tr( "Add all audio files" ), this, SLOT( addAllMusicToList() ) );
151 new MenuItem( pmPlayList, tr( "Add all video files" ), this, SLOT( addAllVideoToList() ) ); 151 new MenuItem( pmPlayList, tr( "Add all video files" ), this, SLOT( addAllVideoToList() ) );
152 new MenuItem( pmPlayList, tr( "Add all files" ), this, SLOT( addAllToList() ) ); 152 new MenuItem( pmPlayList, tr( "Add all files" ), this, SLOT( addAllToList() ) );
153 pmPlayList->insertSeparator(-1); 153 pmPlayList->insertSeparator(-1);
154 new MenuItem( pmPlayList, tr( "Save PlayList" ), this, SLOT( saveList() ) ); 154 new MenuItem( pmPlayList, tr( "Save PlayList" ), this, SLOT( saveList() ) );
155 new MenuItem( pmPlayList, tr( "Export playlist to m3u" ), this, SLOT(writem3u() ) ); 155 new MenuItem( pmPlayList, tr( "Export playlist to m3u" ), this, SLOT(writem3u() ) );
156 pmPlayList->insertSeparator(-1); 156 pmPlayList->insertSeparator(-1);
157 new MenuItem( pmPlayList, tr( "Open File or URL" ), this,SLOT( openFile() ) ); 157 new MenuItem( pmPlayList, tr( "Open File or URL" ), this,SLOT( openFile() ) );
158 pmPlayList->insertSeparator(-1); 158 pmPlayList->insertSeparator(-1);
159 new MenuItem( pmPlayList, tr( "Rescan for Audio Files" ), this,SLOT( scanForAudio() ) ); 159 new MenuItem( pmPlayList, tr( "Rescan for Audio Files" ), this,SLOT( scanForAudio() ) );
160 new MenuItem( pmPlayList, tr( "Rescan for Video Files" ), this,SLOT( scanForVideo() ) ); 160 new MenuItem( pmPlayList, tr( "Rescan for Video Files" ), this,SLOT( scanForVideo() ) );
161 161
162 162
163 pmView = new QPopupMenu( this ); 163 pmView = new QPopupMenu( this );
164 menu->insertItem( tr( "View" ), pmView ); 164 menu->insertItem( tr( "View" ), pmView );
165 pmView->isCheckable(); 165 pmView->isCheckable();
166 166
167 pmView->insertItem( Resource::loadPixmap("fullscreen") , tr( "Full Screen"), this, SLOT( toggleFull() ) ); 167 pmView->insertItem( Resource::loadPixmap("fullscreen") , tr( "Full Screen"), mediaPlayerState, SLOT( toggleFullscreen() ) );
168 168
169 Config cfg( "OpiePlayer" ); 169 Config cfg( "OpiePlayer" );
170 bool b= cfg.readBoolEntry("FullScreen", 0); 170 bool b= cfg.readBoolEntry("FullScreen", 0);
171 mediaPlayerState->setFullscreen( b ); 171 mediaPlayerState->setFullscreen( b );
172 pmView->setItemChecked( -16, b ); 172 pmView->setItemChecked( -16, b );
173 173
174 pmView->insertItem( Resource::loadPixmap("opieplayer/scale") , tr( "Scale"), this, SLOT(toggleScaled() ) ); 174 pmView->insertItem( Resource::loadPixmap("opieplayer/scale") , tr( "Scale"), mediaPlayerState, SLOT(toggleScaled() ) );
175 175
176 QVBox *vbox5 = new QVBox( this ); vbox5->setBackgroundMode( PaletteButton ); 176 QVBox *vbox5 = new QVBox( this ); vbox5->setBackgroundMode( PaletteButton );
177 QVBox *vbox4 = new QVBox( vbox5 ); vbox4->setBackgroundMode( PaletteButton ); 177 QVBox *vbox4 = new QVBox( vbox5 ); vbox4->setBackgroundMode( PaletteButton );
178 178
179 QHBox *hbox6 = new QHBox( vbox4 ); hbox6->setBackgroundMode( PaletteButton ); 179 QHBox *hbox6 = new QHBox( vbox4 ); hbox6->setBackgroundMode( PaletteButton );
180 180
181 tabWidget = new QTabWidget( hbox6, "tabWidget" ); 181 tabWidget = new QTabWidget( hbox6, "tabWidget" );
182// tabWidget->setTabShape(QTabWidget::Triangular); 182// tabWidget->setTabShape(QTabWidget::Triangular);
183 183
184 QWidget *pTab; 184 QWidget *pTab;
185 pTab = new QWidget( tabWidget, "pTab" ); 185 pTab = new QWidget( tabWidget, "pTab" );
186 tabWidget->insertTab( pTab,"Playlist"); 186 tabWidget->insertTab( pTab,"Playlist");
187 187
188 188
189 // Add the playlist area 189 // Add the playlist area
190 190
191 QVBox *vbox3 = new QVBox( pTab ); vbox3->setBackgroundMode( PaletteButton ); 191 QVBox *vbox3 = new QVBox( pTab ); vbox3->setBackgroundMode( PaletteButton );
192 d->playListFrame = vbox3; 192 d->playListFrame = vbox3;
193 d->playListFrame ->setMinimumSize(235,260); 193 d->playListFrame ->setMinimumSize(235,260);
194 194
195 QHBox *hbox2 = new QHBox( vbox3 ); hbox2->setBackgroundMode( PaletteButton ); 195 QHBox *hbox2 = new QHBox( vbox3 ); hbox2->setBackgroundMode( PaletteButton );
196 196
197 d->selectedFiles = new PlayListSelection( hbox2); 197 d->selectedFiles = new PlayListSelection( hbox2);
198 QVBox *vbox1 = new QVBox( hbox2 ); vbox1->setBackgroundMode( PaletteButton ); 198 QVBox *vbox1 = new QVBox( hbox2 ); vbox1->setBackgroundMode( PaletteButton );
199 199
200 QPEApplication::setStylusOperation( d->selectedFiles->viewport(),QPEApplication::RightOnHold); 200 QPEApplication::setStylusOperation( d->selectedFiles->viewport(),QPEApplication::RightOnHold);
201 201
202 QVBox *stretch1 = new QVBox( vbox1 ); stretch1->setBackgroundMode( PaletteButton ); // add stretch 202 QVBox *stretch1 = new QVBox( vbox1 ); stretch1->setBackgroundMode( PaletteButton ); // add stretch
203 new ToolButton( vbox1, tr( "Move Up" ), "opieplayer/up", d->selectedFiles, SLOT(moveSelectedUp()) ); 203 new ToolButton( vbox1, tr( "Move Up" ), "opieplayer/up", d->selectedFiles, SLOT(moveSelectedUp()) );
204 new ToolButton( vbox1, tr( "Remove" ), "opieplayer/cut", d->selectedFiles, SLOT(removeSelected()) ); 204 new ToolButton( vbox1, tr( "Remove" ), "opieplayer/cut", d->selectedFiles, SLOT(removeSelected()) );
205 new ToolButton( vbox1, tr( "Move Down" ), "opieplayer/down", d->selectedFiles, SLOT(moveSelectedDown()) ); 205 new ToolButton( vbox1, tr( "Move Down" ), "opieplayer/down", d->selectedFiles, SLOT(moveSelectedDown()) );
206 QVBox *stretch2 = new QVBox( vbox1 ); stretch2->setBackgroundMode( PaletteButton ); // add stretch 206 QVBox *stretch2 = new QVBox( vbox1 ); stretch2->setBackgroundMode( PaletteButton ); // add stretch
207 207
208 QWidget *aTab; 208 QWidget *aTab;
209 aTab = new QWidget( tabWidget, "aTab" ); 209 aTab = new QWidget( tabWidget, "aTab" );
210 audioView = new QListView( aTab, "Audioview" ); 210 audioView = new QListView( aTab, "Audioview" );
211 audioView->setMinimumSize(233,260); 211 audioView->setMinimumSize(233,260);
212 audioView->addColumn( tr("Title"),140); 212 audioView->addColumn( tr("Title"),140);
213 audioView->addColumn(tr("Size"), -1); 213 audioView->addColumn(tr("Size"), -1);
214 audioView->addColumn(tr("Media"),-1); 214 audioView->addColumn(tr("Media"),-1);
215 audioView->setColumnAlignment(1, Qt::AlignRight); 215 audioView->setColumnAlignment(1, Qt::AlignRight);
216 audioView->setColumnAlignment(2, Qt::AlignRight); 216 audioView->setColumnAlignment(2, Qt::AlignRight);
217 audioView->setAllColumnsShowFocus(TRUE); 217 audioView->setAllColumnsShowFocus(TRUE);
218 218
219 audioView->setMultiSelection( TRUE ); 219 audioView->setMultiSelection( TRUE );
220 audioView->setSelectionMode( QListView::Extended); 220 audioView->setSelectionMode( QListView::Extended);
221 221
222 tabWidget->insertTab(aTab,tr("Audio")); 222 tabWidget->insertTab(aTab,tr("Audio"));
223 223
224 QPEApplication::setStylusOperation( audioView->viewport(),QPEApplication::RightOnHold); 224 QPEApplication::setStylusOperation( audioView->viewport(),QPEApplication::RightOnHold);
225 225
226 QWidget *vTab; 226 QWidget *vTab;
227 vTab = new QWidget( tabWidget, "vTab" ); 227 vTab = new QWidget( tabWidget, "vTab" );
228 videoView = new QListView( vTab, "Videoview" ); 228 videoView = new QListView( vTab, "Videoview" );
229 videoView->setMinimumSize(233,260); 229 videoView->setMinimumSize(233,260);
230 230
231 videoView->addColumn(tr("Title"),140); 231 videoView->addColumn(tr("Title"),140);
232 videoView->addColumn(tr("Size"),-1); 232 videoView->addColumn(tr("Size"),-1);
233 videoView->addColumn(tr("Media"),-1); 233 videoView->addColumn(tr("Media"),-1);
234 videoView->setColumnAlignment(1, Qt::AlignRight); 234 videoView->setColumnAlignment(1, Qt::AlignRight);
235 videoView->setColumnAlignment(2, Qt::AlignRight); 235 videoView->setColumnAlignment(2, Qt::AlignRight);
236 videoView->setAllColumnsShowFocus(TRUE); 236 videoView->setAllColumnsShowFocus(TRUE);
237 videoView->setMultiSelection( TRUE ); 237 videoView->setMultiSelection( TRUE );
238 videoView->setSelectionMode( QListView::Extended); 238 videoView->setSelectionMode( QListView::Extended);
239 239
240 QPEApplication::setStylusOperation( videoView->viewport(),QPEApplication::RightOnHold); 240 QPEApplication::setStylusOperation( videoView->viewport(),QPEApplication::RightOnHold);
241 241
242 tabWidget->insertTab( vTab,tr("Video")); 242 tabWidget->insertTab( vTab,tr("Video"));
243 243
244 //playlists list 244 //playlists list
245 QWidget *LTab; 245 QWidget *LTab;
246 LTab = new QWidget( tabWidget, "LTab" ); 246 LTab = new QWidget( tabWidget, "LTab" );
247 playLists = new FileSelector( "playlist/plain", LTab, "fileselector" , FALSE, FALSE); //buggy 247 playLists = new FileSelector( "playlist/plain", LTab, "fileselector" , FALSE, FALSE); //buggy
248 playLists->setMinimumSize(233,260); 248 playLists->setMinimumSize(233,260);
249 tabWidget->insertTab(LTab,tr("Lists")); 249 tabWidget->insertTab(LTab,tr("Lists"));
250 250
251 connect(tbDeletePlaylist,(SIGNAL(released())),SLOT( deletePlaylist())); 251 connect(tbDeletePlaylist,(SIGNAL(released())),SLOT( deletePlaylist()));
252 252
253connect( pmView, SIGNAL( activated(int)), this, SLOT( pmViewActivated(int) ) ); 253connect( pmView, SIGNAL( activated(int)), this, SLOT( pmViewActivated(int) ) );
254 254
255// connect( scaleButton, SIGNAL(activated()), mediaPlayerState, SLOT(toggleScaled() ) ); 255// connect( scaleButton, SIGNAL(activated()), mediaPlayerState, SLOT(toggleScaled() ) );
256 256
257 connect( d->selectedFiles, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), 257 connect( d->selectedFiles, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)),
258 this,SLOT( playlistViewPressed(int, QListViewItem *, const QPoint&, int)) ); 258 this,SLOT( playlistViewPressed(int, QListViewItem *, const QPoint&, int)) );
259 connect( audioView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), 259 connect( audioView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)),
260 this,SLOT( viewPressed(int, QListViewItem *, const QPoint&, int)) ); 260 this,SLOT( viewPressed(int, QListViewItem *, const QPoint&, int)) );
261 connect( audioView, SIGNAL( returnPressed( QListViewItem *)), 261 connect( audioView, SIGNAL( returnPressed( QListViewItem *)),
262 this,SLOT( playIt( QListViewItem *)) ); 262 this,SLOT( playIt( QListViewItem *)) );
263 connect( audioView, SIGNAL( doubleClicked( QListViewItem *) ), this, SLOT( addToSelection( QListViewItem *) ) ); 263 connect( audioView, SIGNAL( doubleClicked( QListViewItem *) ), this, SLOT( addToSelection( QListViewItem *) ) );
264 connect( videoView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), 264 connect( videoView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)),
265 this,SLOT( viewPressed(int, QListViewItem *, const QPoint&, int)) ); 265 this,SLOT( viewPressed(int, QListViewItem *, const QPoint&, int)) );
266 connect( videoView, SIGNAL( returnPressed( QListViewItem *)), 266 connect( videoView, SIGNAL( returnPressed( QListViewItem *)),
267 this,SLOT( playIt( QListViewItem *)) ); 267 this,SLOT( playIt( QListViewItem *)) );
268 connect( videoView, SIGNAL( doubleClicked( QListViewItem *) ), this, SLOT( addToSelection( QListViewItem *) ) ); 268 connect( videoView, SIGNAL( doubleClicked( QListViewItem *) ), this, SLOT( addToSelection( QListViewItem *) ) );
269 connect( playLists, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( loadList( const DocLnk & ) ) ); 269 connect( playLists, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( loadList( const DocLnk & ) ) );
270 connect( tabWidget, SIGNAL (currentChanged(QWidget*)),this,SLOT(tabChanged(QWidget*))); 270 connect( tabWidget, SIGNAL (currentChanged(QWidget*)),this,SLOT(tabChanged(QWidget*)));
271 connect( mediaPlayerState, SIGNAL( playingToggled( bool ) ), d->tbPlay, SLOT( setOn( bool ) ) ); 271 connect( mediaPlayerState, SIGNAL( playingToggled( bool ) ), d->tbPlay, SLOT( setOn( bool ) ) );
272 connect( mediaPlayerState, SIGNAL( loopingToggled( bool ) ), d->tbLoop, SLOT( setOn( bool ) ) ); 272 connect( mediaPlayerState, SIGNAL( loopingToggled( bool ) ), d->tbLoop, SLOT( setOn( bool ) ) );
273 connect( mediaPlayerState, SIGNAL( shuffledToggled( bool ) ), d->tbShuffle, SLOT( setOn( bool ) ) ); 273 connect( mediaPlayerState, SIGNAL( shuffledToggled( bool ) ), d->tbShuffle, SLOT( setOn( bool ) ) );
274 connect( mediaPlayerState, SIGNAL( playlistToggled( bool ) ), this, SLOT( setPlaylist( bool ) ) ); 274 connect( mediaPlayerState, SIGNAL( playlistToggled( bool ) ), this, SLOT( setPlaylist( bool ) ) );
275 connect( d->selectedFiles, SIGNAL( doubleClicked( QListViewItem *) ), this, SLOT( playIt( QListViewItem *) ) ); 275 connect( d->selectedFiles, SIGNAL( doubleClicked( QListViewItem *) ), this, SLOT( playIt( QListViewItem *) ) );
276 276
277 setCentralWidget( vbox5 ); 277 setCentralWidget( vbox5 );
278 278
279 readConfig( cfg ); 279 readConfig( cfg );
280 QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); 280 QString currentPlaylist = cfg.readEntry("CurrentPlaylist","");
281 loadList(DocLnk( currentPlaylist)); 281 loadList(DocLnk( currentPlaylist));
282 setCaption(tr("OpiePlayer: ")+ currentPlaylist ); 282 setCaption(tr("OpiePlayer: ")+ currentPlaylist );
283 283
284 initializeStates(); 284 initializeStates();
285} 285}
286 286
287 287
288PlayListWidget::~PlayListWidget() { 288PlayListWidget::~PlayListWidget() {
289 Config cfg( "OpiePlayer" ); 289 Config cfg( "OpiePlayer" );
290 writeConfig( cfg ); 290 writeConfig( cfg );
291 291
292 if ( d->current ) { 292 if ( d->current ) {
293 delete d->current; 293 delete d->current;
294 } 294 }
295 delete d; 295 delete d;
296} 296}
297 297
298 298
299void PlayListWidget::initializeStates() { 299void PlayListWidget::initializeStates() {
300 300
301 d->tbPlay->setOn( mediaPlayerState->playing() ); 301 d->tbPlay->setOn( mediaPlayerState->playing() );
302 d->tbLoop->setOn( mediaPlayerState->looping() ); 302 d->tbLoop->setOn( mediaPlayerState->looping() );
303 d->tbShuffle->setOn( mediaPlayerState->shuffled() ); 303 d->tbShuffle->setOn( mediaPlayerState->shuffled() );
304 setPlaylist( true); 304 setPlaylist( true);
305} 305}
306 306
307 307
308void PlayListWidget::readConfig( Config& cfg ) { 308void PlayListWidget::readConfig( Config& cfg ) {
309 cfg.setGroup("PlayList"); 309 cfg.setGroup("PlayList");
310 QString currentString = cfg.readEntry("current", "" ); 310 QString currentString = cfg.readEntry("current", "" );
311 int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); 311 int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 );
312 for ( int i = 0; i < noOfFiles; i++ ) { 312 for ( int i = 0; i < noOfFiles; i++ ) {
313 QString entryName; 313 QString entryName;
314 entryName.sprintf( "File%i", i + 1 ); 314 entryName.sprintf( "File%i", i + 1 );
315 QString linkFile = cfg.readEntry( entryName ); 315 QString linkFile = cfg.readEntry( entryName );
316 DocLnk lnk( linkFile ); 316 DocLnk lnk( linkFile );
317 if ( lnk.isValid() ) { 317 if ( lnk.isValid() ) {
318 d->selectedFiles->addToSelection( lnk ); 318 d->selectedFiles->addToSelection( lnk );
319 } 319 }
320 } 320 }
321 d->selectedFiles->setSelectedItem( currentString); 321 d->selectedFiles->setSelectedItem( currentString);
322} 322}
323 323
324 324
325void PlayListWidget::writeConfig( Config& cfg ) const { 325void PlayListWidget::writeConfig( Config& cfg ) const {
326 326
327 d->selectedFiles->writeCurrent( cfg); 327 d->selectedFiles->writeCurrent( cfg);
328 cfg.setGroup("PlayList"); 328 cfg.setGroup("PlayList");
329 int noOfFiles = 0; 329 int noOfFiles = 0;
330 d->selectedFiles->first(); 330 d->selectedFiles->first();
331 do { 331 do {
332 const DocLnk *lnk = d->selectedFiles->current(); 332 const DocLnk *lnk = d->selectedFiles->current();
333 if ( lnk ) { 333 if ( lnk ) {
334 QString entryName; 334 QString entryName;
335 entryName.sprintf( "File%i", noOfFiles + 1 ); 335 entryName.sprintf( "File%i", noOfFiles + 1 );
336 cfg.writeEntry( entryName, lnk->linkFile() ); 336 cfg.writeEntry( entryName, lnk->linkFile() );
337 // if this link does exist, add it so we have the file 337 // if this link does exist, add it so we have the file
338 // next time... 338 // next time...
339 if ( !QFile::exists( lnk->linkFile() ) ) { 339 if ( !QFile::exists( lnk->linkFile() ) ) {
340 // the way writing lnks doesn't really check for out 340 // the way writing lnks doesn't really check for out
341 // of disk space, but check it anyway. 341 // of disk space, but check it anyway.
342 if ( !lnk->writeLink() ) { 342 if ( !lnk->writeLink() ) {
343 QMessageBox::critical( 0, tr("Out of space"), 343 QMessageBox::critical( 0, tr("Out of space"),
344 tr( "There was a problem saving " 344 tr( "There was a problem saving "
345 "the playlist.\n" 345 "the playlist.\n"
346 "Your playlist " 346 "Your playlist "
347 "may be missing some entries\n" 347 "may be missing some entries\n"
348 "the next time you start it." ) 348 "the next time you start it." )
349 ); 349 );
350 } 350 }
351 } 351 }
352 noOfFiles++; 352 noOfFiles++;
353 } 353 }
354 } 354 }
355 while ( d->selectedFiles->next() ); 355 while ( d->selectedFiles->next() );
356 cfg.writeEntry("NumberOfFiles", noOfFiles ); 356 cfg.writeEntry("NumberOfFiles", noOfFiles );
357} 357}
358 358
359 359
360void PlayListWidget::addToSelection( const DocLnk& lnk ) { 360void PlayListWidget::addToSelection( const DocLnk& lnk ) {
361 d->setDocumentUsed = FALSE; 361 d->setDocumentUsed = FALSE;
362 if ( mediaPlayerState->playlist() ) { 362 if ( mediaPlayerState->playlist() ) {
363 if(QFileInfo(lnk.file()).exists() || lnk.file().left(4) == "http" ) 363 if(QFileInfo(lnk.file()).exists() || lnk.file().left(4) == "http" )
364 d->selectedFiles->addToSelection( lnk ); 364 d->selectedFiles->addToSelection( lnk );
365 } 365 }
366 else 366 else
367 mediaPlayerState->setPlaying( TRUE ); 367 mediaPlayerState->setPlaying( TRUE );
368} 368}
369 369
370 370
371void PlayListWidget::clearList() { 371void PlayListWidget::clearList() {
372 while ( first() ) { 372 while ( first() ) {
373 d->selectedFiles->removeSelected(); 373 d->selectedFiles->removeSelected();
374 } 374 }
375} 375}
376 376
377 377
378void PlayListWidget::addAllToList() { 378void PlayListWidget::addAllToList() {
379 DocLnkSet filesAll; 379 DocLnkSet filesAll;
380 Global::findDocuments(&filesAll, "video/*;audio/*"); 380 Global::findDocuments(&filesAll, "video/*;audio/*");
381 QListIterator<DocLnk> Adit( filesAll.children() ); 381 QListIterator<DocLnk> Adit( filesAll.children() );
382 for ( ; Adit.current(); ++Adit ) { 382 for ( ; Adit.current(); ++Adit ) {
383 if(QFileInfo(Adit.current()->file()).exists()) { 383 if(QFileInfo(Adit.current()->file()).exists()) {
384 d->selectedFiles->addToSelection( **Adit ); 384 d->selectedFiles->addToSelection( **Adit );
385 } 385 }
386 } 386 }
387} 387}
388 388
389 389
390void PlayListWidget::addAllMusicToList() { 390void PlayListWidget::addAllMusicToList() {
391 QListIterator<DocLnk> dit( files.children() ); 391 QListIterator<DocLnk> dit( files.children() );
392 for ( ; dit.current(); ++dit ) { 392 for ( ; dit.current(); ++dit ) {
393 if(QFileInfo(dit.current()->file()).exists()) { 393 if(QFileInfo(dit.current()->file()).exists()) {
394 d->selectedFiles->addToSelection( **dit ); 394 d->selectedFiles->addToSelection( **dit );
395 } 395 }
396 } 396 }
397} 397}
398 398
399 399
400void PlayListWidget::addAllVideoToList() { 400void PlayListWidget::addAllVideoToList() {
401 QListIterator<DocLnk> dit( vFiles.children() ); 401 QListIterator<DocLnk> dit( vFiles.children() );
402 for ( ; dit.current(); ++dit ) 402 for ( ; dit.current(); ++dit )
403 if(QFileInfo( dit.current()->file()).exists()) 403 if(QFileInfo( dit.current()->file()).exists())
404 d->selectedFiles->addToSelection( **dit ); 404 d->selectedFiles->addToSelection( **dit );
405} 405}
406 406
407 407
408void PlayListWidget::setDocument(const QString& fileref) { 408void PlayListWidget::setDocument(const QString& fileref) {
409 qDebug(fileref); 409 qDebug(fileref);
410 fromSetDocument = TRUE; 410 fromSetDocument = TRUE;
411 if ( fileref.isNull() ) { 411 if ( fileref.isNull() ) {
412 QMessageBox::critical( 0, tr( "Invalid File" ), tr( "There was a problem in getting the file." ) ); 412 QMessageBox::critical( 0, tr( "Invalid File" ), tr( "There was a problem in getting the file." ) );
413 return; 413 return;
414 } 414 }
415 415
416 if(fileref.find("m3u",0,TRUE) != -1) { //is m3u 416 if(fileref.find("m3u",0,TRUE) != -1) { //is m3u
417 readm3u( fileref); 417 readm3u( fileref);
418 } else if(fileref.find("pls",0,TRUE) != -1) { //is pls 418 } else if(fileref.find("pls",0,TRUE) != -1) { //is pls
419 readPls( fileref); 419 readPls( fileref);
420 } else if(fileref.find("playlist",0,TRUE) != -1) {//is playlist 420 } else if(fileref.find("playlist",0,TRUE) != -1) {//is playlist
421 clearList(); 421 clearList();
422 loadList(DocLnk(fileref)); 422 loadList(DocLnk(fileref));
423 d->selectedFiles->first(); 423 d->selectedFiles->first();
424 } else { 424 } else {
425 clearList(); 425 clearList();
426 addToSelection( DocLnk( fileref ) ); 426 addToSelection( DocLnk( fileref ) );
427 d->setDocumentUsed = TRUE; 427 d->setDocumentUsed = TRUE;
428 mediaPlayerState->setPlaying( FALSE ); 428 mediaPlayerState->setPlaying( FALSE );
429 qApp->processEvents(); 429 qApp->processEvents();
430 mediaPlayerState->setPlaying( TRUE ); 430 mediaPlayerState->setPlaying( TRUE );
431 qApp->processEvents(); 431 qApp->processEvents();
432 setCaption(tr("OpiePlayer")); 432 setCaption(tr("OpiePlayer"));
433 } 433 }
434} 434}
435 435
436 436
437void PlayListWidget::setActiveWindow() { 437void PlayListWidget::setActiveWindow() {
438 qDebug("SETTING active window"); 438 qDebug("SETTING active window");
439 // When we get raised we need to ensure that it switches views 439 // When we get raised we need to ensure that it switches views
440 char origView = mediaPlayerState->view(); 440 char origView = mediaPlayerState->view();
441 mediaPlayerState->setView( 'l' ); // invalidate 441 mediaPlayerState->setView( 'l' ); // invalidate
442 mediaPlayerState->setView( origView ); // now switch back 442 mediaPlayerState->setView( origView ); // now switch back
443} 443}
444 444
445 445
446void PlayListWidget::useSelectedDocument() { 446void PlayListWidget::useSelectedDocument() {
447 d->setDocumentUsed = FALSE; 447 d->setDocumentUsed = FALSE;
448} 448}
449 449
450 450
451const DocLnk *PlayListWidget::current() { // this is fugly 451const DocLnk *PlayListWidget::current() { // this is fugly
452 452
453 switch (tabWidget->currentPageIndex()) { 453 switch (tabWidget->currentPageIndex()) {
454 case 0: //playlist 454 case 0: //playlist
455 { 455 {
456 qDebug("playlist"); 456 qDebug("playlist");
457 if ( mediaPlayerState->playlist() ) { 457 if ( mediaPlayerState->playlist() ) {
458 return d->selectedFiles->current(); 458 return d->selectedFiles->current();
459 } else if ( d->setDocumentUsed && d->current ) { 459 } else if ( d->setDocumentUsed && d->current ) {
460 return d->current; 460 return d->current;
461 } else { 461 } else {
462 return d->files->selected(); 462 return d->files->selected();
463 } 463 }
464 } 464 }
465 break; 465 break;
466 case 1://audio 466 case 1://audio
467 { 467 {
468 qDebug("audioView"); 468 qDebug("audioView");
469 QListIterator<DocLnk> dit( files.children() ); 469 QListIterator<DocLnk> dit( files.children() );
470 for ( ; dit.current(); ++dit ) { 470 for ( ; dit.current(); ++dit ) {
471 if( dit.current()->name() == audioView->currentItem()->text(0) && !insanityBool) { 471 if( dit.current()->name() == audioView->currentItem()->text(0) && !insanityBool) {
472 qDebug("here"); 472 qDebug("here");
473 insanityBool=TRUE; 473 insanityBool=TRUE;
474 return dit; 474 return dit;
475 } 475 }
476 } 476 }
477 } 477 }
478 break; 478 break;
479 case 2: // video 479 case 2: // video
480 { 480 {
481 qDebug("videoView"); 481 qDebug("videoView");
482 QListIterator<DocLnk> Vdit( vFiles.children() ); 482 QListIterator<DocLnk> Vdit( vFiles.children() );
483 for ( ; Vdit.current(); ++Vdit ) { 483 for ( ; Vdit.current(); ++Vdit ) {
484 if( Vdit.current()->name() == videoView->currentItem()->text(0) && !insanityBool) { 484 if( Vdit.current()->name() == videoView->currentItem()->text(0) && !insanityBool) {
485 insanityBool=TRUE; 485 insanityBool=TRUE;
486 return Vdit; 486 return Vdit;
487 } 487 }
488 } 488 }
489 } 489 }
490 break; 490 break;
491 }; 491 };
492 return 0; 492 return 0;
493} 493}
494 494
495bool PlayListWidget::prev() { 495bool PlayListWidget::prev() {
496 if ( mediaPlayerState->playlist() ) { 496 if ( mediaPlayerState->playlist() ) {
497 if ( mediaPlayerState->shuffled() ) { 497 if ( mediaPlayerState->shuffled() ) {
498 const DocLnk *cur = current(); 498 const DocLnk *cur = current();
499 int j = 1 + (int)(97.0 * rand() / (RAND_MAX + 1.0)); 499 int j = 1 + (int)(97.0 * rand() / (RAND_MAX + 1.0));
500 for ( int i = 0; i < j; i++ ) { 500 for ( int i = 0; i < j; i++ ) {
501 if ( !d->selectedFiles->next() ) 501 if ( !d->selectedFiles->next() )
502 d->selectedFiles->first(); 502 d->selectedFiles->first();
503 } 503 }
504 if ( cur == current() ) 504 if ( cur == current() )
505 if ( !d->selectedFiles->next() ) 505 if ( !d->selectedFiles->next() )
506 d->selectedFiles->first(); 506 d->selectedFiles->first();
507 return TRUE; 507 return TRUE;
508 } else { 508 } else {
509 if ( !d->selectedFiles->prev() ) { 509 if ( !d->selectedFiles->prev() ) {
510 if ( mediaPlayerState->looping() ) { 510 if ( mediaPlayerState->looping() ) {
511 return d->selectedFiles->last(); 511 return d->selectedFiles->last();
512 } else { 512 } else {
513 return FALSE; 513 return FALSE;
514 } 514 }
515 } 515 }
516 return TRUE; 516 return TRUE;
517 } 517 }
518 } else { 518 } else {
519 return mediaPlayerState->looping(); 519 return mediaPlayerState->looping();
520 } 520 }
521} 521}
522 522
523 523
524bool PlayListWidget::next() { 524bool PlayListWidget::next() {
525 if ( mediaPlayerState->playlist() ) { 525 if ( mediaPlayerState->playlist() ) {
526 if ( mediaPlayerState->shuffled() ) { 526 if ( mediaPlayerState->shuffled() ) {
527 return prev(); 527 return prev();
528 } else { 528 } else {
529 if ( !d->selectedFiles->next() ) { 529 if ( !d->selectedFiles->next() ) {
530 if ( mediaPlayerState->looping() ) { 530 if ( mediaPlayerState->looping() ) {
531 return d->selectedFiles->first(); 531 return d->selectedFiles->first();
532 } else { 532 } else {
533 return FALSE; 533 return FALSE;
534 } 534 }
535 } 535 }
536 return TRUE; 536 return TRUE;
537 } 537 }
538 } else { 538 } else {
539 return mediaPlayerState->looping(); 539 return mediaPlayerState->looping();
540 } 540 }
541} 541}
542 542
543 543
544bool PlayListWidget::first() { 544bool PlayListWidget::first() {
545 if ( mediaPlayerState->playlist() ) 545 if ( mediaPlayerState->playlist() )
546 return d->selectedFiles->first(); 546 return d->selectedFiles->first();
547 else 547 else
548 return mediaPlayerState->looping(); 548 return mediaPlayerState->looping();
549} 549}
550 550
551 551
552bool PlayListWidget::last() { 552bool PlayListWidget::last() {
553 if ( mediaPlayerState->playlist() ) 553 if ( mediaPlayerState->playlist() )
554 return d->selectedFiles->last(); 554 return d->selectedFiles->last();
555 else 555 else
556 return mediaPlayerState->looping(); 556 return mediaPlayerState->looping();
557} 557}
558 558
559 559
560void PlayListWidget::saveList() { 560void PlayListWidget::saveList() {
561 561
562 QString filename; 562 QString filename;
563 InputDialog *fileDlg; 563 InputDialog *fileDlg;
564 fileDlg = new InputDialog(this,tr("Save Playlist"),TRUE, 0); 564 fileDlg = new InputDialog(this,tr("Save Playlist"),TRUE, 0);
565 fileDlg->exec(); 565 fileDlg->exec();
566 if( fileDlg->result() == 1 ) { 566 if( fileDlg->result() == 1 ) {
567 if ( d->current ) 567 if ( d->current )
568 delete d->current; 568 delete d->current;
569 filename = fileDlg->LineEdit1->text();//+".playlist"; 569 filename = fileDlg->LineEdit1->text();//+".playlist";
570 // qDebug("saving playlist "+filename+".playlist"); 570 // qDebug("saving playlist "+filename+".playlist");
571 Config cfg( filename +".playlist"); 571 Config cfg( filename +".playlist");
572 writeConfig( cfg ); 572 writeConfig( cfg );
573 573
574 DocLnk lnk; 574 DocLnk lnk;
575 lnk.setFile(QDir::homeDirPath()+"/Settings/"+filename+".playlist.conf"); //sets File property 575 lnk.setFile(QDir::homeDirPath()+"/Settings/"+filename+".playlist.conf"); //sets File property
576 lnk.setType("playlist/plain");// hey is this a REGISTERED mime type?!?!? ;D 576 lnk.setType("playlist/plain");// hey is this a REGISTERED mime type?!?!? ;D
577 lnk.setIcon("opieplayer/playlist2"); 577 lnk.setIcon("opieplayer/playlist2");
578 lnk.setName( filename); //sets file name 578 lnk.setName( filename); //sets file name
579 // qDebug(filename); 579 // qDebug(filename);
580 if(!lnk.writeLink()) { 580 if(!lnk.writeLink()) {
581 qDebug("Writing doclink did not work"); 581 qDebug("Writing doclink did not work");
582 } 582 }
583 } 583 }
584 Config config( "OpiePlayer" ); 584 Config config( "OpiePlayer" );
585 config.writeEntry("CurrentPlaylist",filename); 585 config.writeEntry("CurrentPlaylist",filename);
586 setCaption(tr("OpiePlayer: ")+filename); 586 setCaption(tr("OpiePlayer: ")+filename);
587 d->selectedFiles->first(); 587 d->selectedFiles->first();
588 if(fileDlg) { 588 if(fileDlg) {
589 delete fileDlg; 589 delete fileDlg;
590 } 590 }
591} 591}
592 592
593void PlayListWidget::loadList( const DocLnk & lnk) { 593void PlayListWidget::loadList( const DocLnk & lnk) {
594 QString name= lnk.name(); 594 QString name= lnk.name();
595 // qDebug("currentList is "+name); 595 // qDebug("currentList is "+name);
596 if( name.length()>1) { 596 if( name.length()>1) {
597 setCaption("OpiePlayer: "+name); 597 setCaption("OpiePlayer: "+name);
598 // qDebug("load list "+ name+".playlist"); 598 // qDebug("load list "+ name+".playlist");
599 clearList(); 599 clearList();
600 Config cfg( name+".playlist"); 600 Config cfg( name+".playlist");
601 readConfig(cfg); 601 readConfig(cfg);
602 602
603 tabWidget->setCurrentPage(0); 603 tabWidget->setCurrentPage(0);
604 604
605 Config config( "OpiePlayer" ); 605 Config config( "OpiePlayer" );
606 config.writeEntry("CurrentPlaylist", name); 606 config.writeEntry("CurrentPlaylist", name);
607 // d->selectedFiles->first(); 607 // d->selectedFiles->first();
608 } 608 }
609 609
610} 610}
611 611
612void PlayListWidget::setPlaylist( bool shown ) { 612void PlayListWidget::setPlaylist( bool shown ) {
613 if ( shown ) { 613 if ( shown ) {
614 d->playListFrame->show(); 614 d->playListFrame->show();
615 } else { 615 } else {
616 d->playListFrame->hide(); 616 d->playListFrame->hide();
617 } 617 }
618} 618}
619 619
620void PlayListWidget::setView( char view ) { 620void PlayListWidget::setView( char view ) {
621 if ( view == 'l' ) 621 if ( view == 'l' )
622 showMaximized(); 622 showMaximized();
623 else 623 else
624 hide(); 624 hide();
625} 625}
626 626
627void PlayListWidget::addSelected() { 627void PlayListWidget::addSelected() {
628 628
629 Config cfg( "OpiePlayer" ); 629 Config cfg( "OpiePlayer" );
630 cfg.setGroup("PlayList"); 630 cfg.setGroup("PlayList");
631 QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); 631 QString currentPlaylist = cfg.readEntry("CurrentPlaylist","");
632 int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); 632 int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 );
633 633
634 switch (tabWidget->currentPageIndex()) { 634 switch (tabWidget->currentPageIndex()) {
635 case 0: //playlist 635 case 0: //playlist
636 break; 636 break;
637 case 1: { //audio 637 case 1: { //audio
638 QListViewItemIterator it( audioView ); 638 QListViewItemIterator it( audioView );
639 // iterate through all items of the listview 639 // iterate through all items of the listview
640 for ( ; it.current(); ++it ) { 640 for ( ; it.current(); ++it ) {
641 if ( it.current()->isSelected() ) { 641 if ( it.current()->isSelected() ) {
642 QListIterator<DocLnk> dit( files.children() ); 642 QListIterator<DocLnk> dit( files.children() );
643 for ( ; dit.current(); ++dit ) { 643 for ( ; dit.current(); ++dit ) {
644 if( dit.current()->name() == it.current()->text(0) ) { 644 if( dit.current()->name() == it.current()->text(0) ) {
645 d->selectedFiles->addToSelection( **dit ); 645 d->selectedFiles->addToSelection( **dit );
646 } 646 }
647 } 647 }
648 audioView->setSelected( it.current(),FALSE); 648 audioView->setSelected( it.current(),FALSE);
649 } 649 }
650 } 650 }
651 tabWidget->setCurrentPage(0); 651 tabWidget->setCurrentPage(0);
652 } 652 }
653 break; 653 break;
654 case 2: { // video 654 case 2: { // video
655 QListViewItemIterator it( videoView ); 655 QListViewItemIterator it( videoView );
656 // iterate through all items of the listview 656 // iterate through all items of the listview
657 for ( ; it.current(); ++it ) { 657 for ( ; it.current(); ++it ) {
658 if ( it.current()->isSelected() ) { 658 if ( it.current()->isSelected() ) {
659 QListIterator<DocLnk> dit( vFiles.children() ); 659 QListIterator<DocLnk> dit( vFiles.children() );
660 for ( ; dit.current(); ++dit ) { 660 for ( ; dit.current(); ++dit ) {
661 if( dit.current()->name() == it.current()->text(0) ) { 661 if( dit.current()->name() == it.current()->text(0) ) {
662 d->selectedFiles->addToSelection( **dit ); 662 d->selectedFiles->addToSelection( **dit );
663 } 663 }
664 } 664 }
665 videoView->setSelected( it.current(),FALSE); 665 videoView->setSelected( it.current(),FALSE);
666 } 666 }
667 } 667 }
668 tabWidget->setCurrentPage(0); 668 tabWidget->setCurrentPage(0);
669 } 669 }
670 break; 670 break;
671 }; 671 };
672} 672}
673 673
674void PlayListWidget::removeSelected() { 674void PlayListWidget::removeSelected() {
675 d->selectedFiles->removeSelected( ); 675 d->selectedFiles->removeSelected( );
676} 676}
677 677
678void PlayListWidget::playIt( QListViewItem *it) { 678void PlayListWidget::playIt( QListViewItem *it) {
679 qDebug("playIt"); 679 qDebug("playIt");
680 mediaPlayerState->setPlaying(FALSE); 680 mediaPlayerState->setPlaying(FALSE);
681 mediaPlayerState->setPlaying(TRUE); 681 mediaPlayerState->setPlaying(TRUE);
682 d->selectedFiles->unSelect(); 682 d->selectedFiles->unSelect();
683} 683}
684 684
685void PlayListWidget::addToSelection( QListViewItem *it) { 685void PlayListWidget::addToSelection( QListViewItem *it) {
686 d->setDocumentUsed = FALSE; 686 d->setDocumentUsed = FALSE;
687 687
688 if(it) { 688 if(it) {
689 switch (tabWidget->currentPageIndex()) { 689 switch (tabWidget->currentPageIndex()) {
690 case 1: { 690 case 1: {
691 QListIterator<DocLnk> dit( files.children() ); 691 QListIterator<DocLnk> dit( files.children() );
692 for ( ; dit.current(); ++dit ) { 692 for ( ; dit.current(); ++dit ) {
693 if( dit.current()->name() == it->text(0)) { 693 if( dit.current()->name() == it->text(0)) {
694 d->selectedFiles->addToSelection( **dit ); 694 d->selectedFiles->addToSelection( **dit );
695 } 695 }
696 } 696 }
697 } 697 }
698 break; 698 break;
699 case 2: { 699 case 2: {
700 QListIterator<DocLnk> dit( vFiles.children() ); 700 QListIterator<DocLnk> dit( vFiles.children() );
701 for ( ; dit.current(); ++dit ) { 701 for ( ; dit.current(); ++dit ) {
702 if( dit.current()->name() == it->text(0)) { 702 if( dit.current()->name() == it->text(0)) {
703 d->selectedFiles->addToSelection( **dit ); 703 d->selectedFiles->addToSelection( **dit );
704 } 704 }
705 } 705 }
706 } 706 }
707 break; 707 break;
708 case 0: 708 case 0:
709 break; 709 break;
710 }; 710 };
711 tabWidget->setCurrentPage(0); 711 tabWidget->setCurrentPage(0);
712 } 712 }
713} 713}
714 714
715void PlayListWidget::tabChanged(QWidget *widg) { 715void PlayListWidget::tabChanged(QWidget *widg) {
716 716
717 switch ( tabWidget->currentPageIndex()) { 717 switch ( tabWidget->currentPageIndex()) {
718 case 0: 718 case 0:
719 { 719 {
720 if( !tbDeletePlaylist->isHidden()) 720 if( !tbDeletePlaylist->isHidden())
721 tbDeletePlaylist->hide(); 721 tbDeletePlaylist->hide();
722 d->tbRemoveFromList->setEnabled(TRUE); 722 d->tbRemoveFromList->setEnabled(TRUE);
723 d->tbAddToList->setEnabled(FALSE); 723 d->tbAddToList->setEnabled(FALSE);
724 } 724 }
725 break; 725 break;
726 case 1: 726 case 1:
727 { 727 {
728 audioView->clear(); 728 audioView->clear();
729 populateAudioView(); 729 populateAudioView();
730 730
731 if( !tbDeletePlaylist->isHidden()) 731 if( !tbDeletePlaylist->isHidden())
732 tbDeletePlaylist->hide(); 732 tbDeletePlaylist->hide();
733 d->tbRemoveFromList->setEnabled(FALSE); 733 d->tbRemoveFromList->setEnabled(FALSE);
734 d->tbAddToList->setEnabled(TRUE); 734 d->tbAddToList->setEnabled(TRUE);
735 } 735 }
736 break; 736 break;
737 case 2: 737 case 2:
738 { 738 {
739 videoView->clear(); 739 videoView->clear();
740 populateVideoView(); 740 populateVideoView();
741 if( !tbDeletePlaylist->isHidden()) 741 if( !tbDeletePlaylist->isHidden())
742 tbDeletePlaylist->hide(); 742 tbDeletePlaylist->hide();
743 d->tbRemoveFromList->setEnabled(FALSE); 743 d->tbRemoveFromList->setEnabled(FALSE);
744 d->tbAddToList->setEnabled(TRUE); 744 d->tbAddToList->setEnabled(TRUE);
745 } 745 }
746 break; 746 break;
747 case 3: 747 case 3:
748 { 748 {
749 if( tbDeletePlaylist->isHidden()) 749 if( tbDeletePlaylist->isHidden())
750 tbDeletePlaylist->show(); 750 tbDeletePlaylist->show();
751 playLists->reread(); 751 playLists->reread();
752 } 752 }
753 break; 753 break;
754 }; 754 };
755} 755}
756 756
757void PlayListWidget::btnPlay(bool b) { 757void PlayListWidget::btnPlay(bool b) {
758 758
759// mediaPlayerState->setPlaying(b); 759// mediaPlayerState->setPlaying(b);
760 switch ( tabWidget->currentPageIndex()) { 760 switch ( tabWidget->currentPageIndex()) {
761 case 0: 761 case 0:
762 { 762 {
763 mediaPlayerState->setPlaying(b); 763 mediaPlayerState->setPlaying(b);
764 } 764 }
765 break; 765 break;
766 case 1: 766 case 1:
767 { 767 {
768 addToSelection( audioView->currentItem() ); 768 addToSelection( audioView->currentItem() );
769 mediaPlayerState->setPlaying(b); 769 mediaPlayerState->setPlaying(b);
770 d->selectedFiles->removeSelected( ); 770 d->selectedFiles->removeSelected( );
771 tabWidget->setCurrentPage(1); 771 tabWidget->setCurrentPage(1);
772 d->selectedFiles->unSelect(); 772 d->selectedFiles->unSelect();
773 insanityBool=FALSE; 773 insanityBool=FALSE;
774 }// audioView->clearSelection(); 774 }// audioView->clearSelection();
775 break; 775 break;
776 case 2: 776 case 2:
777 { 777 {
778 addToSelection( videoView->currentItem() ); 778 addToSelection( videoView->currentItem() );
779 mediaPlayerState->setPlaying(b); 779 mediaPlayerState->setPlaying(b);
780 qApp->processEvents(); 780 qApp->processEvents();
781 d->selectedFiles->removeSelected( ); 781 d->selectedFiles->removeSelected( );
782 tabWidget->setCurrentPage(2); 782 tabWidget->setCurrentPage(2);
783 d->selectedFiles->unSelect(); 783 d->selectedFiles->unSelect();
784 insanityBool=FALSE; 784 insanityBool=FALSE;
785 }// videoView->clearSelection(); 785 }// videoView->clearSelection();
786 break; 786 break;
787 }; 787 };
788 788
789} 789}
790 790
791void PlayListWidget::deletePlaylist() { 791void PlayListWidget::deletePlaylist() {
792 switch( QMessageBox::information( this, (tr("Remove Playlist?")), 792 switch( QMessageBox::information( this, (tr("Remove Playlist?")),
793 (tr("You really want to delete\nthis playlist?")), 793 (tr("You really want to delete\nthis playlist?")),
794 (tr("Yes")), (tr("No")), 0 )){ 794 (tr("Yes")), (tr("No")), 0 )){
795 case 0: // Yes clicked, 795 case 0: // Yes clicked,
796 QFile().remove(playLists->selected()->file()); 796 QFile().remove(playLists->selected()->file());
797 QFile().remove(playLists->selected()->linkFile()); 797 QFile().remove(playLists->selected()->linkFile());
798 playLists->reread(); 798 playLists->reread();
799 break; 799 break;
800 case 1: // Cancel 800 case 1: // Cancel
801 break; 801 break;
802 }; 802 };
803} 803}
804 804
805void PlayListWidget::viewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) { 805void PlayListWidget::viewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) {
806 switch (mouse) { 806 switch (mouse) {
807 case 1: 807 case 1:
808 break; 808 break;
809 case 2:{ 809 case 2:{
810 QPopupMenu m; 810 QPopupMenu m;
811 m.insertItem( tr( "Play" ), this, SLOT( playSelected() )); 811 m.insertItem( tr( "Play" ), this, SLOT( playSelected() ));
812 m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() )); 812 m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() ));
813 m.insertSeparator(); 813 m.insertSeparator();
814 m.insertItem( tr( "Properties" ), this, SLOT( listDelete() )); 814 m.insertItem( tr( "Properties" ), this, SLOT( listDelete() ));
815 m.exec( QCursor::pos() ); 815 m.exec( QCursor::pos() );
816 } 816 }
817 break; 817 break;
818 }; 818 };
819} 819}
820 820
821void PlayListWidget::playSelected() { 821void PlayListWidget::playSelected() {
822 btnPlay( TRUE); 822 btnPlay( TRUE);
823} 823}
824 824
825void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) { 825void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *item, const QPoint& point, int i) {
826 switch (mouse) { 826 switch (mouse) {
827 case 1: 827 case 1:
828 828
829 break; 829 break;
830 case 2: 830 case 2:
831 { 831 {
832 QPopupMenu m; 832 QPopupMenu m;
833 m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() )); 833 m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() ));
834 m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() )); 834 m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() ));
835 m.exec( QCursor::pos() ); 835 m.exec( QCursor::pos() );
836 } 836 }
837 break; 837 break;
838 }; 838 };
839} 839}
840 840
841void PlayListWidget::listDelete() { 841void PlayListWidget::listDelete() {
842 Config cfg( "OpiePlayer" ); 842 Config cfg( "OpiePlayer" );
843 cfg.setGroup("PlayList"); 843 cfg.setGroup("PlayList");
844 QString currentPlaylist = cfg.readEntry("CurrentPlaylist",""); 844 QString currentPlaylist = cfg.readEntry("CurrentPlaylist","");
845 QString file; 845 QString file;
846 int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); 846 int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 );
847 switch ( tabWidget->currentPageIndex()) { 847 switch ( tabWidget->currentPageIndex()) {
848 case 0: 848 case 0:
849 break; 849 break;
850 case 1: 850 case 1:
851 { 851 {
852 file = audioView->currentItem()->text(0); 852 file = audioView->currentItem()->text(0);
853 QListIterator<DocLnk> Pdit( files.children() ); 853 QListIterator<DocLnk> Pdit( files.children() );
854 for ( ; Pdit.current(); ++Pdit ) { 854 for ( ; Pdit.current(); ++Pdit ) {
855 if( Pdit.current()->name() == file) { 855 if( Pdit.current()->name() == file) {
856 LnkProperties prop( Pdit.current() ); 856 LnkProperties prop( Pdit.current() );
857 prop.showMaximized(); 857 prop.showMaximized();
858 prop.exec(); 858 prop.exec();
859 } 859 }
860 } 860 }
861 populateAudioView(); 861 populateAudioView();
862 } 862 }
863 break; 863 break;
864 case 2: 864 case 2:
865 { 865 {
866 866
867 } 867 }
868 break; 868 break;
869 }; 869 };
870} 870}
871 871
872void PlayListWidget::scanForAudio() { 872void PlayListWidget::scanForAudio() {
873 qDebug("scan for audio"); 873 qDebug("scan for audio");
874 files.detachChildren(); 874 files.detachChildren();
875 QListIterator<DocLnk> sdit( files.children() ); 875 QListIterator<DocLnk> sdit( files.children() );
876 for ( ; sdit.current(); ++sdit ) { 876 for ( ; sdit.current(); ++sdit ) {
877 delete sdit.current(); 877 delete sdit.current();
878 } 878 }
879 Global::findDocuments(&files, "audio/*"); 879 Global::findDocuments(&files, "audio/*");
880 audioScan = TRUE; 880 audioScan = TRUE;
881} 881}
882void PlayListWidget::scanForVideo() { 882void PlayListWidget::scanForVideo() {
883 qDebug("scan for video"); 883 qDebug("scan for video");
884 vFiles.detachChildren(); 884 vFiles.detachChildren();
885 QListIterator<DocLnk> sdit( vFiles.children() ); 885 QListIterator<DocLnk> sdit( vFiles.children() );
886 for ( ; sdit.current(); ++sdit ) { 886 for ( ; sdit.current(); ++sdit ) {
887 delete sdit.current(); 887 delete sdit.current();
888 } 888 }
889 Global::findDocuments(&vFiles, "video/*"); 889 Global::findDocuments(&vFiles, "video/*");
890 videoScan = TRUE; 890 videoScan = TRUE;
891} 891}
892 892
893void PlayListWidget::populateAudioView() { 893void PlayListWidget::populateAudioView() {
894 894
895 audioView->clear(); 895 audioView->clear();
896 StorageInfo storageInfo; 896 StorageInfo storageInfo;
897 const QList<FileSystem> &fs = storageInfo.fileSystems(); 897 const QList<FileSystem> &fs = storageInfo.fileSystems();
898 if(!audioScan) scanForAudio(); 898 if(!audioScan) scanForAudio();
899 899
900 QListIterator<DocLnk> dit( files.children() ); 900 QListIterator<DocLnk> dit( files.children() );
901 QListIterator<FileSystem> it ( fs ); 901 QListIterator<FileSystem> it ( fs );
902 902
903 QString storage; 903 QString storage;
904 for ( ; dit.current(); ++dit ) { 904 for ( ; dit.current(); ++dit ) {
905 for( ; it.current(); ++it ){ 905 for( ; it.current(); ++it ){
906 const QString name = (*it)->name(); 906 const QString name = (*it)->name();
907 const QString path = (*it)->path(); 907 const QString path = (*it)->path();
908 if(dit.current()->file().find(path) != -1 ) storage=name; 908 if(dit.current()->file().find(path) != -1 ) storage=name;
909 } 909 }
910 910
911 QListViewItem * newItem; 911 QListViewItem * newItem;
912 if ( QFile( dit.current()->file()).exists() ) { 912 if ( QFile( dit.current()->file()).exists() ) {
913 // qDebug(dit.current()->name()); 913 // qDebug(dit.current()->name());
914 newItem= /*(void)*/ new QListViewItem( audioView, dit.current()->name(), 914 newItem= /*(void)*/ new QListViewItem( audioView, dit.current()->name(),
915 QString::number( QFile( dit.current()->file()).size() ), storage); 915 QString::number( QFile( dit.current()->file()).size() ), storage);
916 newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/musicfile" )); 916 newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/musicfile" ));
917 } 917 }
918 } 918 }
919 919
920} 920}
921 921
922void PlayListWidget::populateVideoView() { 922void PlayListWidget::populateVideoView() {
923 videoView->clear(); 923 videoView->clear();
924 StorageInfo storageInfo; 924 StorageInfo storageInfo;
925 const QList<FileSystem> &fs = storageInfo.fileSystems(); 925 const QList<FileSystem> &fs = storageInfo.fileSystems();
926 926
927 if(!videoScan ) scanForVideo(); 927 if(!videoScan ) scanForVideo();
928 928
929 QListIterator<DocLnk> Vdit( vFiles.children() ); 929 QListIterator<DocLnk> Vdit( vFiles.children() );
930 QListIterator<FileSystem> it ( fs ); 930 QListIterator<FileSystem> it ( fs );
931 videoView->clear(); 931 videoView->clear();
932 QString storage; 932 QString storage;
933 for ( ; Vdit.current(); ++Vdit ) { 933 for ( ; Vdit.current(); ++Vdit ) {
934 for( ; it.current(); ++it ){ 934 for( ; it.current(); ++it ){
935 const QString name = (*it)->name(); 935 const QString name = (*it)->name();
936 const QString path = (*it)->path(); 936 const QString path = (*it)->path();
937 if( Vdit.current()->file().find(path) != -1 ) storage=name; 937 if( Vdit.current()->file().find(path) != -1 ) storage=name;
938 } 938 }
939 939
940 QListViewItem * newItem; 940 QListViewItem * newItem;
941 if ( QFile( Vdit.current()->file()).exists() ) { 941 if ( QFile( Vdit.current()->file()).exists() ) {
942 newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(), 942 newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(),
943 QString::number( QFile( Vdit.current()->file()).size() ), storage); 943 QString::number( QFile( Vdit.current()->file()).size() ), storage);
944 newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/videofile" )); 944 newItem->setPixmap(0, Resource::loadPixmap( "opieplayer/videofile" ));
945 } 945 }
946 } 946 }
947} 947}
948 948
949void PlayListWidget::openFile() { 949void PlayListWidget::openFile() {
950 QString filename, name; 950 QString filename, name;
951 InputDialog *fileDlg; 951 InputDialog *fileDlg;
952 fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); 952 fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0);
953 fileDlg->exec(); 953 fileDlg->exec();
954 if( fileDlg->result() == 1 ) { 954 if( fileDlg->result() == 1 ) {
955 filename = fileDlg->LineEdit1->text(); 955 filename = fileDlg->LineEdit1->text();
956 956
957 qDebug("Selected filename is "+filename); 957 qDebug("Selected filename is "+filename);
958 if(filename.right(3) == "m3u") { 958 if(filename.right(3) == "m3u") {
959 readm3u( filename ); 959 readm3u( filename );
960 } else if(filename.right(3) == "pls") { 960 } else if(filename.right(3) == "pls") {
961 readPls( filename ); 961 readPls( filename );
962 } else { 962 } else {
963 DocLnk lnk; 963 DocLnk lnk;
964 964
965 lnk.setName(filename); //sets file name 965 lnk.setName(filename); //sets file name
966 lnk.setFile(filename); //sets File property 966 lnk.setFile(filename); //sets File property
967 lnk.setType("audio/x-mpegurl"); 967 lnk.setType("audio/x-mpegurl");
968 lnk.setExec("opieplayer"); 968 lnk.setExec("opieplayer");
969 lnk.setIcon("opieplayer/MPEGPlayer"); 969 lnk.setIcon("opieplayer/MPEGPlayer");
970 970
971 if(!lnk.writeLink()) { 971 if(!lnk.writeLink()) {
972 qDebug("Writing doclink did not work"); 972 qDebug("Writing doclink did not work");
973 } 973 }
974 d->selectedFiles->addToSelection( lnk); 974 d->selectedFiles->addToSelection( lnk);
975 } 975 }
976 } 976 }
977 if(fileDlg) { 977 if(fileDlg) {
978 delete fileDlg; 978 delete fileDlg;
979 } 979 }
980} 980}
981 981
982void PlayListWidget::keyReleaseEvent( QKeyEvent *e) 982void PlayListWidget::keyReleaseEvent( QKeyEvent *e)
983{ 983{
984 switch ( e->key() ) { 984 switch ( e->key() ) {
985////////////////////////////// Zaurus keys 985////////////////////////////// Zaurus keys
986 case Key_F9: //activity 986 case Key_F9: //activity
987// if(audioUI->isHidden()) 987// if(audioUI->isHidden())
988// audioUI->showMaximized(); 988// audioUI->showMaximized();
989 break; 989 break;
990 case Key_F10: //contacts 990 case Key_F10: //contacts
991// if( videoUI->isHidden()) 991// if( videoUI->isHidden())
992// videoUI->showMaximized(); 992// videoUI->showMaximized();
993 break; 993 break;
994 case Key_F11: //menu 994 case Key_F11: //menu
995 break; 995 break;
996 case Key_F12: //home 996 case Key_F12: //home
997// doBlank(); 997// doBlank();
998 break; 998 break;
999 case Key_F13: //mail 999 case Key_F13: //mail
1000// doUnblank(); 1000// doUnblank();
1001 break; 1001 break;
1002 case Key_Q: //add to playlist 1002 case Key_Q: //add to playlist
1003 qDebug("Add"); 1003 qDebug("Add");
1004 addSelected(); 1004 addSelected();
1005 break; 1005 break;
1006 case Key_R: //remove from playlist 1006 case Key_R: //remove from playlist
1007 removeSelected(); 1007 removeSelected();
1008 break; 1008 break;
1009// case Key_P: //play 1009// case Key_P: //play
1010// qDebug("Play"); 1010// qDebug("Play");
1011// playSelected(); 1011// playSelected();
1012// break; 1012// break;
1013 case Key_Space: 1013 case Key_Space:
1014 qDebug("Play"); 1014 qDebug("Play");
1015// playSelected(); puh 1015// playSelected(); puh
1016 break; 1016 break;
1017 case Key_1: 1017 case Key_1:
1018 tabWidget->setCurrentPage(0); 1018 tabWidget->setCurrentPage(0);
1019 break; 1019 break;
1020 case Key_2: 1020 case Key_2:
1021 tabWidget->setCurrentPage(1); 1021 tabWidget->setCurrentPage(1);
1022 break; 1022 break;
1023 case Key_3: 1023 case Key_3:
1024 tabWidget->setCurrentPage(2); 1024 tabWidget->setCurrentPage(2);
1025 break; 1025 break;
1026 case Key_4: 1026 case Key_4:
1027 tabWidget->setCurrentPage(3); 1027 tabWidget->setCurrentPage(3);
1028 break; 1028 break;
1029 case Key_Down: 1029 case Key_Down:
1030 if ( !d->selectedFiles->next() ) 1030 if ( !d->selectedFiles->next() )
1031 d->selectedFiles->first(); 1031 d->selectedFiles->first();
1032 1032
1033 break; 1033 break;
1034 case Key_Up: 1034 case Key_Up:
1035 if ( !d->selectedFiles->prev() ) 1035 if ( !d->selectedFiles->prev() )
1036 // d->selectedFiles->last(); 1036 // d->selectedFiles->last();
1037 1037
1038 break; 1038 break;
1039 1039
1040 } 1040 }
1041} 1041}
1042 1042
1043void PlayListWidget::keyPressEvent( QKeyEvent *e) 1043void PlayListWidget::keyPressEvent( QKeyEvent *e)
1044{ 1044{
1045// qDebug("Key press"); 1045// qDebug("Key press");
1046// switch ( e->key() ) { 1046// switch ( e->key() ) {
1047// ////////////////////////////// Zaurus keys 1047// ////////////////////////////// Zaurus keys
1048// case Key_A: //add to playlist 1048// case Key_A: //add to playlist
1049// qDebug("Add"); 1049// qDebug("Add");
1050// addSelected(); 1050// addSelected();
1051// break; 1051// break;
1052// case Key_R: //remove from playlist 1052// case Key_R: //remove from playlist
1053// removeSelected(); 1053// removeSelected();
1054// break; 1054// break;
1055// case Key_P: //play 1055// case Key_P: //play
1056// qDebug("Play"); 1056// qDebug("Play");
1057// playSelected(); 1057// playSelected();
1058// break; 1058// break;
1059// case Key_Space: 1059// case Key_Space:
1060// qDebug("Play"); 1060// qDebug("Play");
1061// playSelected(); 1061// playSelected();
1062// break; 1062// break;
1063// } 1063// }
1064} 1064}
1065 1065
1066void PlayListWidget::doBlank() { 1066void PlayListWidget::doBlank() {
1067 qDebug("do blanking"); 1067 qDebug("do blanking");
1068 fd=open("/dev/fb0",O_RDWR); 1068 fd=open("/dev/fb0",O_RDWR);
1069 if (fd != -1) { 1069 if (fd != -1) {
1070 ioctl(fd,FBIOBLANK,1); 1070 ioctl(fd,FBIOBLANK,1);
1071// close(fd); 1071// close(fd);
1072 } 1072 }
1073} 1073}
1074 1074
1075void PlayListWidget::doUnblank() { 1075void PlayListWidget::doUnblank() {
1076 // this crashes opieplayer with a segfault 1076 // this crashes opieplayer with a segfault
1077 // int fd; 1077 // int fd;
1078 // fd=open("/dev/fb0",O_RDWR); 1078 // fd=open("/dev/fb0",O_RDWR);
1079 qDebug("do unblanking"); 1079 qDebug("do unblanking");
1080 if (fd != -1) { 1080 if (fd != -1) {
1081 ioctl(fd,FBIOBLANK,0); 1081 ioctl(fd,FBIOBLANK,0);
1082 close(fd); 1082 close(fd);
1083 } 1083 }
1084 QCopEnvelope h("QPE/System", "setBacklight(int)"); 1084 QCopEnvelope h("QPE/System", "setBacklight(int)");
1085 h <<-3;// v[1]; // -3 Force on 1085 h <<-3;// v[1]; // -3 Force on
1086} 1086}
1087 1087
1088void PlayListWidget::readm3u(const QString &filename) { 1088void PlayListWidget::readm3u(const QString &filename) {
1089 1089
1090 qDebug("m3u filename is "+filename); 1090 qDebug("m3u filename is "+filename);
1091 QFile f(filename); 1091 QFile f(filename);
1092 1092
1093 if(f.open(IO_ReadOnly)) { 1093 if(f.open(IO_ReadOnly)) {
1094 QTextStream t(&f); 1094 QTextStream t(&f);
1095 QString s;//, first, second; 1095 QString s;//, first, second;
1096 int i=0; 1096 int i=0;
1097 while ( !t.atEnd()) { 1097 while ( !t.atEnd()) {
1098 s=t.readLine(); 1098 s=t.readLine();
1099 1099
1100 if(s.find("#",0,TRUE) == -1) { 1100 if(s.find("#",0,TRUE) == -1) {
1101 if(s.find(" ",0,TRUE) == -1) { // not sure if this is neede since cf uses vfat 1101 if(s.find(" ",0,TRUE) == -1) { // not sure if this is neede since cf uses vfat
1102 if(s.left(2) == "E:" || s.left(2) == "P:") { 1102 if(s.left(2) == "E:" || s.left(2) == "P:") {
1103 s=s.right(s.length()-2); 1103 s=s.right(s.length()-2);
1104 DocLnk lnk( s ); 1104 DocLnk lnk( s );
1105 QFileInfo f(s); 1105 QFileInfo f(s);
1106 QString name = f.baseName(); 1106 QString name = f.baseName();
1107 name = name.right( name.length()-name.findRev( "\\",-1,TRUE ) -1 ); 1107 name = name.right( name.length()-name.findRev( "\\",-1,TRUE ) -1 );
1108 lnk.setName( name ); 1108 lnk.setName( name );
1109 s=s.replace( QRegExp("\\"),"/"); 1109 s=s.replace( QRegExp("\\"),"/");
1110 lnk.setFile( s ); 1110 lnk.setFile( s );
1111 lnk.writeLink(); 1111 lnk.writeLink();
1112 qDebug("add "+name); 1112 qDebug("add "+name);
1113 d->selectedFiles->addToSelection( lnk); 1113 d->selectedFiles->addToSelection( lnk);
1114 } else { // is url 1114 } else { // is url
1115 s.replace(QRegExp("%20")," "); 1115 s.replace(QRegExp("%20")," ");
1116 DocLnk lnk( s ); 1116 DocLnk lnk( s );
1117 QString name; 1117 QString name;
1118 if(name.left(4)=="http") { 1118 if(name.left(4)=="http") {
1119 name = s.right( s.length() - 7); 1119 name = s.right( s.length() - 7);
1120 } else { 1120 } else {
1121 name = s; 1121 name = s;
1122 } 1122 }
1123 lnk.setName(name); 1123 lnk.setName(name);
1124 if(s.at(s.length()-4) == '.') { 1124 if(s.at(s.length()-4) == '.') {
1125 lnk.setFile( s); 1125 lnk.setFile( s);
1126 } else { 1126 } else {
1127 lnk.setFile( s+"/"); 1127 lnk.setFile( s+"/");
1128 } 1128 }
1129 lnk.setType("audio/x-mpegurl"); 1129 lnk.setType("audio/x-mpegurl");
1130 lnk.writeLink(); 1130 lnk.writeLink();
1131 d->selectedFiles->addToSelection( lnk); 1131 d->selectedFiles->addToSelection( lnk);
1132 } 1132 }
1133 i++; 1133 i++;
1134 } 1134 }
1135 } 1135 }
1136 } 1136 }
1137 } 1137 }
1138 f.close(); 1138 f.close();
1139} 1139}
1140 1140
1141void PlayListWidget::writem3u() { 1141void PlayListWidget::writem3u() {
1142 1142
1143 InputDialog *fileDlg; 1143 InputDialog *fileDlg;
1144 fileDlg = new InputDialog(this,tr("Save m3u Playlist "),TRUE, 0); 1144 fileDlg = new InputDialog(this,tr("Save m3u Playlist "),TRUE, 0);
1145 fileDlg->exec(); 1145 fileDlg->exec();
1146 QString filename,list; 1146 QString filename,list;
1147 if( fileDlg->result() == 1 ) { 1147 if( fileDlg->result() == 1 ) {
1148 filename = fileDlg->LineEdit1->text(); 1148 filename = fileDlg->LineEdit1->text();
1149 qDebug(filename); 1149 qDebug(filename);
1150 int noOfFiles = 0; 1150 int noOfFiles = 0;
1151 d->selectedFiles->first(); 1151 d->selectedFiles->first();
1152 do { 1152 do {
1153 // we dont check for existance because of url's 1153 // we dont check for existance because of url's
1154 // qDebug(d->selectedFiles->current()->file()); 1154 // qDebug(d->selectedFiles->current()->file());
1155 list += d->selectedFiles->current()->file()+"\n"; 1155 list += d->selectedFiles->current()->file()+"\n";
1156 noOfFiles++; 1156 noOfFiles++;
1157 } 1157 }
1158 while ( d->selectedFiles->next() ); 1158 while ( d->selectedFiles->next() );
1159 qDebug(list); 1159 qDebug(list);
1160 if(filename.left(1) != "/") 1160 if(filename.left(1) != "/")
1161 filename=QPEApplication::documentDir()+"/"+filename; 1161 filename=QPEApplication::documentDir()+"/"+filename;
1162 if(filename.right(3) != "m3u") 1162 if(filename.right(3) != "m3u")
1163 filename=filename+".m3u"; 1163 filename=filename+".m3u";
1164 1164
1165 QFile f(filename); 1165 QFile f(filename);
1166 f.open(IO_WriteOnly); 1166 f.open(IO_WriteOnly);
1167 f.writeBlock(list, list.length()); 1167 f.writeBlock(list, list.length());
1168 f.close(); 1168 f.close();
1169 } 1169 }
1170 if(fileDlg) delete fileDlg; 1170 if(fileDlg) delete fileDlg;
1171} 1171}
1172 1172
1173void PlayListWidget::readPls(const QString &filename) { 1173void PlayListWidget::readPls(const QString &filename) {
1174 1174
1175 qDebug("pls filename is "+filename); 1175 qDebug("pls filename is "+filename);
1176 QFile f(filename); 1176 QFile f(filename);
1177 1177
1178 if(f.open(IO_ReadOnly)) { 1178 if(f.open(IO_ReadOnly)) {
1179 QTextStream t(&f); 1179 QTextStream t(&f);
1180 QString s;//, first, second; 1180 QString s;//, first, second;
1181 int i=0; 1181 int i=0;
1182 while ( !t.atEnd()) { 1182 while ( !t.atEnd()) {
1183 s=t.readLine(); 1183 s=t.readLine();
1184 if(s.left(4) == "File") { 1184 if(s.left(4) == "File") {
1185 s=s.right(s.length() - 6); 1185 s=s.right(s.length() - 6);
1186 s.replace(QRegExp("%20")," "); 1186 s.replace(QRegExp("%20")," ");
1187 qDebug("adding "+s+" to playlist"); 1187 qDebug("adding "+s+" to playlist");
1188 // numberofentries=2 1188 // numberofentries=2
1189 // File1=http 1189 // File1=http
1190 // Title 1190 // Title
1191 // Length 1191 // Length
1192 // Version 1192 // Version
1193 // File2=http 1193 // File2=http
1194 s=s.replace( QRegExp("\\"),"/"); 1194 s=s.replace( QRegExp("\\"),"/");
1195 DocLnk lnk( s ); 1195 DocLnk lnk( s );
1196 QFileInfo f(s); 1196 QFileInfo f(s);
1197 QString name = f.baseName(); 1197 QString name = f.baseName();
1198 if(name.left(4)=="http") 1198 if(name.left(4)=="http")
1199 name = s.right( s.length() - 7); 1199 name = s.right( s.length() - 7);
1200 else 1200 else
1201 name=s; 1201 name=s;
1202 name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); 1202 name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1);
1203 lnk.setName( name); 1203 lnk.setName( name);
1204 if(s.at(s.length()-4) == '.') // if this is probably a file 1204 if(s.at(s.length()-4) == '.') // if this is probably a file
1205 lnk.setFile( s); 1205 lnk.setFile( s);
1206 else { //if its a url 1206 else { //if its a url
1207 if( name.right(1).find('/') == -1) 1207 if( name.right(1).find('/') == -1)
1208 s+="/"; 1208 s+="/";
1209 lnk.setFile( s); 1209 lnk.setFile( s);
1210 } 1210 }
1211 lnk.setType("audio/x-mpegurl"); 1211 lnk.setType("audio/x-mpegurl");
1212 1212
1213 qDebug("DocLnk add "+name); 1213 qDebug("DocLnk add "+name);
1214 d->selectedFiles->addToSelection( lnk); 1214 d->selectedFiles->addToSelection( lnk);
1215 } 1215 }
1216 } 1216 }
1217 i++; 1217 i++;
1218 } 1218 }
1219} 1219}
1220 1220
1221void PlayListWidget::pmViewActivated(int index) { 1221void PlayListWidget::pmViewActivated(int index) {
1222qDebug("%d", index); 1222qDebug("%d", index);
1223switch(index) { 1223switch(index) {
1224 case -16: 1224 case -16:
1225 { 1225 {
1226 1226
1227 mediaPlayerState->toggleFullscreen(); 1227 mediaPlayerState->toggleFullscreen();
1228 bool b=mediaPlayerState->fullscreen(); 1228 bool b=mediaPlayerState->fullscreen();
1229 pmView->setItemChecked( index,b); 1229 pmView->setItemChecked( index,b);
1230 Config cfg( "OpiePlayer" ); 1230 Config cfg( "OpiePlayer" );
1231 cfg.writeEntry("FullScreen", b); 1231 cfg.writeEntry("FullScreen", b);
1232 1232
1233 } 1233 }
1234 break; 1234 break;
1235}; 1235};
1236} 1236}
diff --git a/noncore/multimedia/opieplayer2/playlistwidget.h b/noncore/multimedia/opieplayer2/playlistwidget.h
index fdfa666..dd49892 100644
--- a/noncore/multimedia/opieplayer2/playlistwidget.h
+++ b/noncore/multimedia/opieplayer2/playlistwidget.h
@@ -1,111 +1,110 @@
1 1
2#ifndef PLAY_LIST_WIDGET_H 2#ifndef PLAY_LIST_WIDGET_H
3#define PLAY_LIST_WIDGET_H 3#define PLAY_LIST_WIDGET_H
4 4
5#include <qmainwindow.h> 5#include <qmainwindow.h>
6#include <qpe/applnk.h> 6#include <qpe/applnk.h>
7#include <qtabwidget.h> 7#include <qtabwidget.h>
8#include <qpe/fileselector.h> 8#include <qpe/fileselector.h>
9#include <qpushbutton.h> 9#include <qpushbutton.h>
10#include <qpopupmenu.h> 10#include <qpopupmenu.h>
11 11
12/* #include <qtimer.h> */ 12/* #include <qtimer.h> */
13 13
14 14
15class PlayListWidgetPrivate; 15class PlayListWidgetPrivate;
16class Config; 16class Config;
17class QListViewItem; 17class QListViewItem;
18class QListView; 18class QListView;
19class QPoint; 19class QPoint;
20class QAction; 20class QAction;
21class QLabel; 21class QLabel;
22 22
23class PlayListWidget : public QMainWindow { 23class PlayListWidget : public QMainWindow {
24 Q_OBJECT 24 Q_OBJECT
25public: 25public:
26 PlayListWidget( QWidget* parent=0, const char* name=0, WFlags fl=0 ); 26 PlayListWidget( QWidget* parent=0, const char* name=0, WFlags fl=0 );
27 ~PlayListWidget(); 27 ~PlayListWidget();
28 QTabWidget * tabWidget; 28 QTabWidget * tabWidget;
29// MenuItem *fullScreenButton, *scaleButton; 29// MenuItem *fullScreenButton, *scaleButton;
30// QAction *fullScreenButton, *scaleButton; 30// QAction *fullScreenButton, *scaleButton;
31 DocLnkSet files; 31 DocLnkSet files;
32 DocLnkSet vFiles; 32 DocLnkSet vFiles;
33 QListView *audioView, *videoView, *playlistView; 33 QListView *audioView, *videoView, *playlistView;
34 QLabel *libString; 34 QLabel *libString;
35 QPopupMenu *pmView ; 35 QPopupMenu *pmView ;
36 bool fromSetDocument; 36 bool fromSetDocument;
37 bool insanityBool; 37 bool insanityBool;
38 QString setDocFileRef; 38 QString setDocFileRef;
39 // retrieve the current playlist entry (media file link) 39 // retrieve the current playlist entry (media file link)
40 const DocLnk *current(); 40 const DocLnk *current();
41 void useSelectedDocument(); 41 void useSelectedDocument();
42/* QTimer * menuTimer; */ 42/* QTimer * menuTimer; */
43 FileSelector* playLists; 43 FileSelector* playLists;
44 QPushButton *tbDeletePlaylist; 44 QPushButton *tbDeletePlaylist;
45 int fd, selected; 45 int fd, selected;
46public slots: 46public slots:
47 bool first(); 47 bool first();
48 bool last(); 48 bool last();
49 bool next(); 49 bool next();
50 bool prev(); 50 bool prev();
51/* void setFullScreen(); */ 51/* void setFullScreen(); */
52/* void setScaled(); */ 52/* void setScaled(); */
53protected: 53protected:
54/* void contentsMousePressEvent( QMouseEvent * e ); */ 54/* void contentsMousePressEvent( QMouseEvent * e ); */
55/* void contentsMouseReleaseEvent( QMouseEvent * e ); */ 55/* void contentsMouseReleaseEvent( QMouseEvent * e ); */
56void keyReleaseEvent( QKeyEvent *e); 56void keyReleaseEvent( QKeyEvent *e);
57void keyPressEvent( QKeyEvent *e); 57void keyPressEvent( QKeyEvent *e);
58private: 58private:
59 bool audioScan, videoScan; 59 bool audioScan, videoScan;
60 void doBlank(); 60 void doBlank();
61 void doUnblank(); 61 void doUnblank();
62 void readm3u(const QString &); 62 void readm3u(const QString &);
63 void readPls(const QString &); 63 void readPls(const QString &);
64 64
65
66 void initializeStates(); 65 void initializeStates();
67 void readConfig( Config& cfg ); 66 void readConfig( Config& cfg );
68 void writeConfig( Config& cfg ) const; 67 void writeConfig( Config& cfg ) const;
69 PlayListWidgetPrivate *d; // Private implementation data 68 PlayListWidgetPrivate *d; // Private implementation data
70 void populateAudioView(); 69 void populateAudioView();
71 void populateVideoView(); 70 void populateVideoView();
72private slots: 71private slots:
73 void pmViewActivated(int); 72 void pmViewActivated(int);
74 void writem3u(); 73 void writem3u();
75 void scanForAudio(); 74 void scanForAudio();
76 void scanForVideo(); 75 void scanForVideo();
77 void openFile(); 76 void openFile();
78 void setDocument( const QString& fileref ); 77 void setDocument( const QString& fileref );
79 void addToSelection( const DocLnk& ); // Add a media file to the playlist 78 void addToSelection( const DocLnk& ); // Add a media file to the playlist
80 void addToSelection( QListViewItem* ); // Add a media file to the playlist 79 void addToSelection( QListViewItem* ); // Add a media file to the playlist
81 void setActiveWindow(); // need to handle this to show the right view 80 void setActiveWindow(); // need to handle this to show the right view
82 void setPlaylist( bool ); // Show/Hide the playlist 81 void setPlaylist( bool ); // Show/Hide the playlist
83 void setView( char ); 82 void setView( char );
84 void clearList(); 83 void clearList();
85 void addAllToList(); 84 void addAllToList();
86 void addAllMusicToList(); 85 void addAllMusicToList();
87 void addAllVideoToList(); 86 void addAllVideoToList();
88 void saveList(); // Save the playlist 87 void saveList(); // Save the playlist
89 void loadList( const DocLnk &); // Load a playlist 88 void loadList( const DocLnk &); // Load a playlist
90 void playIt( QListViewItem *); 89 void playIt( QListViewItem *);
91 90
92 void btnPlay(bool); 91 void btnPlay(bool);
93 void deletePlaylist(); 92 void deletePlaylist();
94 void addSelected(); 93 void addSelected();
95 void removeSelected(); 94 void removeSelected();
96 void tabChanged(QWidget*); 95 void tabChanged(QWidget*);
97 void viewPressed( int, QListViewItem *, const QPoint&, int); 96 void viewPressed( int, QListViewItem *, const QPoint&, int);
98 void playlistViewPressed( int, QListViewItem *, const QPoint&, int); 97 void playlistViewPressed( int, QListViewItem *, const QPoint&, int);
99 void playSelected(); 98 void playSelected();
100 void listDelete(); 99 void listDelete();
101 100
102protected slots: 101protected slots:
103/* void cancelMenuTimer(); */ 102/* void cancelMenuTimer(); */
104/* void showFileMenu(); */ 103/* void showFileMenu(); */
105 104
106 105
107}; 106};
108 107
109 108
110#endif // PLAY_LIST_WIDGET_H 109#endif // PLAY_LIST_WIDGET_H
111 110
diff --git a/noncore/multimedia/opieplayer2/videowidget.cpp b/noncore/multimedia/opieplayer2/videowidget.cpp
index 9b88299..33153d4 100644
--- a/noncore/multimedia/opieplayer2/videowidget.cpp
+++ b/noncore/multimedia/opieplayer2/videowidget.cpp
@@ -1,466 +1,523 @@
1/* 1/*
2                This file is part of the Opie Project 2                This file is part of the Opie Project
3 3
4              Copyright (c) 2002 Max Reiss <harlekin@handhelds.org> 4              Copyright (c) 2002 Max Reiss <harlekin@handhelds.org>
5 Copyright (c) 2002 L. Potter <ljp@llornkcor.com> 5 Copyright (c) 2002 L. Potter <ljp@llornkcor.com>
6 Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> 6 Copyright (c) 2002 Holger Freyther <zecke@handhelds.org>
7 =. 7 =.
8 .=l. 8 .=l.
9           .>+-= 9           .>+-=
10 _;:,     .>    :=|. This program is free software; you can 10 _;:,     .>    :=|. This program is free software; you can
11.> <`_,   >  .   <= redistribute it and/or modify it under 11.> <`_,   >  .   <= redistribute it and/or modify it under
12:`=1 )Y*s>-.--   : the terms of the GNU General Public 12:`=1 )Y*s>-.--   : the terms of the GNU General Public
13.="- .-=="i,     .._ License as published by the Free Software 13.="- .-=="i,     .._ License as published by the Free Software
14 - .   .-<_>     .<> Foundation; either version 2 of the License, 14 - .   .-<_>     .<> Foundation; either version 2 of the License,
15     ._= =}       : or (at your option) any later version. 15     ._= =}       : or (at your option) any later version.
16    .%`+i>       _;_. 16    .%`+i>       _;_.
17    .i_,=:_.      -<s. This program is distributed in the hope that 17    .i_,=:_.      -<s. This program is distributed in the hope that
18     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 18     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
19    : ..    .:,     . . . without even the implied warranty of 19    : ..    .:,     . . . without even the implied warranty of
20    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 20    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
21  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 21  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
22..}^=.=       =       ; Library General Public License for more 22..}^=.=       =       ; Library General Public License for more
23++=   -.     .`     .: details. 23++=   -.     .`     .: details.
24 :     =  ...= . :.=- 24 :     =  ...= . :.=-
25 -.   .:....=;==+<; You should have received a copy of the GNU 25 -.   .:....=;==+<; You should have received a copy of the GNU
26  -_. . .   )=.  = Library General Public License along with 26  -_. . .   )=.  = Library General Public License along with
27    --        :-=` this library; see the file COPYING.LIB. 27    --        :-=` this library; see the file COPYING.LIB.
28 If not, write to the Free Software Foundation, 28 If not, write to the Free Software Foundation,
29 Inc., 59 Temple Place - Suite 330, 29 Inc., 59 Temple Place - Suite 330,
30 Boston, MA 02111-1307, USA. 30 Boston, MA 02111-1307, USA.
31 31
32*/ 32*/
33 33
34#include <qpe/resource.h> 34#include <qpe/resource.h>
35#include <qpe/mediaplayerplugininterface.h> 35#include <qpe/mediaplayerplugininterface.h>
36#include <qpe/config.h> 36#include <qpe/config.h>
37 37
38#include <qwidget.h> 38#include <qwidget.h>
39#include <qpainter.h> 39#include <qpainter.h>
40#include <qpixmap.h> 40#include <qpixmap.h>
41#include <qslider.h> 41#include <qslider.h>
42#include <qdrawutil.h> 42#include <qdrawutil.h>
43#include "videowidget.h" 43#include "videowidget.h"
44#include "mediaplayerstate.h" 44#include "mediaplayerstate.h"
45 45
46 46
47#ifdef Q_WS_QWS 47#ifdef Q_WS_QWS
48# define USE_DIRECT_PAINTER 48# define USE_DIRECT_PAINTER
49# include <qdirectpainter_qws.h> 49# include <qdirectpainter_qws.h>
50# include <qgfxraster_qws.h> 50# include <qgfxraster_qws.h>
51#endif 51#endif
52 52
53 53
54extern MediaPlayerState *mediaPlayerState; 54extern MediaPlayerState *mediaPlayerState;
55 55
56 56
57static const int xo = 2; // movable x offset 57static const int xo = 2; // movable x offset
58static const int yo = 0; // movable y offset 58static const int yo = 0; // movable y offset
59 59
60 60
61struct MediaButton { 61struct MediaButton {
62 bool isToggle, isHeld, isDown; 62 bool isToggle, isHeld, isDown;
63}; 63};
64 64
65MediaButton videoButtons[] = { 65MediaButton videoButtons[] = {
66 { FALSE, FALSE, FALSE }, // previous
67 { FALSE, FALSE, FALSE }, // stop 66 { FALSE, FALSE, FALSE }, // stop
68 { TRUE, FALSE, FALSE }, // play 67 { TRUE, FALSE, FALSE }, // play
69 { TRUE, FALSE, FALSE }, // pause 68 { FALSE, FALSE, FALSE }, // previous
70 { FALSE, FALSE, FALSE }, // next 69 { FALSE, FALSE, FALSE }, // next
71 { FALSE, FALSE, FALSE }, // playlist 70 { FALSE, FALSE, FALSE }, // volUp
71 { FALSE, FALSE, FALSE }, // volDown
72 { TRUE, FALSE, FALSE } // fullscreen 72 { TRUE, FALSE, FALSE } // fullscreen
73}; 73};
74 74
75const char *skinV_mask_file_names[7] = { 75const char *skinV_mask_file_names[7] = {
76"stop","play","back","fwd","up","down","full" 76"stop","play","back","fwd","up","down","full"
77}; 77};
78 78
79static const int numButtons = (sizeof(videoButtons)/sizeof(MediaButton)); 79static const int numVButtons = (sizeof(videoButtons)/sizeof(MediaButton));
80 80
81 81
82VideoWidget::VideoWidget(QWidget* parent, const char* name, WFlags f) : 82VideoWidget::VideoWidget(QWidget* parent, const char* name, WFlags f) :
83QWidget( parent, name, f ), scaledWidth( 0 ), scaledHeight( 0 ) { 83QWidget( parent, name, f ), scaledWidth( 0 ), scaledHeight( 0 ) {
84 setCaption( tr("OpiePlayer - Video") ); 84 setCaption( tr("OpiePlayer - Video") );
85 85
86 videoFrame = new XineVideoWidget ( this, "Video frame" ); 86 videoFrame = new XineVideoWidget ( this, "Video frame" );
87 connect ( videoFrame, SIGNAL( videoResized ( const QSize & )), this, SIGNAL( videoResized ( const QSize & ))); 87 connect ( videoFrame, SIGNAL( videoResized ( const QSize & )), this, SIGNAL( videoResized ( const QSize & )));
88 88
89 Config cfg("OpiePlayer"); 89 Config cfg("OpiePlayer");
90 cfg.setGroup("VideoWidget"); 90 cfg.setGroup("VideoWidget");
91 skin = cfg.readEntry("Skin","default"); 91 skin = cfg.readEntry("Skin","default");
92 92
93 QString skinPath = "opieplayer2/skins/" + skin; 93 QString skinPath = "opieplayer2/skins/" + skin;
94 pixBg = new QPixmap( Resource::loadPixmap( QString("%1/background").arg(skinPath) ) ); 94 pixBg = new QPixmap( Resource::loadPixmap( QString("%1/background").arg(skinPath) ) );
95 imgUp = new QImage( Resource::loadImage( QString("%1/skinV_up").arg(skinPath) ) ); 95 imgUp = new QImage( Resource::loadImage( QString("%1/skinV_up").arg(skinPath) ) );
96 imgDn = new QImage( Resource::loadImage( QString("%1/skinV_down").arg(skinPath) ) ); 96 imgDn = new QImage( Resource::loadImage( QString("%1/skinV_down").arg(skinPath) ) );
97 97
98 imgButtonMask = new QImage( imgUp->width(), imgUp->height(), 8, 255 ); 98 imgButtonMask = new QImage( imgUp->width(), imgUp->height(), 8, 255 );
99 imgButtonMask->fill( 0 ); 99 imgButtonMask->fill( 0 );
100 100
101 for ( int i = 0; i < 7; i++ ) { 101 for ( int i = 0; i < 7; i++ ) {
102 QString filename = QString(getenv("OPIEDIR")) + "/pics/" + skinPath + "/skinV_mask_" + skinV_mask_file_names[i] + ".png"; 102 QString filename = QString(getenv("OPIEDIR")) + "/pics/" + skinPath + "/skinV_mask_" + skinV_mask_file_names[i] + ".png";
103 masks[i] = new QBitmap( filename ); 103 masks[i] = new QBitmap( filename );
104 qDebug(filename); 104 qDebug(filename);
105 if ( !masks[i]->isNull() ) { 105 if ( !masks[i]->isNull() ) {
106 QImage imgMask = masks[i]->convertToImage(); 106 QImage imgMask = masks[i]->convertToImage();
107 uchar **dest = imgButtonMask->jumpTable(); 107 uchar **dest = imgButtonMask->jumpTable();
108 for ( int y = 0; y < imgUp->height(); y++ ) { 108 for ( int y = 0; y < imgUp->height(); y++ ) {
109 uchar *line = dest[y]; 109 uchar *line = dest[y];
110 for ( int x = 0; x < imgUp->width(); x++ ) { 110 for ( int x = 0; x < imgUp->width(); x++ ) {
111 if ( !qRed( imgMask.pixel( x, y ) ) ) 111 if ( !qRed( imgMask.pixel( x, y ) ) )
112 line[x] = i + 1; 112 line[x] = i + 1;
113 } 113 }
114 } 114 }
115 } 115 }
116 116
117 } 117 }
118 118
119 for ( int i = 0; i < 7; i++ ) { 119 for ( int i = 0; i < 7; i++ ) {
120 buttonPixUp[i] = NULL; 120 buttonPixUp[i] = NULL;
121 buttonPixDown[i] = NULL; 121 buttonPixDown[i] = NULL;
122 } 122 }
123 123
124 setBackgroundPixmap( *pixBg ); 124 setBackgroundPixmap( *pixBg );
125 125
126 slider = new QSlider( Qt::Horizontal, this ); 126 slider = new QSlider( Qt::Horizontal, this );
127 slider->setMinValue( 0 ); 127 slider->setMinValue( 0 );
128 slider->setMaxValue( 1 ); 128 slider->setMaxValue( 1 );
129 slider->setBackgroundPixmap( Resource::loadPixmap( backgroundPix ) ); 129 slider->setBackgroundPixmap( Resource::loadPixmap( backgroundPix ) );
130 slider->setFocusPolicy( QWidget::NoFocus ); 130 slider->setFocusPolicy( QWidget::NoFocus );
131 slider->setGeometry( QRect( 7, 250, 220, 20 ) ); 131 slider->setGeometry( QRect( 7, 250, 220, 20 ) );
132 132
133 connect( slider, SIGNAL( sliderPressed() ), this, SLOT( sliderPressed() ) ); 133 connect( slider, SIGNAL( sliderPressed() ), this, SLOT( sliderPressed() ) );
134 connect( slider, SIGNAL( sliderReleased() ), this, SLOT( sliderReleased() ) ); 134 connect( slider, SIGNAL( sliderReleased() ), this, SLOT( sliderReleased() ) );
135 135
136 connect( mediaPlayerState, SIGNAL( lengthChanged(long) ), this, SLOT( setLength(long) ) ); 136 connect( mediaPlayerState, SIGNAL( lengthChanged(long) ), this, SLOT( setLength(long) ) );
137 connect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) ); 137 connect( mediaPlayerState, SIGNAL( positionChanged(long) ),this, SLOT( setPosition(long) ) );
138 connect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) ); 138 connect( mediaPlayerState, SIGNAL( positionUpdated(long) ),this, SLOT( setPosition(long) ) );
139 connect( mediaPlayerState, SIGNAL( viewChanged(char) ), this, SLOT( setView(char) ) ); 139 connect( mediaPlayerState, SIGNAL( viewChanged(char) ), this, SLOT( setView(char) ) );
140
140 connect( mediaPlayerState, SIGNAL( pausedToggled(bool) ), this, SLOT( setPaused(bool) ) ); 141 connect( mediaPlayerState, SIGNAL( pausedToggled(bool) ), this, SLOT( setPaused(bool) ) );
141 connect( mediaPlayerState, SIGNAL( playingToggled(bool) ), this, SLOT( setPlaying(bool) ) ); 142 connect( mediaPlayerState, SIGNAL( playingToggled(bool) ), this, SLOT( setPlaying(bool) ) );
142 143
143 setLength( mediaPlayerState->length() ); 144 setLength( mediaPlayerState->length() );
144 setPosition( mediaPlayerState->position() ); 145 setPosition( mediaPlayerState->position() );
145 146
146 ////////////////////////// FIXME 147 ////////////////////////// FIXME
147// setFullscreen( mediaPlayerState->fullscreen() ); 148// setFullscreen( mediaPlayerState->fullscreen() );
148 setPaused( mediaPlayerState->paused() ); 149 setPaused( mediaPlayerState->paused() );
149 setPlaying( mediaPlayerState->playing() ); 150 setPlaying( mediaPlayerState->playing() );
150 qDebug("finished videowidget"); 151 qDebug("finished videowidget");
151} 152}
152 153
153 154
154VideoWidget::~VideoWidget() { 155VideoWidget::~VideoWidget() {
156 mediaPlayerState->setPlaying( FALSE );
155 for ( int i = 0; i < 7; i++ ) { 157 for ( int i = 0; i < 7; i++ ) {
156 delete buttonPixUp[i]; 158 delete buttonPixUp[i];
157 delete buttonPixDown[i]; 159 delete buttonPixDown[i];
158 } 160 }
159 161
160 delete pixBg; 162 delete pixBg;
161 delete imgUp; 163 delete imgUp;
162 delete imgDn; 164 delete imgDn;
163 delete imgButtonMask; 165 delete imgButtonMask;
164 for ( int i = 0; i < 7; i++ ) { 166 for ( int i = 0; i < 7; i++ ) {
165 delete masks[i]; 167 delete masks[i];
166 } 168 }
169
167} 170}
168 171
169QPixmap *combineVImageWithBackground( QImage img, QPixmap bg, QPoint offset ) { 172QPixmap *combineVImageWithBackground( QImage img, QPixmap bg, QPoint offset ) {
170 QPixmap pix( img.width(), img.height() ); 173 QPixmap pix( img.width(), img.height() );
171 QPainter p( &pix ); 174 QPainter p( &pix );
172 p.drawTiledPixmap( pix.rect(), bg, offset ); 175 p.drawTiledPixmap( pix.rect(), bg, offset );
173 p.drawImage( 0, 0, img ); 176 p.drawImage( 0, 0, img );
174 return new QPixmap( pix ); 177 return new QPixmap( pix );
175} 178}
176 179
177QPixmap *maskVPixToMask( QPixmap pix, QBitmap mask ) { 180QPixmap *maskVPixToMask( QPixmap pix, QBitmap mask ) {
178 QPixmap *pixmap = new QPixmap( pix ); 181 QPixmap *pixmap = new QPixmap( pix );
179 pixmap->setMask( mask ); 182 pixmap->setMask( mask );
180 return pixmap; 183 return pixmap;
181} 184}
182 185
183void VideoWidget::resizeEvent( QResizeEvent * ) { 186void VideoWidget::resizeEvent( QResizeEvent * ) {
184 int h = height(); 187 int h = height();
185 int w = width(); 188 int w = width();
186 int Vh = 160; 189 int Vh = 160;
187 //videoFrame->height(); 190 //videoFrame->height();
188 int Vw = 220; 191 int Vw = 220;
189 //videoFrame->width(); 192 //videoFrame->width();
190// songInfo.setGeometry( QRect( 2, 10, w - 4, 20 ) ); 193// songInfo.setGeometry( QRect( 2, 10, w - 4, 20 ) );
191 194
192 slider->setFixedWidth( w - 110 ); 195 slider->setFixedWidth( w - 110 );
193 slider->setGeometry( QRect( 15, h - 30, w - 90, 20 ) ); 196 slider->setGeometry( QRect( 15, h - 30, w - 90, 20 ) );
194 slider->setBackgroundOrigin( QWidget::ParentOrigin ); 197 slider->setBackgroundOrigin( QWidget::ParentOrigin );
195 slider->setFocusPolicy( QWidget::NoFocus ); 198 slider->setFocusPolicy( QWidget::NoFocus );
196 slider->setBackgroundPixmap( *pixBg ); 199 slider->setBackgroundPixmap( *pixBg );
197 200
198// time.setGeometry( QRect( w - 85, h - 30, 70, 20 ) ); 201// time.setGeometry( QRect( w - 85, h - 30, 70, 20 ) );
199 xoff = 0;// ( imgUp->width() ) / 2; 202 xoff = 0;// ( imgUp->width() ) / 2;
200 yoff = 180;//(( Vh - imgUp->height() ) / 2) - 10; 203 yoff = 180;//(( Vh - imgUp->height() ) / 2) - 10;
201 QPoint p( xoff, yoff ); 204 QPoint p( xoff, yoff );
202 205
203 206
204 QPixmap *pixUp = combineVImageWithBackground( *imgUp, *pixBg, p ); 207 QPixmap *pixUp = combineVImageWithBackground( *imgUp, *pixBg, p );
205 QPixmap *pixDn = combineVImageWithBackground( *imgDn, *pixBg, p ); 208 QPixmap *pixDn = combineVImageWithBackground( *imgDn, *pixBg, p );
206 209
207 for ( int i = 0; i < 7; i++ ) { 210 for ( int i = 0; i < 7; i++ ) {
208 if ( !masks[i]->isNull() ) { 211 if ( !masks[i]->isNull() ) {
209 delete buttonPixUp[i]; 212 delete buttonPixUp[i];
210 delete buttonPixDown[i]; 213 delete buttonPixDown[i];
211 buttonPixUp[i] = maskVPixToMask( *pixUp, *masks[i] ); 214 buttonPixUp[i] = maskVPixToMask( *pixUp, *masks[i] );
212 buttonPixDown[i] = maskVPixToMask( *pixDn, *masks[i] ); 215 buttonPixDown[i] = maskVPixToMask( *pixDn, *masks[i] );
213 } 216 }
214 } 217 }
215 218
216 delete pixUp; 219 delete pixUp;
217 delete pixDn; 220 delete pixDn;
218} 221}
219 222
220static bool videoSliderBeingMoved = FALSE; 223static bool videoSliderBeingMoved = FALSE;
221 224
222void VideoWidget::sliderPressed() { 225void VideoWidget::sliderPressed() {
223 videoSliderBeingMoved = TRUE; 226 videoSliderBeingMoved = TRUE;
224} 227}
225 228
226void VideoWidget::sliderReleased() { 229void VideoWidget::sliderReleased() {
227 videoSliderBeingMoved = FALSE; 230 videoSliderBeingMoved = FALSE;
228 if ( slider->width() == 0 ) { 231 if ( slider->width() == 0 ) {
229 return; 232 return;
230 } 233 }
231 long val = long((double)slider->value() * mediaPlayerState->length() / slider->width()); 234 long val = long((double)slider->value() * mediaPlayerState->length() / slider->width());
232 mediaPlayerState->setPosition( val ); 235 mediaPlayerState->setPosition( val );
233} 236}
234 237
235void VideoWidget::setPosition( long i ) { 238void VideoWidget::setPosition( long i ) {
236 updateSlider( i, mediaPlayerState->length() ); 239 updateSlider( i, mediaPlayerState->length() );
237} 240}
238 241
239 242
240void VideoWidget::setLength( long max ) { 243void VideoWidget::setLength( long max ) {
241 updateSlider( mediaPlayerState->position(), max ); 244 updateSlider( mediaPlayerState->position(), max );
242} 245}
243 246
244void VideoWidget::setView( char view ) { 247void VideoWidget::setView( char view ) {
245 if ( view == 'v' ) { 248 if ( view == 'v' ) {
246 makeVisible(); 249 makeVisible();
247 } else { 250 } else {
248 // Effectively blank the view next time we show it so it looks nicer 251 // Effectively blank the view next time we show it so it looks nicer
249 scaledWidth = 0; 252 scaledWidth = 0;
250 scaledHeight = 0; 253 scaledHeight = 0;
251 hide(); 254 hide();
252 } 255 }
253} 256}
254 257
255void VideoWidget::updateSlider( long i, long max ) { 258void VideoWidget::updateSlider( long i, long max ) {
256 // Will flicker too much if we don't do this 259 // Will flicker too much if we don't do this
257 if ( max == 0 ) { 260 if ( max == 0 ) {
258 return; 261 return;
259 } 262 }
260 int width = slider->width(); 263 int width = slider->width();
261 int val = int((double)i * width / max); 264 int val = int((double)i * width / max);
262 if ( !mediaPlayerState->fullscreen() && !videoSliderBeingMoved ) { 265 if ( !mediaPlayerState->fullscreen() && !videoSliderBeingMoved ) {
263 if ( slider->value() != val ) { 266 if ( slider->value() != val ) {
264 slider->setValue( val ); 267 slider->setValue( val );
265 } 268 }
266 if ( slider->maxValue() != width ) { 269 if ( slider->maxValue() != width ) {
267 slider->setMaxValue( width ); 270 slider->setMaxValue( width );
268 } 271 }
269 } 272 }
270} 273}
271 274
272void VideoWidget::setToggleButton( int i, bool down ) { 275void VideoWidget::setToggleButton( int i, bool down ) {
273 if ( down != videoButtons[i].isDown ) { 276 if ( down != videoButtons[i].isDown ) {
274 toggleButton( i ); 277 toggleButton( i );
275 } 278 }
276} 279}
277 280
278void VideoWidget::toggleButton( int i ) { 281void VideoWidget::toggleButton( int i ) {
279 videoButtons[i].isDown = !videoButtons[i].isDown; 282 videoButtons[i].isDown = !videoButtons[i].isDown;
280 QPainter p(this); 283 QPainter p(this);
281 paintButton ( &p, i ); 284 paintButton ( &p, i );
282} 285}
283 286
284void VideoWidget::paintButton( QPainter *p, int i ) { 287void VideoWidget::paintButton( QPainter *p, int i ) {
285 288
286 if ( videoButtons[i].isDown ) 289 if ( videoButtons[i].isDown )
287 p->drawPixmap( xoff, yoff, *buttonPixDown[i] ); 290 p->drawPixmap( xoff, yoff, *buttonPixDown[i] );
288 else 291 else
289 p->drawPixmap( xoff, yoff, *buttonPixUp[i] ); 292 p->drawPixmap( xoff, yoff, *buttonPixUp[i] );
290} 293}
291 294
292void VideoWidget::mouseMoveEvent( QMouseEvent *event ) { 295void VideoWidget::mouseMoveEvent( QMouseEvent *event ) {
293 for ( int i = 0; i < numButtons; i++ ) { 296 for ( int i = 0; i < numVButtons; i++ ) {
294 if ( event->state() == QMouseEvent::LeftButton ) { 297 if ( event->state() == QMouseEvent::LeftButton ) {
295 // The test to see if the mouse click is inside the button or not 298 // The test to see if the mouse click is inside the button or not
296 int x = event->pos().x() - xoff; 299 int x = event->pos().x() - xoff;
297 int y = event->pos().y() - yoff; 300 int y = event->pos().y() - yoff;
298 301
299 bool isOnButton = ( x > 0 && y > 0 && x < imgButtonMask->width() 302 bool isOnButton = ( x > 0 && y > 0 && x < imgButtonMask->width()
300 && y < imgButtonMask->height() && imgButtonMask->pixelIndex( x, y ) == i + 1 ); 303 && y < imgButtonMask->height() && imgButtonMask->pixelIndex( x, y ) == i + 1 );
301 if ( isOnButton != videoButtons[i].isHeld ) { 304 if ( isOnButton != videoButtons[i].isHeld ) {
302 videoButtons[i].isHeld = isOnButton; 305 videoButtons[i].isHeld = isOnButton;
303 toggleButton(i); 306 toggleButton(i);
304 } 307 }
308
309// qDebug("mouseMove event switch1 %d", i);
310 if( isOnButton)
311 switch (i) {
312 case VideoStop:{
313 setToggleButton( i, FALSE );
314 mediaPlayerState->setStop(TRUE);
315 mediaPlayerState->setPlaying(FALSE);
316 return;
317 }
318 case VideoPlay: {
319
320 if( mediaPlayerState->isPaused) {
321 setToggleButton( i, FALSE );
322 mediaPlayerState->setPaused( FALSE);
323 return;
324 }
325 else if( mediaPlayerState->isPlaying) {
326 setToggleButton( i, TRUE );
327 mediaPlayerState->setPaused( TRUE);
328 return;
329 }
330 else {
331 setToggleButton( i, FALSE );
332 mediaPlayerState->setPlaying( videoButtons[i].isDown );
333 return;
334 }
335 }
336 case VideoNext: qDebug("next"); mediaPlayerState->setNext(); return;
337 case VideoPrevious: qDebug("previous"); mediaPlayerState->setPrev(); return;
338 case VideoVolUp: return;
339 case VideoVolDown: return;
340 case VideoFullscreen: mediaPlayerState->setFullscreen( TRUE ); makeVisible(); return;
341
342 };
343
305 } else { 344 } else {
306 if ( videoButtons[i].isHeld ) { 345 if ( videoButtons[i].isHeld ) {
307 videoButtons[i].isHeld = FALSE; 346 videoButtons[i].isHeld = FALSE;
308 if ( !videoButtons[i].isToggle ) 347 if ( !videoButtons[i].isToggle ) {
309 setToggleButton( i, FALSE ); 348 setToggleButton( i, FALSE );
349 }
350// qDebug("mouseMove event switch2 %d %d", i, VideoPlay);
351 switch (i) {
352 case VideoPlay: {
353 if( mediaPlayerState->isPaused) {
354 mediaPlayerState->setPaused( FALSE); return; }
355 else if( mediaPlayerState->isPlaying) {
356 mediaPlayerState->setPaused( TRUE); return; }
357 else
358 mediaPlayerState->setPlaying( TRUE /*videoButtons[i].isDown*/ ); return;
359 }
360 case VideoStop: mediaPlayerState->setPlaying(FALSE); return;
361// case VideoPause: mediaPlayerState->setPaused(videoButtons[i].isDown); return;
362 case VideoNext: mediaPlayerState->setNext(); return;
363 case VideoPrevious: mediaPlayerState->setPrev(); return;
364 case VideoVolUp: return;
365 case VideoVolDown: return;
366 case VideoFullscreen: mediaPlayerState->setFullscreen( TRUE ); makeVisible(); return;
367 }
310 } 368 }
311 } 369 }
312 switch (i) {
313 case VideoPlay: mediaPlayerState->setPlaying(videoButtons[i].isDown); return;
314 case VideoStop: mediaPlayerState->setPlaying(FALSE); return;
315 case VideoPause: mediaPlayerState->setPaused(videoButtons[i].isDown); return;
316 case VideoNext: mediaPlayerState->setNext(); return;
317 case VideoPrevious: mediaPlayerState->setPrev(); return;
318 case VideoPlayList: mediaPlayerState->setList(); return;
319 case VideoFullscreen: mediaPlayerState->setFullscreen( TRUE ); makeVisible(); return;
320 }
321
322 } 370 }
323} 371}
324 372
325void VideoWidget::mousePressEvent( QMouseEvent *event ) { 373void VideoWidget::mousePressEvent( QMouseEvent *event ) {
326 mouseMoveEvent( event ); 374 mouseMoveEvent( event );
327} 375}
328 376
329void VideoWidget::mouseReleaseEvent( QMouseEvent *event ) { 377void VideoWidget::mouseReleaseEvent( QMouseEvent *event ) {
330 if ( mediaPlayerState->fullscreen() ) { 378 if ( mediaPlayerState->fullscreen() ) {
331 mediaPlayerState->setFullscreen( FALSE ); 379 mediaPlayerState->setFullscreen( FALSE );
332 makeVisible(); 380 makeVisible();
333 381
334 mouseMoveEvent( event ); 382 mouseMoveEvent( event );
335 } 383 }
336} 384}
337 385
338 386
339void VideoWidget::makeVisible() { 387void VideoWidget::makeVisible() {
340 if ( mediaPlayerState->fullscreen() ) { 388 if ( mediaPlayerState->fullscreen() ) {
341 setBackgroundMode( QWidget::NoBackground ); 389 setBackgroundMode( QWidget::NoBackground );
342 showFullScreen(); 390 showFullScreen();
343 resize( qApp->desktop()->size() ); 391 resize( qApp->desktop()->size() );
344 slider->hide(); 392 slider->hide();
345 videoFrame-> setGeometry ( 0, 0, width ( ), height ( )); 393 videoFrame-> setGeometry ( 0, 0, width ( ), height ( ));
346 } else { 394 } else {
347 showNormal(); 395 showNormal();
348 showMaximized(); 396 showMaximized();
349 slider->show(); 397 slider->show();
350 videoFrame->setGeometry( QRect( 10, 20, 220, 160 ) ); 398 videoFrame->setGeometry( QRect( 10, 20, 220, 160 ) );
351 } 399 }
352} 400}
353 401
354 402
355void VideoWidget::paintEvent( QPaintEvent * pe) { 403void VideoWidget::paintEvent( QPaintEvent * pe) {
356 QPainter p( this ); 404 QPainter p( this );
357 405
358 if ( mediaPlayerState->fullscreen() ) { 406 if ( mediaPlayerState->fullscreen() ) {
359 // Clear the background 407 // Clear the background
360 p.setBrush( QBrush( Qt::black ) ); 408 p.setBrush( QBrush( Qt::black ) );
361// videoFrame->setGeometry( QRect( 0, 0 , 240 ,320 ) ); 409// videoFrame->setGeometry( QRect( 0, 0 , 240 ,320 ) );
362 410
363 } else { 411 } else {
364 412
365 // videoFrame->setGeometry( QRect( 0, 15 , 240 ,170 ) ); 413 // videoFrame->setGeometry( QRect( 0, 15 , 240 ,170 ) );
366 // draw the buttons 414 // draw the buttons
367 415
368 if ( !pe->erased() ) { 416 if ( !pe->erased() ) {
369 // Combine with background and double buffer 417 // Combine with background and double buffer
370 QPixmap pix( pe->rect().size() ); 418 QPixmap pix( pe->rect().size() );
371 QPainter p( &pix ); 419 QPainter p( &pix );
372 p.translate( -pe->rect().topLeft().x(), -pe->rect().topLeft().y() ); 420 p.translate( -pe->rect().topLeft().x(), -pe->rect().topLeft().y() );
373 p.drawTiledPixmap( pe->rect(), *pixBg, pe->rect().topLeft() ); 421 p.drawTiledPixmap( pe->rect(), *pixBg, pe->rect().topLeft() );
374 for ( int i = 0; i < numButtons; i++ ) 422 for ( int i = 0; i < numVButtons; i++ )
375 paintButton( &p, i ); 423 paintButton( &p, i );
376 QPainter p2( this ); 424 QPainter p2( this );
377 p2.drawPixmap( pe->rect().topLeft(), pix ); 425 p2.drawPixmap( pe->rect().topLeft(), pix );
378 } else { 426 } else {
379 QPainter p( this ); 427 QPainter p( this );
380 for ( int i = 0; i < numButtons; i++ ) 428 for ( int i = 0; i < numVButtons; i++ )
381 paintButton( &p, i ); 429 paintButton( &p, i );
382 } 430 }
383// for ( int i = 0; i < numButtons; i++ ) { 431// for ( int i = 0; i < numButtons; i++ ) {
384// paintButton( &p, i ); 432// paintButton( &p, i );
385// } 433// }
386// // draw the slider 434 // draw the slider
387// slider->repaint( TRUE ); 435 slider->repaint( TRUE );
388 } 436 }
389} 437}
390 438
391 439
392void VideoWidget::closeEvent( QCloseEvent* ) { 440void VideoWidget::closeEvent( QCloseEvent* ) {
393 mediaPlayerState->setList(); 441 mediaPlayerState->setList();
394} 442}
395 443
396 444
397bool VideoWidget::playVideo() { 445bool VideoWidget::playVideo() {
398 bool result = FALSE; 446 bool result = FALSE;
399 447
400 int stream = 0; 448 int stream = 0;
401 449
402 int sw = 240; 450 int sw = 240;
403 int sh = 320; 451 int sh = 320;
404 int dd = QPixmap::defaultDepth(); 452 int dd = QPixmap::defaultDepth();
405 int w = height(); 453 int w = height();
406 int h = width(); 454 int h = width();
407 455
408 return true; 456 return true;
409} 457}
410 458
411void VideoWidget::keyReleaseEvent( QKeyEvent *e) { 459void VideoWidget::keyReleaseEvent( QKeyEvent *e) {
412 switch ( e->key() ) { 460 switch ( e->key() ) {
413////////////////////////////// Zaurus keys 461////////////////////////////// Zaurus keys
414 case Key_Home: 462 case Key_Home:
415 break; 463 break;
416 case Key_F9: //activity 464 case Key_F9: //activity
417 break; 465 break;
418 case Key_F10: //contacts 466 case Key_F10: //contacts
419// hide(); 467// hide();
420 break; 468 break;
421 case Key_F11: //menu 469 case Key_F11: //menu
422 break; 470 break;
423 case Key_F12: //home 471 case Key_F12: //home
424 break; 472 break;
425 case Key_F13: //mail 473 case Key_F13: //mail
426 break; 474 break;
427 case Key_Space: { 475 case Key_Space: {
428 if(mediaPlayerState->playing()) { 476 if(mediaPlayerState->playing()) {
429 mediaPlayerState->setPlaying(FALSE); 477 mediaPlayerState->setPlaying(FALSE);
430 } else { 478 } else {
431 mediaPlayerState->setPlaying(TRUE); 479 mediaPlayerState->setPlaying(TRUE);
432 } 480 }
433 } 481 }
434 break; 482 break;
435 case Key_Down: 483 case Key_Down:
436// toggleButton(6); 484// toggleButton(6);
437// emit lessClicked(); 485// emit lessClicked();
438// emit lessReleased(); 486// emit lessReleased();
439// toggleButton(6); 487// toggleButton(6);
440 break; 488 break;
441 case Key_Up: 489 case Key_Up:
442// toggleButton(5); 490// toggleButton(5);
443// emit moreClicked(); 491// emit moreClicked();
444// emit moreReleased(); 492// emit moreReleased();
445// toggleButton(5); 493// toggleButton(5);
446 break; 494 break;
447 case Key_Right: 495 case Key_Right:
448 mediaPlayerState->setNext(); 496 mediaPlayerState->setNext();
449 break; 497 break;
450 case Key_Left: 498 case Key_Left:
451 mediaPlayerState->setPrev(); 499 mediaPlayerState->setPrev();
452 break; 500 break;
453 case Key_Escape: 501 case Key_Escape:
454 break; 502 break;
455 503
456 }; 504 };
457} 505}
458 506
459XineVideoWidget* VideoWidget::vidWidget() { 507XineVideoWidget* VideoWidget::vidWidget() {
460 return videoFrame; 508 return videoFrame;
461} 509}
462 510
463 511
464void VideoWidget::setFullscreen ( bool b ) { 512void VideoWidget::setFullscreen ( bool b ) {
465 setToggleButton( VideoFullscreen, b ); 513 setToggleButton( VideoFullscreen, b );
466} 514}
515
516void VideoWidget::setPaused( bool b) {
517// setToggleButton( VideoPause, b );
518}
519
520void VideoWidget::setPlaying( bool b) {
521 setToggleButton( VideoPlay, b );
522}
523
diff --git a/noncore/multimedia/opieplayer2/videowidget.h b/noncore/multimedia/opieplayer2/videowidget.h
index 830696e..92193a4 100644
--- a/noncore/multimedia/opieplayer2/videowidget.h
+++ b/noncore/multimedia/opieplayer2/videowidget.h
@@ -1,116 +1,117 @@
1/* 1/*
2                This file is part of the Opie Project 2                This file is part of the Opie Project
3 3
4              Copyright (c) 2002 Max Reiss <harlekin@handhelds.org> 4              Copyright (c) 2002 Max Reiss <harlekin@handhelds.org>
5 Copyright (c) 2002 L. Potter <ljp@llornkcor.com> 5 Copyright (c) 2002 L. Potter <ljp@llornkcor.com>
6 Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> 6 Copyright (c) 2002 Holger Freyther <zecke@handhelds.org>
7 =. 7 =.
8 .=l. 8 .=l.
9           .>+-= 9           .>+-=
10 _;:,     .>    :=|. This program is free software; you can 10 _;:,     .>    :=|. This program is free software; you can
11.> <`_,   >  .   <= redistribute it and/or modify it under 11.> <`_,   >  .   <= redistribute it and/or modify it under
12:`=1 )Y*s>-.--   : the terms of the GNU General Public 12:`=1 )Y*s>-.--   : the terms of the GNU General Public
13.="- .-=="i,     .._ License as published by the Free Software 13.="- .-=="i,     .._ License as published by the Free Software
14 - .   .-<_>     .<> Foundation; either version 2 of the License, 14 - .   .-<_>     .<> Foundation; either version 2 of the License,
15     ._= =}       : or (at your option) any later version. 15     ._= =}       : or (at your option) any later version.
16    .%`+i>       _;_. 16    .%`+i>       _;_.
17    .i_,=:_.      -<s. This program is distributed in the hope that 17    .i_,=:_.      -<s. This program is distributed in the hope that
18     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 18     +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
19    : ..    .:,     . . . without even the implied warranty of 19    : ..    .:,     . . . without even the implied warranty of
20    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 20    =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
21  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 21  _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
22..}^=.=       =       ; Library General Public License for more 22..}^=.=       =       ; Library General Public License for more
23++=   -.     .`     .: details. 23++=   -.     .`     .: details.
24 :     =  ...= . :.=- 24 :     =  ...= . :.=-
25 -.   .:....=;==+<; You should have received a copy of the GNU 25 -.   .:....=;==+<; You should have received a copy of the GNU
26  -_. . .   )=.  = Library General Public License along with 26  -_. . .   )=.  = Library General Public License along with
27    --        :-=` this library; see the file COPYING.LIB. 27    --        :-=` this library; see the file COPYING.LIB.
28 If not, write to the Free Software Foundation, 28 If not, write to the Free Software Foundation,
29 Inc., 59 Temple Place - Suite 330, 29 Inc., 59 Temple Place - Suite 330,
30 Boston, MA 02111-1307, USA. 30 Boston, MA 02111-1307, USA.
31 31
32*/ 32*/
33 33
34#ifndef VIDEO_WIDGET_H 34#ifndef VIDEO_WIDGET_H
35#define VIDEO_WIDGET_H 35#define VIDEO_WIDGET_H
36 36
37#include <qwidget.h> 37#include <qwidget.h>
38#include "xinevideowidget.h" 38#include "xinevideowidget.h"
39 39
40class QPixmap; 40class QPixmap;
41class QSlider; 41class QSlider;
42 42
43enum VideoButtons { 43enum VideoButtons {
44 VideoPrevious,
45 VideoStop, 44 VideoStop,
46 VideoPlay, 45 VideoPlay,
47 VideoPause, 46// VideoPause,
47 VideoPrevious,
48 VideoNext, 48 VideoNext,
49 VideoPlayList, 49 VideoVolUp,
50 VideoVolDown,
50 VideoFullscreen 51 VideoFullscreen
51}; 52};
52 53
53class VideoWidget : public QWidget { 54class VideoWidget : public QWidget {
54 Q_OBJECT 55 Q_OBJECT
55public: 56public:
56 VideoWidget( QWidget* parent=0, const char* name=0, WFlags f=0 ); 57 VideoWidget( QWidget* parent=0, const char* name=0, WFlags f=0 );
57 ~VideoWidget(); 58 ~VideoWidget();
58 59
59 bool playVideo(); 60 bool playVideo();
60 XineVideoWidget* vidWidget(); 61 XineVideoWidget* vidWidget();
61public slots: 62public slots:
62 void updateSlider( long, long ); 63 void updateSlider( long, long );
63 void sliderPressed( ); 64 void sliderPressed( );
64 void sliderReleased( ); 65 void sliderReleased( );
65 void setPaused( bool b) { setToggleButton( VideoPause, b ); } 66 void setPaused( bool b);
66 void setPlaying( bool b) { setToggleButton( VideoPlay, b ); } 67 void setPlaying( bool b);
67 void setFullscreen( bool b ); 68 void setFullscreen( bool b );
68 void makeVisible(); 69 void makeVisible();
69 void setPosition( long ); 70 void setPosition( long );
70 void setLength( long ); 71 void setLength( long );
71 void setView( char ); 72 void setView( char );
72 73
73signals: 74signals:
74 void sliderMoved( long ); 75 void sliderMoved( long );
75 void videoResized ( const QSize &s ); 76 void videoResized ( const QSize &s );
76 77
77protected: 78protected:
78 QString skin; 79 QString skin;
79 void resizeEvent( QResizeEvent * ); 80 void resizeEvent( QResizeEvent * );
80 void paintEvent( QPaintEvent *pe ); 81 void paintEvent( QPaintEvent *pe );
81 void mouseMoveEvent( QMouseEvent *event ); 82 void mouseMoveEvent( QMouseEvent *event );
82 void mousePressEvent( QMouseEvent *event ); 83 void mousePressEvent( QMouseEvent *event );
83 void mouseReleaseEvent( QMouseEvent *event ); 84 void mouseReleaseEvent( QMouseEvent *event );
84 void closeEvent( QCloseEvent *event ); 85 void closeEvent( QCloseEvent *event );
85 void keyReleaseEvent( QKeyEvent *e); 86 void keyReleaseEvent( QKeyEvent *e);
86 87
87private: 88private:
88// Ticker songInfo; 89// Ticker songInfo;
89 QPixmap *pixBg; 90 QPixmap *pixBg;
90 QImage *imgUp; 91 QImage *imgUp;
91 QImage *imgDn; 92 QImage *imgDn;
92 QImage *imgButtonMask; 93 QImage *imgButtonMask;
93 QBitmap *masks[7]; 94 QBitmap *masks[7];
94 QPixmap *buttonPixUp[7]; 95 QPixmap *buttonPixUp[7];
95 QPixmap *buttonPixDown[7]; 96 QPixmap *buttonPixDown[7];
96// QPixmap *pixmaps[4]; 97// QPixmap *pixmaps[4];
97 int xoff, yoff; 98 int xoff, yoff;
98 99
99 100
100 void paintButton( QPainter *p, int i ); 101 void paintButton( QPainter *p, int i );
101 void toggleButton( int ); 102 void toggleButton( int );
102 void setToggleButton( int, bool ); 103 void setToggleButton( int, bool );
103 104
104 QString backgroundPix; 105 QString backgroundPix;
105 QSlider *slider; 106 QSlider *slider;
106 QPixmap *pixmaps[3]; 107 QPixmap *pixmaps[3];
107 QImage *currentFrame; 108 QImage *currentFrame;
108 int scaledWidth; 109 int scaledWidth;
109 int scaledHeight; 110 int scaledHeight;
110 XineVideoWidget* videoFrame; 111 XineVideoWidget* videoFrame;
111}; 112};
112 113
113#endif // VIDEO_WIDGET_H 114#endif // VIDEO_WIDGET_H
114 115
115 116
116 117