summaryrefslogtreecommitdiff
path: root/core/multimedia/opieplayer/playlistwidget.cpp
authorllornkcor <llornkcor>2002-04-10 19:13:40 (UTC)
committer llornkcor <llornkcor>2002-04-10 19:13:40 (UTC)
commit9237a75548f9b932fbb1900d8ea28dbee9da81ac (patch) (unidiff)
treea0249408df5ce581af8bcee5b6f58bcee1db461a /core/multimedia/opieplayer/playlistwidget.cpp
parent11d754ffa429875b526c49f125d8a844c5cda3d8 (diff)
downloadopie-9237a75548f9b932fbb1900d8ea28dbee9da81ac.zip
opie-9237a75548f9b932fbb1900d8ea28dbee9da81ac.tar.gz
opie-9237a75548f9b932fbb1900d8ea28dbee9da81ac.tar.bz2
bug fix
Diffstat (limited to 'core/multimedia/opieplayer/playlistwidget.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--core/multimedia/opieplayer/playlistwidget.cpp250
1 files changed, 138 insertions, 112 deletions
diff --git a/core/multimedia/opieplayer/playlistwidget.cpp b/core/multimedia/opieplayer/playlistwidget.cpp
index 3b8f6d7..63df715 100644
--- a/core/multimedia/opieplayer/playlistwidget.cpp
+++ b/core/multimedia/opieplayer/playlistwidget.cpp
@@ -16,24 +16,25 @@
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20// code added by L. J. Potter Sat 03-02-2002 06:17:54 20// code added by L. J. Potter Sat 03-02-2002 06:17:54
21#define QTOPIA_INTERNAL_FSLP 21#define QTOPIA_INTERNAL_FSLP
22 22
23#include <qpe/qpemenubar.h> 23#include <qpe/qpemenubar.h>
24#include <qpe/qpetoolbar.h> 24#include <qpe/qpetoolbar.h>
25#include <qpe/fileselector.h> 25#include <qpe/fileselector.h>
26#include <qpe/qpeapplication.h> 26#include <qpe/qpeapplication.h>
27#include <qpe/lnkproperties.h> 27#include <qpe/lnkproperties.h>
28#include <qpe/storage.h>
28 29
29#include <qpe/applnk.h> 30#include <qpe/applnk.h>
30#include <qpe/config.h> 31#include <qpe/config.h>
31#include <qpe/global.h> 32#include <qpe/global.h>
32#include <qpe/resource.h> 33#include <qpe/resource.h>
33#include <qaction.h> 34#include <qaction.h>
34#include <qimage.h> 35#include <qimage.h>
35#include <qfile.h> 36#include <qfile.h>
36#include <qdir.h> 37#include <qdir.h>
37#include <qlayout.h> 38#include <qlayout.h>
38#include <qlabel.h> 39#include <qlabel.h>
39#include <qlist.h> 40#include <qlist.h>
@@ -207,46 +208,52 @@ PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl )
207 QVBox *stretch2 = new QVBox( vbox1 ); stretch2->setBackgroundMode( PaletteButton ); // add stretch 208 QVBox *stretch2 = new QVBox( vbox1 ); stretch2->setBackgroundMode( PaletteButton ); // add stretch
208 209
209 QWidget *aTab; 210 QWidget *aTab;
210 aTab = new QWidget( tabWidget, "aTab" ); 211 aTab = new QWidget( tabWidget, "aTab" );
211 audioView = new QListView( aTab, "Audioview" ); 212 audioView = new QListView( aTab, "Audioview" );
212 audioView->setMinimumSize(233,260); 213 audioView->setMinimumSize(233,260);
213 audioView->addColumn( tr("Title"),140); 214 audioView->addColumn( tr("Title"),140);
214 audioView->addColumn(tr("Size"), -1); 215 audioView->addColumn(tr("Size"), -1);
215 audioView->addColumn(tr("Media"),-1); 216 audioView->addColumn(tr("Media"),-1);
216 audioView->setColumnAlignment(1, Qt::AlignRight); 217 audioView->setColumnAlignment(1, Qt::AlignRight);
217 audioView->setColumnAlignment(2, Qt::AlignRight); 218 audioView->setColumnAlignment(2, Qt::AlignRight);
218 audioView->setAllColumnsShowFocus(TRUE); 219 audioView->setAllColumnsShowFocus(TRUE);
220// audioView->setMultiSelection( TRUE );
221// audioView->setSelectionMode( QListView::Extended);
222
219 tabWidget->insertTab(aTab,tr("Audio")); 223 tabWidget->insertTab(aTab,tr("Audio"));
220 224
221 QPEApplication::setStylusOperation( audioView->viewport(),QPEApplication::RightOnHold); 225 QPEApplication::setStylusOperation( audioView->viewport(),QPEApplication::RightOnHold);
222 connect( audioView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), 226 connect( audioView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)),
223 this,SLOT( viewPressed(int, QListViewItem *, const QPoint&, int)) ); 227 this,SLOT( viewPressed(int, QListViewItem *, const QPoint&, int)) );
224 228
225 229
226// audioView 230// audioView
227 populateAudioView(); 231 populateAudioView();
228// videowidget 232// videowidget
229 233
230 QWidget *vTab; 234 QWidget *vTab;
231 vTab = new QWidget( tabWidget, "vTab" ); 235 vTab = new QWidget( tabWidget, "vTab" );
232 videoView = new QListView( vTab, "Videoview" ); 236 videoView = new QListView( vTab, "Videoview" );
233 videoView->setMinimumSize(233,260); 237 videoView->setMinimumSize(233,260);
234 238
235 videoView->addColumn(tr("Title"),140); 239 videoView->addColumn(tr("Title"),140);
236 videoView->addColumn(tr("Size"),-1); 240 videoView->addColumn(tr("Size"),-1);
237 videoView->addColumn(tr("Media"),-1); 241 videoView->addColumn(tr("Media"),-1);
238 videoView->setColumnAlignment(1, Qt::AlignRight); 242 videoView->setColumnAlignment(1, Qt::AlignRight);
239 videoView->setColumnAlignment(2, Qt::AlignRight); 243 videoView->setColumnAlignment(2, Qt::AlignRight);
240 videoView->setAllColumnsShowFocus(TRUE); 244 videoView->setAllColumnsShowFocus(TRUE);
245// videoView->setMultiSelection( TRUE );
246// videoView->setSelectionMode( QListView::Extended);
247
241 QPEApplication::setStylusOperation( videoView->viewport(),QPEApplication::RightOnHold); 248 QPEApplication::setStylusOperation( videoView->viewport(),QPEApplication::RightOnHold);
242 connect( videoView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), 249 connect( videoView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)),
243 this,SLOT( viewPressed(int, QListViewItem *, const QPoint&, int)) ); 250 this,SLOT( viewPressed(int, QListViewItem *, const QPoint&, int)) );
244 251
245 tabWidget->insertTab( vTab,tr("Video")); 252 tabWidget->insertTab( vTab,tr("Video"));
246 253
247 254
248//playlists list 255//playlists list
249 QWidget *LTab; 256 QWidget *LTab;
250 LTab = new QWidget( tabWidget, "LTab" ); 257 LTab = new QWidget( tabWidget, "LTab" );
251 playLists = new FileSelector( "playlist/plain", LTab, "fileselector" , FALSE, FALSE); //buggy 258 playLists = new FileSelector( "playlist/plain", LTab, "fileselector" , FALSE, FALSE); //buggy
252 playLists->setMinimumSize(233,260);; 259 playLists->setMinimumSize(233,260);;
@@ -309,113 +316,111 @@ void PlayListWidget::initializeStates() {
309 d->tbShuffle->setOn( mediaPlayerState->shuffled() ); 316 d->tbShuffle->setOn( mediaPlayerState->shuffled() );
310// d->tbFull->setOn( mediaPlayerState->fullscreen() ); 317// d->tbFull->setOn( mediaPlayerState->fullscreen() );
311// d->tbScale->setOn( mediaPlayerState->scaled() ); 318// d->tbScale->setOn( mediaPlayerState->scaled() );
312// d->tbScale->setEnabled( mediaPlayerState->fullscreen() ); 319// d->tbScale->setEnabled( mediaPlayerState->fullscreen() );
313// setPlaylist( mediaPlayerState->playlist() ); 320// setPlaylist( mediaPlayerState->playlist() );
314 setPlaylist( true); 321 setPlaylist( true);
315 d->selectedFiles->first(); 322 d->selectedFiles->first();
316} 323}
317 324
318 325
319void PlayListWidget::readConfig( Config& cfg ) { 326void PlayListWidget::readConfig( Config& cfg ) {
320 cfg.setGroup("PlayList"); 327 cfg.setGroup("PlayList");
321 328 QString currentString = cfg.readEntry("current", "" );
322 int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); 329 int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 );
323
324 for ( int i = 0; i < noOfFiles; i++ ) { 330 for ( int i = 0; i < noOfFiles; i++ ) {
325 QString entryName; 331 QString entryName;
326 entryName.sprintf( "File%i", i + 1 ); 332 entryName.sprintf( "File%i", i + 1 );
327 QString linkFile = cfg.readEntry( entryName ); 333 QString linkFile = cfg.readEntry( entryName );
328 DocLnk lnk( linkFile ); 334 DocLnk lnk( linkFile );
329 if ( lnk.isValid() ) 335 if ( lnk.isValid() ) {
330 d->selectedFiles->addToSelection( lnk ); 336 d->selectedFiles->addToSelection( lnk );
337 }
331 } 338 }
339// d->selectedFiles->setSelectedItem( (const QString &)currentString);
332} 340}
333 341
334 342
335void PlayListWidget::writeConfig( Config& cfg ) const { 343void PlayListWidget::writeConfig( Config& cfg ) const {
336 cfg.setGroup("PlayList");
337 344
345 d->selectedFiles->writeCurrent( cfg);
346 cfg.setGroup("PlayList");
338 int noOfFiles = 0; 347 int noOfFiles = 0;
339
340 d->selectedFiles->first(); 348 d->selectedFiles->first();
341 do { 349 do {
342 const DocLnk *lnk = d->selectedFiles->current(); 350 const DocLnk *lnk = d->selectedFiles->current();
343 if ( lnk ) { 351 if ( lnk ) {
344 QString entryName; 352 QString entryName;
345 entryName.sprintf( "File%i", noOfFiles + 1 ); 353 entryName.sprintf( "File%i", noOfFiles + 1 );
346 cfg.writeEntry( entryName, lnk->linkFile() ); 354 qDebug(entryName);
347 // if this link does exist, add it so we have the file 355 cfg.writeEntry( entryName, lnk->linkFile() );
348 // next time... 356 // if this link does exist, add it so we have the file
349 if ( !QFile::exists( lnk->linkFile() ) ) { 357 // next time...
350 // the way writing lnks doesn't really check for out 358 if ( !QFile::exists( lnk->linkFile() ) ) {
351 // of disk space, but check it anyway. 359 // the way writing lnks doesn't really check for out
352 if ( !lnk->writeLink() ) { 360 // of disk space, but check it anyway.
353 QMessageBox::critical( 0, tr("Out of space"), 361 if ( !lnk->writeLink() ) {
354 tr( "There was a problem saving " 362 QMessageBox::critical( 0, tr("Out of space"),
355 "the playlist.\n" 363 tr( "There was a problem saving "
356 "Your playlist " 364 "the playlist.\n"
357 "may be missing some entries\n" 365 "Your playlist "
358 "the next time you start it." ) 366 "may be missing some entries\n"
359 ); 367 "the next time you start it." )
368 );
369 }
370 }
371 noOfFiles++;
372 }
360 } 373 }
361 } 374 while ( d->selectedFiles->next() );
362 noOfFiles++;
363 }
364 } while ( d->selectedFiles->next() );
365
366 cfg.writeEntry("NumberOfFiles", noOfFiles ); 375 cfg.writeEntry("NumberOfFiles", noOfFiles );
367
368
369} 376}
370 377
371 378
372void PlayListWidget::addToSelection( const DocLnk& lnk ) { 379void PlayListWidget::addToSelection( const DocLnk& lnk ) {
373// qDebug("add"); 380// qDebug("add");
374 d->setDocumentUsed = FALSE; 381 d->setDocumentUsed = FALSE;
375 if ( mediaPlayerState->playlist() ) 382 if ( mediaPlayerState->playlist() )
376 d->selectedFiles->addToSelection( lnk ); 383 d->selectedFiles->addToSelection( lnk );
377 else 384 else
378 mediaPlayerState->setPlaying( TRUE ); 385 mediaPlayerState->setPlaying( TRUE );
379} 386}
380 387
381 388
382void PlayListWidget::clearList() { 389void PlayListWidget::clearList() {
383 while ( first() ) 390 while ( first() )
384 d->selectedFiles->removeSelected(); 391 d->selectedFiles->removeSelected();
385} 392}
386 393
387 394
388void PlayListWidget::addAllToList() { 395void PlayListWidget::addAllToList() {
389 DocLnkSet files; 396 DocLnkSet filesAll;
390 Global::findDocuments(&files, "video/*;audio/*"); 397 Global::findDocuments(&filesAll, "video/*;audio/*");
391 QListIterator<DocLnk> dit( files.children() ); 398 QListIterator<DocLnk> Adit( filesAll.children() );
392 for ( ; dit.current(); ++dit ) 399 for ( ; Adit.current(); ++Adit )
393 d->selectedFiles->addToSelection( **dit ); 400 d->selectedFiles->addToSelection( **Adit );
394} 401}
395 402
396 403
397void PlayListWidget::addAllMusicToList() { 404void PlayListWidget::addAllMusicToList() {
398 DocLnkSet files; 405// DocLnkSet files;
399 Global::findDocuments(&files, "audio/*"); 406// Global::findDocuments(&files, "audio/*");
400 QListIterator<DocLnk> dit( files.children() ); 407 QListIterator<DocLnk> dit( files.children() );
401 for ( ; dit.current(); ++dit ) 408 for ( ; dit.current(); ++dit )
402 d->selectedFiles->addToSelection( **dit ); 409 d->selectedFiles->addToSelection( **dit );
403} 410}
404 411
405 412
406void PlayListWidget::addAllVideoToList() { 413void PlayListWidget::addAllVideoToList() {
407 DocLnkSet files; 414 QListIterator<DocLnk> dit( vFiles.children() );
408 Global::findDocuments(&files, "video/*");
409 QListIterator<DocLnk> dit( files.children() );
410 for ( ; dit.current(); ++dit ) 415 for ( ; dit.current(); ++dit )
411 d->selectedFiles->addToSelection( **dit ); 416 d->selectedFiles->addToSelection( **dit );
412} 417}
413 418
414 419
415void PlayListWidget::setDocument(const QString& fileref) { 420void PlayListWidget::setDocument(const QString& fileref) {
416 fromSetDocument = TRUE; 421 fromSetDocument = TRUE;
417 if ( fileref.isNull() ) { 422 if ( fileref.isNull() ) {
418 QMessageBox::critical( 0, tr( "Invalid File" ), tr( "There was a problem in getting the file." ) ); 423 QMessageBox::critical( 0, tr( "Invalid File" ), tr( "There was a problem in getting the file." ) );
419 return; 424 return;
420 } 425 }
421// qDebug("setDocument "+fileref); 426// qDebug("setDocument "+fileref);
@@ -459,33 +464,33 @@ const DocLnk *PlayListWidget::current() { // this is fugly
459// QListIterator<DocLnk> dit( files.children() ); 464// QListIterator<DocLnk> dit( files.children() );
460// for ( ; dit.current(); ++dit ) { 465// for ( ; dit.current(); ++dit ) {
461// if(dit.current()->linkFile() == setDocFileRef) { 466// if(dit.current()->linkFile() == setDocFileRef) {
462// qDebug(setDocFileRef); 467// qDebug(setDocFileRef);
463// return dit; 468// return dit;
464// } 469// }
465// } 470// }
466// } else 471// } else
467// qDebug("current"); 472// qDebug("current");
468// switch (tabWidget->currentPageIndex()) { 473// switch (tabWidget->currentPageIndex()) {
469// case 0: //playlist 474// case 0: //playlist
470// { 475// {
471 qDebug("playlist"); 476 qDebug("playlist");
472 if ( mediaPlayerState->playlist() ) { 477 if ( mediaPlayerState->playlist() ) {
473 return d->selectedFiles->current(); 478 return d->selectedFiles->current();
474 } 479 }
475 else if ( d->setDocumentUsed && d->current ) { 480 else if ( d->setDocumentUsed && d->current ) {
476 return d->current; 481 return d->current;
477 } else { 482 } else {
478 return d->files->selected(); 483 return d->files->selected();
479 } 484 }
480// } 485// }
481// break; 486// break;
482// case 1://audio 487// case 1://audio
483// { 488// {
484// qDebug("audioView"); 489// qDebug("audioView");
485// Global::findDocuments(&files, "audio/*"); 490// Global::findDocuments(&files, "audio/*");
486// QListIterator<DocLnk> dit( files.children() ); 491// QListIterator<DocLnk> dit( files.children() );
487// for ( ; dit.current(); ++dit ) { 492// for ( ; dit.current(); ++dit ) {
488// if( dit.current()->name() == audioView->currentItem()->text(0) && !insanityBool) { 493// if( dit.current()->name() == audioView->currentItem()->text(0) && !insanityBool) {
489// qDebug("here"); 494// qDebug("here");
490// insanityBool=TRUE; 495// insanityBool=TRUE;
491// return dit; 496// return dit;
@@ -503,138 +508,145 @@ const DocLnk *PlayListWidget::current() { // this is fugly
503// insanityBool=TRUE; 508// insanityBool=TRUE;
504// return Vdit; 509// return Vdit;
505// } 510// }
506// } 511// }
507// } 512// }
508// break; 513// break;
509// }; 514// };
510// return 0; 515// return 0;
511} 516}
512 517
513bool PlayListWidget::prev() { 518bool PlayListWidget::prev() {
514 if ( mediaPlayerState->playlist() ) { 519 if ( mediaPlayerState->playlist() ) {
515 if ( mediaPlayerState->shuffled() ) { 520 if ( mediaPlayerState->shuffled() ) {
516 const DocLnk *cur = current(); 521 const DocLnk *cur = current();
517 int j = 1 + (int)(97.0 * rand() / (RAND_MAX + 1.0)); 522 int j = 1 + (int)(97.0 * rand() / (RAND_MAX + 1.0));
518 for ( int i = 0; i < j; i++ ) { 523 for ( int i = 0; i < j; i++ ) {
519 if ( !d->selectedFiles->next() ) 524 if ( !d->selectedFiles->next() )
520 d->selectedFiles->first(); 525 d->selectedFiles->first();
521 } 526 }
522 if ( cur == current() ) 527 if ( cur == current() )
523 if ( !d->selectedFiles->next() ) 528 if ( !d->selectedFiles->next() )
524 d->selectedFiles->first(); 529 d->selectedFiles->first();
525 return TRUE; 530 return TRUE;
526 } else { 531 } else {
527 if ( !d->selectedFiles->prev() ) { 532 if ( !d->selectedFiles->prev() ) {
528 if ( mediaPlayerState->looping() ) { 533 if ( mediaPlayerState->looping() ) {
529 return d->selectedFiles->last(); 534 return d->selectedFiles->last();
530 } else { 535 } else {
531 return FALSE; 536 return FALSE;
532 } 537 }
533 } 538 }
534 return TRUE; 539 return TRUE;
535 } 540 }
536 } else { 541 } else {
537 return mediaPlayerState->looping(); 542 return mediaPlayerState->looping();
538 } 543 }
539} 544}
540 545
541 546
542bool PlayListWidget::next() { 547bool PlayListWidget::next() {
543 if ( mediaPlayerState->playlist() ) { 548 if ( mediaPlayerState->playlist() ) {
544 if ( mediaPlayerState->shuffled() ) { 549 if ( mediaPlayerState->shuffled() ) {
545 return prev(); 550 return prev();
546 } else { 551 } else {
547 if ( !d->selectedFiles->next() ) { 552 if ( !d->selectedFiles->next() ) {
548 if ( mediaPlayerState->looping() ) { 553 if ( mediaPlayerState->looping() ) {
549 return d->selectedFiles->first(); 554 return d->selectedFiles->first();
550 } else { 555 } else {
551 return FALSE; 556 return FALSE;
552 } 557 }
553 } 558 }
554 return TRUE; 559 return TRUE;
555 } 560 }
556 } else { 561 } else {
557 return mediaPlayerState->looping(); 562 return mediaPlayerState->looping();
558 } 563 }
559} 564}
560 565
561 566
562bool PlayListWidget::first() { 567bool PlayListWidget::first() {
563 if ( mediaPlayerState->playlist() ) 568 if ( mediaPlayerState->playlist() )
564 return d->selectedFiles->first(); 569 return d->selectedFiles->first();
565 else 570 else
566 return mediaPlayerState->looping(); 571 return mediaPlayerState->looping();
567} 572}
568 573
569 574
570bool PlayListWidget::last() { 575bool PlayListWidget::last() {
571 if ( mediaPlayerState->playlist() ) 576 if ( mediaPlayerState->playlist() )
572 return d->selectedFiles->last(); 577 return d->selectedFiles->last();
573 else 578 else
574 return mediaPlayerState->looping(); 579 return mediaPlayerState->looping();
575} 580}
576 581
577 582
578void PlayListWidget::saveList() { 583void PlayListWidget::saveList() {
579 584
580 QString filename; 585 QString filename;
581 InputDialog *fileDlg; 586 InputDialog *fileDlg;
582 fileDlg = new InputDialog(this,tr("Save Playlist"),TRUE, 0); 587 fileDlg = new InputDialog(this,tr("Save Playlist"),TRUE, 0);
583 fileDlg->exec(); 588 fileDlg->exec();
584 if( fileDlg->result() == 1 ) { 589 if( fileDlg->result() == 1 ) {
585 if ( d->current ) 590 if ( d->current )
586 delete d->current; 591 delete d->current;
587 filename = fileDlg->LineEdit1->text();//+".playlist"; 592 filename = fileDlg->LineEdit1->text();//+".playlist";
588// qDebug("saving playlist "+filename+".playlist"); 593// qDebug("saving playlist "+filename+".playlist");
589 Config cfg( filename +".playlist"); 594 Config cfg( filename +".playlist");
590 writeConfig( cfg ); 595 writeConfig( cfg );
591 if( playLists->selected()->name() == filename) { 596
592// qDebug("same name so delete lnk"); 597// qDebug("same name so delete lnk??");
593 QFile().remove(playLists->selected()->file()); 598// if( playLists->selected()->name() == filename) {
594 QFile().remove(playLists->selected()->linkFile()); 599
595 playLists->reread(); 600// qDebug("same name so delete lnk");
596 } 601// QFile().remove(playLists->selected()->file());
597 602// QFile().remove(playLists->selected()->linkFile());
603// playLists->reread();
604// }
605// qDebug("new doclnk");
598 DocLnk lnk; 606 DocLnk lnk;
599// lnk.setComment( ""); 607// lnk.setComment( "");
600 lnk.setFile(QDir::homeDirPath()+"/Settings/"+filename+".playlist.conf"); //sets File property 608 lnk.setFile(QDir::homeDirPath()+"/Settings/"+filename+".playlist.conf"); //sets File property
601 lnk.setType("playlist/plain");// hey is this a REGISTERED mime type?!?!? ;D 609 lnk.setType("playlist/plain");// hey is this a REGISTERED mime type?!?!? ;D
602 lnk.setIcon("mpegplayer/playlist2"); 610 lnk.setIcon("mpegplayer/playlist2");
603 lnk.setName( filename); //sets file name 611 lnk.setName( filename); //sets file name
612 qDebug(filename);
604 if(!lnk.writeLink()) 613 if(!lnk.writeLink())
605 qDebug("Writing doclink did not work"); 614 qDebug("Writing doclink did not work");
606 } 615 }
607 Config config( "MediaPlayer" ); 616 Config config( "MediaPlayer" );
608 config.writeEntry("CurrentPlaylist",filename); 617 config.writeEntry("CurrentPlaylist",filename);
609 setCaption(tr("OpiePlayer: ")+filename); 618 setCaption(tr("OpiePlayer: ")+filename);
610 d->selectedFiles->first(); 619 d->selectedFiles->first();
611 if(fileDlg) 620 if(fileDlg)
612 delete fileDlg; 621 delete fileDlg;
613} 622}
614 623
615void PlayListWidget::loadList( const DocLnk & lnk) { 624void PlayListWidget::loadList( const DocLnk & lnk) {
616 QString name= lnk.name(); 625 QString name= lnk.name();
617// qDebug("currentList is "+name); 626// qDebug("currentList is "+name);
618 if( name.length()>1) { 627 if( name.length()>1) {
619 setCaption("OpiePlayer: "+name); 628 setCaption("OpiePlayer: "+name);
620// qDebug("load list "+ name+".playlist"); 629// qDebug("load list "+ name+".playlist");
621 clearList(); 630 clearList();
622 Config cfg( name+".playlist"); 631 Config cfg( name+".playlist");
623 readConfig(cfg); 632 readConfig(cfg);
633
624 tabWidget->setCurrentPage(0); 634 tabWidget->setCurrentPage(0);
635
625 Config config( "MediaPlayer" ); 636 Config config( "MediaPlayer" );
626 config.writeEntry("CurrentPlaylist", name); 637 config.writeEntry("CurrentPlaylist", name);
627 d->selectedFiles->first(); 638// d->selectedFiles->first();
628 } 639 }
640
629} 641}
630 642
631void PlayListWidget::setPlaylist( bool shown ) { 643void PlayListWidget::setPlaylist( bool shown ) {
632 if ( shown ) 644 if ( shown )
633 d->playListFrame->show(); 645 d->playListFrame->show();
634 else 646 else
635 d->playListFrame->hide(); 647 d->playListFrame->hide();
636} 648}
637 649
638void PlayListWidget::setView( char view ) { 650void PlayListWidget::setView( char view ) {
639 if ( view == 'l' ) 651 if ( view == 'l' )
640 showMaximized(); 652 showMaximized();
@@ -774,36 +786,38 @@ void PlayListWidget::btnPlay(bool b) {
774 case 0: 786 case 0:
775 { 787 {
776 mediaPlayerState->setPlaying(b); 788 mediaPlayerState->setPlaying(b);
777 } 789 }
778 break; 790 break;
779 case 1: 791 case 1:
780 { 792 {
781 addToSelection( audioView->selectedItem() ); 793 addToSelection( audioView->selectedItem() );
782 mediaPlayerState->setPlaying(b); 794 mediaPlayerState->setPlaying(b);
783// qApp->processEvents(); 795// qApp->processEvents();
784 d->selectedFiles->removeSelected( ); 796 d->selectedFiles->removeSelected( );
785 tabWidget->setCurrentPage(1); 797 tabWidget->setCurrentPage(1);
786 d->selectedFiles->unSelect(); 798 audioView->clearSelection();
799// d->selectedFiles->unSelect();
787// mediaPlayerState->setPlaying(FALSE); 800// mediaPlayerState->setPlaying(FALSE);
788 } 801 }
789 break; 802 break;
790 case 2: 803 case 2:
791 { 804 {
792 addToSelection( videoView->selectedItem() ); 805 addToSelection( videoView->selectedItem() );
793 mediaPlayerState->setPlaying(b); 806 mediaPlayerState->setPlaying(b);
794 qApp->processEvents(); 807 qApp->processEvents();
795 d->selectedFiles->removeSelected( ); 808 d->selectedFiles->removeSelected( );
796 tabWidget->setCurrentPage(2); 809 tabWidget->setCurrentPage(2);
797 d->selectedFiles->unSelect(); 810 videoView->clearSelection();
811// d->selectedFiles->unSelect();
798// mediaPlayerState->setPlaying(FALSE); 812// mediaPlayerState->setPlaying(FALSE);
799 } 813 }
800 break; 814 break;
801 }; 815 };
802} 816}
803 817
804void PlayListWidget::deletePlaylist() { 818void PlayListWidget::deletePlaylist() {
805 switch( QMessageBox::information( this, (tr("Remove Playlist?")), 819 switch( QMessageBox::information( this, (tr("Remove Playlist?")),
806 (tr("You really want to delete\nthis playlist?")), 820 (tr("You really want to delete\nthis playlist?")),
807 (tr("Yes")), (tr("No")), 0 )){ 821 (tr("Yes")), (tr("No")), 0 )){
808 case 0: // Yes clicked, 822 case 0: // Yes clicked,
809 QFile().remove(playLists->selected()->file()); 823 QFile().remove(playLists->selected()->file());
@@ -896,46 +910,58 @@ void PlayListWidget::listDelete() {
896// prop.showMaximized(); 910// prop.showMaximized();
897// prop.exec(); 911// prop.exec();
898// } 912// }
899// } 913// }
900 } 914 }
901 break; 915 break;
902 }; 916 };
903} 917}
904 918
905void PlayListWidget::populateAudioView() { 919void PlayListWidget::populateAudioView() {
906// if(files) 920// if(files)
907// files.~DocLnkSet(); 921// files.~DocLnkSet();
922 StorageInfo storageInfo;
923 const QList<FileSystem> &fs = storageInfo.fileSystems();
924
908 Global::findDocuments(&files, "audio/*"); 925 Global::findDocuments(&files, "audio/*");
909 QListIterator<DocLnk> dit( files.children() ); 926 QListIterator<DocLnk> dit( files.children() );
927 QListIterator<FileSystem> it ( fs );
910 audioView->clear(); 928 audioView->clear();
911 QString storage; 929 QString storage;
912 for ( ; dit.current(); ++dit ) { 930 for ( ; dit.current(); ++dit ) {
931 for( ; it.current(); ++it ){
932 const QString name = (*it)->name();
933 const QString path = (*it)->path();
934 if(dit.current()->file().find(path) != -1 ) storage=name;
935 }
936
913 QListViewItem * newItem; 937 QListViewItem * newItem;
914 if(dit.current()->file().find("/mnt/cf") != -1 ) storage=tr("CF");
915 else if(dit.current()->file().find("/mnt/hda") != -1 ) storage=tr("CF");
916 else if(dit.current()->file().find("/mnt/card") != -1 ) storage=tr("SD");
917 else storage=tr("RAM");
918 if ( QFile( dit.current()->file()).exists() ) { 938 if ( QFile( dit.current()->file()).exists() ) {
919 newItem= /*(void)*/ new QListViewItem( audioView, dit.current()->name(), QString::number( QFile( dit.current()->file()).size() ), storage); 939 newItem= /*(void)*/ new QListViewItem( audioView, dit.current()->name(), QString::number( QFile( dit.current()->file()).size() ), storage);
920 newItem->setPixmap(0, Resource::loadPixmap( "mpegplayer/musicfile" )); 940 newItem->setPixmap(0, Resource::loadPixmap( "mpegplayer/musicfile" ));
921 } 941 }
922 } 942 }
923} 943}
924 944
925void PlayListWidget::populateVideoView() { 945void PlayListWidget::populateVideoView() {
946 StorageInfo storageInfo;
947 const QList<FileSystem> &fs = storageInfo.fileSystems();
948
926 Global::findDocuments(&vFiles, "video/*"); 949 Global::findDocuments(&vFiles, "video/*");
927 QListIterator<DocLnk> Vdit( vFiles.children() ); 950 QListIterator<DocLnk> Vdit( vFiles.children() );
951 QListIterator<FileSystem> it ( fs );
928 videoView->clear(); 952 videoView->clear();
929 QString storage; 953 QString storage;
930 for ( ; Vdit.current(); ++Vdit ) { 954 for ( ; Vdit.current(); ++Vdit ) {
931 if( Vdit.current()->file().find("/mnt/cf") != -1 ) storage=tr("CF"); 955 for( ; it.current(); ++it ){
932 else if( Vdit.current()->file().find("/mnt/hda") != -1 ) storage=tr("CF"); 956 const QString name = (*it)->name();
933 else if( Vdit.current()->file().find("/mnt/card") != -1 ) storage=tr("SD"); 957 const QString path = (*it)->path();
934 else storage=tr("RAM"); 958 if( Vdit.current()->file().find(path) != -1 ) storage=name;
959 }
960
935 QListViewItem * newItem; 961 QListViewItem * newItem;
936 if ( QFile( Vdit.current()->file()).exists() ) { 962 if ( QFile( Vdit.current()->file()).exists() ) {
937 newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(), QString::number( QFile( Vdit.current()->file()).size() ), storage); 963 newItem= /*(void)*/ new QListViewItem( videoView, Vdit.current()->name(), QString::number( QFile( Vdit.current()->file()).size() ), storage);
938 newItem->setPixmap(0, Resource::loadPixmap( "mpegplayer/videofile" )); 964 newItem->setPixmap(0, Resource::loadPixmap( "mpegplayer/videofile" ));
939 } 965 }
940 } 966 }
941} 967}