summaryrefslogtreecommitdiff
path: root/noncore/multimedia
authorsimon <simon>2002-12-09 09:47:04 (UTC)
committer simon <simon>2002-12-09 09:47:04 (UTC)
commit7ccd9b65ab621dbf8bf79c053141af81fb39ca4b (patch) (unidiff)
treef0f06b67b5f041cf51eb4eb9e3e407e543f3d556 /noncore/multimedia
parent88882051547c9c62f47fb83d87f1341ebccf99a7 (diff)
downloadopie-7ccd9b65ab621dbf8bf79c053141af81fb39ca4b.zip
opie-7ccd9b65ab621dbf8bf79c053141af81fb39ca4b.tar.gz
opie-7ccd9b65ab621dbf8bf79c053141af81fb39ca4b.tar.bz2
- replaced currentFileListView method with a variable
Diffstat (limited to 'noncore/multimedia') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/multimedia/opieplayer2/playlistwidget.cpp26
-rw-r--r--noncore/multimedia/opieplayer2/playlistwidget.h3
2 files changed, 12 insertions, 17 deletions
diff --git a/noncore/multimedia/opieplayer2/playlistwidget.cpp b/noncore/multimedia/opieplayer2/playlistwidget.cpp
index b78ce24..889667c 100644
--- a/noncore/multimedia/opieplayer2/playlistwidget.cpp
+++ b/noncore/multimedia/opieplayer2/playlistwidget.cpp
@@ -35,49 +35,50 @@
35#include <qpe/qpeapplication.h> 35#include <qpe/qpeapplication.h>
36#include <qpe/storage.h> 36#include <qpe/storage.h>
37#include <qpe/mimetype.h> 37#include <qpe/mimetype.h>
38#include <qpe/global.h> 38#include <qpe/global.h>
39#include <qpe/resource.h> 39#include <qpe/resource.h>
40 40
41#include <qdatetime.h> 41#include <qdatetime.h>
42#include <qdir.h> 42#include <qdir.h>
43#include <qmessagebox.h> 43#include <qmessagebox.h>
44#include <qregexp.h> 44#include <qregexp.h>
45#include <qtextstream.h> 45#include <qtextstream.h>
46 46
47#include "playlistselection.h" 47#include "playlistselection.h"
48#include "playlistwidget.h" 48#include "playlistwidget.h"
49#include "mediaplayerstate.h" 49#include "mediaplayerstate.h"
50#include "inputDialog.h" 50#include "inputDialog.h"
51#include "om3u.h" 51#include "om3u.h"
52#include "playlistfileview.h" 52#include "playlistfileview.h"
53 53
54//only needed for the random play 54//only needed for the random play
55#include <stdlib.h> 55#include <stdlib.h>
56#include <assert.h> 56#include <assert.h>
57 57
58PlayListWidget::PlayListWidget( MediaPlayerState &mediaPlayerState, QWidget* parent, const char* name ) 58PlayListWidget::PlayListWidget( MediaPlayerState &mediaPlayerState, QWidget* parent, const char* name )
59 : PlayListWidgetGui( mediaPlayerState, parent, name ) { 59 : PlayListWidgetGui( mediaPlayerState, parent, name ) , currentFileListView( 0 )
60{
60 61
61 d->tbAddToList = new ToolButton( bar, tr( "Add to Playlist" ), 62 d->tbAddToList = new ToolButton( bar, tr( "Add to Playlist" ),
62 "opieplayer2/add_to_playlist", 63 "opieplayer2/add_to_playlist",
63 this , SLOT(addSelected() ) ); 64 this , SLOT(addSelected() ) );
64 d->tbRemoveFromList = new ToolButton( bar, tr( "Remove from Playlist" ), 65 d->tbRemoveFromList = new ToolButton( bar, tr( "Remove from Playlist" ),
65 "opieplayer2/remove_from_playlist", 66 "opieplayer2/remove_from_playlist",
66 this , SLOT(removeSelected() ) ); 67 this , SLOT(removeSelected() ) );
67 d->tbPlay = new ToolButton( bar, tr( "Play" ), "opieplayer2/play", 68 d->tbPlay = new ToolButton( bar, tr( "Play" ), "opieplayer2/play",
68 this , SLOT( btnPlay( bool) ), TRUE ); 69 this , SLOT( btnPlay( bool) ), TRUE );
69 d->tbShuffle = new ToolButton( bar, tr( "Randomize" ),"opieplayer2/shuffle", 70 d->tbShuffle = new ToolButton( bar, tr( "Randomize" ),"opieplayer2/shuffle",
70 &mediaPlayerState, SLOT( setShuffled( bool ) ), TRUE ); 71 &mediaPlayerState, SLOT( setShuffled( bool ) ), TRUE );
71 d->tbLoop = new ToolButton( bar, tr( "Loop" ), "opieplayer2/loop", 72 d->tbLoop = new ToolButton( bar, tr( "Loop" ), "opieplayer2/loop",
72 &mediaPlayerState, SLOT( setLooping( bool ) ), TRUE ); 73 &mediaPlayerState, SLOT( setLooping( bool ) ), TRUE );
73 74
74 (void)new MenuItem( pmPlayList, tr( "Clear List" ), this, SLOT( clearList() ) ); 75 (void)new MenuItem( pmPlayList, tr( "Clear List" ), this, SLOT( clearList() ) );
75 (void)new MenuItem( pmPlayList, tr( "Add all audio files" ), 76 (void)new MenuItem( pmPlayList, tr( "Add all audio files" ),
76 this, SLOT( addAllMusicToList() ) ); 77 this, SLOT( addAllMusicToList() ) );
77 (void)new MenuItem( pmPlayList, tr( "Add all video files" ), 78 (void)new MenuItem( pmPlayList, tr( "Add all video files" ),
78 this, SLOT( addAllVideoToList() ) ); 79 this, SLOT( addAllVideoToList() ) );
79 (void)new MenuItem( pmPlayList, tr( "Add all files" ), 80 (void)new MenuItem( pmPlayList, tr( "Add all files" ),
80 this, SLOT( addAllToList() ) ); 81 this, SLOT( addAllToList() ) );
81 pmPlayList->insertSeparator(-1); 82 pmPlayList->insertSeparator(-1);
82// (void)new MenuItem( pmPlayList, tr( "Save PlayList" ), 83// (void)new MenuItem( pmPlayList, tr( "Save PlayList" ),
83// this, SLOT( saveList() ) ); 84// this, SLOT( saveList() ) );
@@ -456,62 +457,61 @@ bool PlayListWidget::last() {
456} 457}
457 458
458 459
459 void PlayListWidget::saveList() { 460 void PlayListWidget::saveList() {
460 writem3u(); 461 writem3u();
461 } 462 }
462 463
463 464
464void PlayListWidget::loadList( const DocLnk & lnk) { 465void PlayListWidget::loadList( const DocLnk & lnk) {
465 QString name = lnk.name(); 466 QString name = lnk.name();
466 // qDebug("<<<<<<<<<<<<<<<<<<<<<<<<currentList is "+name); 467 // qDebug("<<<<<<<<<<<<<<<<<<<<<<<<currentList is "+name);
467 468
468 if( name.length()>0) { 469 if( name.length()>0) {
469 setCaption("OpiePlayer: "+name); 470 setCaption("OpiePlayer: "+name);
470// qDebug("<<<<<<<<<<<<load list "+ lnk.file()); 471// qDebug("<<<<<<<<<<<<load list "+ lnk.file());
471 clearList(); 472 clearList();
472 readm3u(lnk.file()); 473 readm3u(lnk.file());
473 tabWidget->setCurrentPage(0); 474 tabWidget->setCurrentPage(0);
474 } 475 }
475} 476}
476 477
477void PlayListWidget::addSelected() { 478void PlayListWidget::addSelected() {
478 assert( inFileListMode() ); 479 assert( inFileListMode() );
479 480
480 QListView *fileListView = currentFileListView(); 481 QListViewItemIterator it( currentFileListView );
481 QListViewItemIterator it( fileListView );
482 for ( ; it.current(); ++it ) 482 for ( ; it.current(); ++it )
483 if ( it.current()->isSelected() ) { 483 if ( it.current()->isSelected() ) {
484 QString filename = it.current()->text(3); 484 QString filename = it.current()->text(3);
485 485
486 DocLnk lnk; 486 DocLnk lnk;
487 lnk.setName( QFileInfo( filename ).baseName() ); //sets name 487 lnk.setName( QFileInfo( filename ).baseName() ); //sets name
488 lnk.setFile( filename ); //sets file name 488 lnk.setFile( filename ); //sets file name
489 489
490 d->selectedFiles->addToSelection( lnk ); 490 d->selectedFiles->addToSelection( lnk );
491 } 491 }
492 492
493 fileListView->clearSelection(); 493 currentFileListView->clearSelection();
494 494
495 tabWidget->setCurrentPage( 0 ); 495 tabWidget->setCurrentPage( 0 );
496 writeCurrentM3u(); 496 writeCurrentM3u();
497} 497}
498 498
499 499
500void PlayListWidget::removeSelected() { 500void PlayListWidget::removeSelected() {
501 d->selectedFiles->removeSelected( ); 501 d->selectedFiles->removeSelected( );
502 writeCurrentM3u(); 502 writeCurrentM3u();
503} 503}
504 504
505 505
506void PlayListWidget::playIt( QListViewItem *it) { 506void PlayListWidget::playIt( QListViewItem *it) {
507 if(!it) return; 507 if(!it) return;
508 mediaPlayerState.setPlaying(FALSE); 508 mediaPlayerState.setPlaying(FALSE);
509 mediaPlayerState.setPlaying(TRUE); 509 mediaPlayerState.setPlaying(TRUE);
510 d->selectedFiles->unSelect(); 510 d->selectedFiles->unSelect();
511} 511}
512 512
513 513
514void PlayListWidget::addToSelection( QListViewItem *it) { 514void PlayListWidget::addToSelection( QListViewItem *it) {
515 d->setDocumentUsed = FALSE; 515 d->setDocumentUsed = FALSE;
516 516
517 if(it) { 517 if(it) {
@@ -521,141 +521,137 @@ void PlayListWidget::addToSelection( QListViewItem *it) {
521 DocLnk lnk; 521 DocLnk lnk;
522 QString filename; 522 QString filename;
523 523
524 filename=it->text(3); 524 filename=it->text(3);
525 lnk.setName( QFileInfo(filename).baseName() ); //sets name 525 lnk.setName( QFileInfo(filename).baseName() ); //sets name
526 lnk.setFile( filename ); //sets file name 526 lnk.setFile( filename ); //sets file name
527 d->selectedFiles->addToSelection( lnk); 527 d->selectedFiles->addToSelection( lnk);
528 528
529 writeCurrentM3u(); 529 writeCurrentM3u();
530 tabWidget->setCurrentPage(0); 530 tabWidget->setCurrentPage(0);
531 531
532 } 532 }
533} 533}
534 534
535 535
536void PlayListWidget::tabChanged(QWidget *) { 536void PlayListWidget::tabChanged(QWidget *) {
537 537
538 d->tbPlay->setEnabled( true ); 538 d->tbPlay->setEnabled( true );
539 539
540 disconnect( audioView, SIGNAL( itemsSelected( bool ) ), 540 disconnect( audioView, SIGNAL( itemsSelected( bool ) ),
541 d->tbPlay, SLOT( setEnabled( bool ) ) ); 541 d->tbPlay, SLOT( setEnabled( bool ) ) );
542 disconnect( videoView, SIGNAL( itemsSelected( bool ) ), 542 disconnect( videoView, SIGNAL( itemsSelected( bool ) ),
543 d->tbPlay, SLOT( setEnabled( bool ) ) ); 543 d->tbPlay, SLOT( setEnabled( bool ) ) );
544 544
545 currentFileListView = 0;
546
545 switch ( currentTab() ) { 547 switch ( currentTab() ) {
546 case CurrentPlayList: 548 case CurrentPlayList:
547 { 549 {
548 if( !tbDeletePlaylist->isHidden() ) { 550 if( !tbDeletePlaylist->isHidden() ) {
549 tbDeletePlaylist->hide(); 551 tbDeletePlaylist->hide();
550 } 552 }
551 d->tbRemoveFromList->setEnabled(TRUE); 553 d->tbRemoveFromList->setEnabled(TRUE);
552 d->tbAddToList->setEnabled(FALSE); 554 d->tbAddToList->setEnabled(FALSE);
553 555
554 d->tbPlay->setEnabled( !d->selectedFiles->isEmpty() ); 556 d->tbPlay->setEnabled( !d->selectedFiles->isEmpty() );
555 } 557 }
556 break; 558 break;
557 case AudioFiles: 559 case AudioFiles:
558 { 560 {
559 audioView->populateView(); 561 audioView->populateView();
560 562
561 if( !tbDeletePlaylist->isHidden() ) { 563 if( !tbDeletePlaylist->isHidden() ) {
562 tbDeletePlaylist->hide(); 564 tbDeletePlaylist->hide();
563 } 565 }
564 d->tbRemoveFromList->setEnabled(FALSE); 566 d->tbRemoveFromList->setEnabled(FALSE);
565 d->tbAddToList->setEnabled(TRUE); 567 d->tbAddToList->setEnabled(TRUE);
566 568
567 connect( audioView, SIGNAL( itemsSelected( bool ) ), 569 connect( audioView, SIGNAL( itemsSelected( bool ) ),
568 d->tbPlay, SLOT( setEnabled( bool ) ) ); 570 d->tbPlay, SLOT( setEnabled( bool ) ) );
569 571
570 d->tbPlay->setEnabled( audioView->hasSelection() ); 572 d->tbPlay->setEnabled( audioView->hasSelection() );
573
574 currentFileListView = audioView;
571 } 575 }
572 break; 576 break;
573 case VideoFiles: 577 case VideoFiles:
574 { 578 {
575 videoView->populateView(); 579 videoView->populateView();
576 if( !tbDeletePlaylist->isHidden() ) { 580 if( !tbDeletePlaylist->isHidden() ) {
577 tbDeletePlaylist->hide(); 581 tbDeletePlaylist->hide();
578 } 582 }
579 d->tbRemoveFromList->setEnabled(FALSE); 583 d->tbRemoveFromList->setEnabled(FALSE);
580 d->tbAddToList->setEnabled(TRUE); 584 d->tbAddToList->setEnabled(TRUE);
581 585
582 connect( videoView, SIGNAL( itemsSelected( bool ) ), 586 connect( videoView, SIGNAL( itemsSelected( bool ) ),
583 d->tbPlay, SLOT( setEnabled( bool ) ) ); 587 d->tbPlay, SLOT( setEnabled( bool ) ) );
584 588
585 d->tbPlay->setEnabled( videoView->hasSelection() ); 589 d->tbPlay->setEnabled( videoView->hasSelection() );
590
591 currentFileListView = videoView;
586 } 592 }
587 break; 593 break;
588 case PlayLists: 594 case PlayLists:
589 { 595 {
590 if( tbDeletePlaylist->isHidden() ) { 596 if( tbDeletePlaylist->isHidden() ) {
591 tbDeletePlaylist->show(); 597 tbDeletePlaylist->show();
592 } 598 }
593 playLists->reread(); 599 playLists->reread();
594 d->tbAddToList->setEnabled(FALSE); 600 d->tbAddToList->setEnabled(FALSE);
595 601
596 d->tbPlay->setEnabled( false ); 602 d->tbPlay->setEnabled( false );
597 } 603 }
598 break; 604 break;
599 }; 605 };
600} 606}
601 607
602 608
603void PlayListWidget::btnPlay(bool b) { 609void PlayListWidget::btnPlay(bool b) {
604// mediaPlayerState->setPlaying(false); 610// mediaPlayerState->setPlaying(false);
605 mediaPlayerState.setPlaying(b); 611 mediaPlayerState.setPlaying(b);
606 insanityBool=FALSE; 612 insanityBool=FALSE;
607} 613}
608 614
609void PlayListWidget::deletePlaylist() { 615void PlayListWidget::deletePlaylist() {
610 switch( QMessageBox::information( this, (tr("Remove Playlist?")), 616 switch( QMessageBox::information( this, (tr("Remove Playlist?")),
611 (tr("You really want to delete\nthis playlist?")), 617 (tr("You really want to delete\nthis playlist?")),
612 (tr("Yes")), (tr("No")), 0 )){ 618 (tr("Yes")), (tr("No")), 0 )){
613 case 0: // Yes clicked, 619 case 0: // Yes clicked,
614 QFile().remove(playLists->selectedDocument().file()); 620 QFile().remove(playLists->selectedDocument().file());
615 QFile().remove(playLists->selectedDocument().linkFile()); 621 QFile().remove(playLists->selectedDocument().linkFile());
616 playLists->reread(); 622 playLists->reread();
617 break; 623 break;
618 case 1: // Cancel 624 case 1: // Cancel
619 break; 625 break;
620 }; 626 };
621} 627}
622 628
623 629
624void PlayListWidget::playSelected() { 630void PlayListWidget::playSelected() {
625 btnPlay( TRUE); 631 btnPlay( TRUE);
626} 632}
627 633
628QListView *PlayListWidget::currentFileListView() const
629{
630 switch ( currentTab() ) {
631 case AudioFiles: return audioView;
632 case VideoFiles: return videoView;
633 default: assert( false );
634 }
635 return 0;
636}
637
638bool PlayListWidget::inFileListMode() const 634bool PlayListWidget::inFileListMode() const
639{ 635{
640 TabType tab = currentTab(); 636 TabType tab = currentTab();
641 return tab == AudioFiles || tab == VideoFiles; 637 return tab == AudioFiles || tab == VideoFiles;
642} 638}
643 639
644void PlayListWidget::openFile() { 640void PlayListWidget::openFile() {
645 // http://66.28.164.33:2080 641 // http://66.28.164.33:2080
646 // http://somafm.com/star0242.m3u 642 // http://somafm.com/star0242.m3u
647 QString filename, name; 643 QString filename, name;
648 InputDialog *fileDlg; 644 InputDialog *fileDlg;
649 fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0); 645 fileDlg = new InputDialog(this,tr("Open file or URL"),TRUE, 0);
650 fileDlg->exec(); 646 fileDlg->exec();
651 if( fileDlg->result() == 1 ) { 647 if( fileDlg->result() == 1 ) {
652 filename = fileDlg->text(); 648 filename = fileDlg->text();
653 qDebug( "Selected filename is " + filename ); 649 qDebug( "Selected filename is " + filename );
654 // Om3u *m3uList; 650 // Om3u *m3uList;
655 DocLnk lnk; 651 DocLnk lnk;
656 Config cfg( "OpiePlayer" ); 652 Config cfg( "OpiePlayer" );
657 cfg.setGroup("PlayList"); 653 cfg.setGroup("PlayList");
658 654
659 if(filename.left(4) == "http") { 655 if(filename.left(4) == "http") {
660 QString m3uFile, m3uFilePath; 656 QString m3uFile, m3uFilePath;
661 if(filename.find(":",8,TRUE) != -1) { //found a port 657 if(filename.find(":",8,TRUE) != -1) { //found a port
@@ -988,26 +984,26 @@ void PlayListWidget::skinsMenuActivated( int item ) {
988} 984}
989 985
990PlayListWidget::TabType PlayListWidget::currentTab() const 986PlayListWidget::TabType PlayListWidget::currentTab() const
991{ 987{
992 static const TabType indexToTabType[ TabTypeCount ] = 988 static const TabType indexToTabType[ TabTypeCount ] =
993 { CurrentPlayList, AudioFiles, VideoFiles, PlayLists }; 989 { CurrentPlayList, AudioFiles, VideoFiles, PlayLists };
994 990
995 int index = tabWidget->currentPageIndex(); 991 int index = tabWidget->currentPageIndex();
996 assert( index < TabTypeCount && index >= 0 ); 992 assert( index < TabTypeCount && index >= 0 );
997 993
998 return indexToTabType[ index ]; 994 return indexToTabType[ index ];
999} 995}
1000 996
1001PlayListWidget::Entry PlayListWidget::currentEntry() const 997PlayListWidget::Entry PlayListWidget::currentEntry() const
1002{ 998{
1003 if ( currentTab() == CurrentPlayList ) { 999 if ( currentTab() == CurrentPlayList ) {
1004 const DocLnk *lnk = current(); 1000 const DocLnk *lnk = current();
1005 return Entry( lnk->name(), lnk->file() ); 1001 return Entry( lnk->name(), lnk->file() );
1006 } 1002 }
1007 1003
1008 return Entry( currentFileListPathName() ); 1004 return Entry( currentFileListPathName() );
1009} 1005}
1010 1006
1011QString PlayListWidget::currentFileListPathName() const { 1007QString PlayListWidget::currentFileListPathName() const {
1012 return currentFileListView()->currentItem()->text( 3 ); 1008 return currentFileListView->currentItem()->text( 3 );
1013} 1009}
diff --git a/noncore/multimedia/opieplayer2/playlistwidget.h b/noncore/multimedia/opieplayer2/playlistwidget.h
index 5c8f30c..e8bf211 100644
--- a/noncore/multimedia/opieplayer2/playlistwidget.h
+++ b/noncore/multimedia/opieplayer2/playlistwidget.h
@@ -77,63 +77,62 @@ public:
77 void useSelectedDocument(); 77 void useSelectedDocument();
78 TabType currentTab() const; 78 TabType currentTab() const;
79 79
80 Entry currentEntry() const; 80 Entry currentEntry() const;
81 81
82public slots: 82public slots:
83 bool first(); 83 bool first();
84 bool last(); 84 bool last();
85 bool next(); 85 bool next();
86 bool prev(); 86 bool prev();
87 void writeDefaultPlaylist( ); 87 void writeDefaultPlaylist( );
88 QString currentFileListPathName() const; 88 QString currentFileListPathName() const;
89protected: 89protected:
90 void keyReleaseEvent( QKeyEvent *e); 90 void keyReleaseEvent( QKeyEvent *e);
91 91
92signals: 92signals:
93 void skinSelected(); 93 void skinSelected();
94 94
95private: 95private:
96 int defaultSkinIndex; 96 int defaultSkinIndex;
97 void readm3u(const QString &); 97 void readm3u(const QString &);
98 void readPls(const QString &); 98 void readPls(const QString &);
99 void initializeStates(); 99 void initializeStates();
100 100
101 QListView *currentFileListView() const;
102
103 bool inFileListMode() const; 101 bool inFileListMode() const;
104 102
105private slots: 103private slots:
106 void populateSkinsMenu(); 104 void populateSkinsMenu();
107 void skinsMenuActivated(int); 105 void skinsMenuActivated(int);
108 void pmViewActivated(int); 106 void pmViewActivated(int);
109 void writem3u(); 107 void writem3u();
110 void writeCurrentM3u(); 108 void writeCurrentM3u();
111 void openFile(); 109 void openFile();
112 void setDocument( const QString& fileref ); 110 void setDocument( const QString& fileref );
113 void addToSelection( const DocLnk& ); // Add a media file to the playlist 111 void addToSelection( const DocLnk& ); // Add a media file to the playlist
114 void addToSelection( QListViewItem* ); // Add a media file to the playlist 112 void addToSelection( QListViewItem* ); // Add a media file to the playlist
115 void clearList(); 113 void clearList();
116 void addAllToList(); 114 void addAllToList();
117 void addAllMusicToList(); 115 void addAllMusicToList();
118 void addAllVideoToList(); 116 void addAllVideoToList();
119 void saveList(); // Save the playlist 117 void saveList(); // Save the playlist
120 void loadList( const DocLnk &); // Load a playlist 118 void loadList( const DocLnk &); // Load a playlist
121 void playIt( QListViewItem *); 119 void playIt( QListViewItem *);
122 void btnPlay(bool); 120 void btnPlay(bool);
123 void deletePlaylist(); 121 void deletePlaylist();
124 void addSelected(); 122 void addSelected();
125 void removeSelected(); 123 void removeSelected();
126 void tabChanged(QWidget*); 124 void tabChanged(QWidget*);
127 void viewPressed( int, QListViewItem *, const QPoint&, int); 125 void viewPressed( int, QListViewItem *, const QPoint&, int);
128 void playlistViewPressed( int, QListViewItem *, const QPoint&, int); 126 void playlistViewPressed( int, QListViewItem *, const QPoint&, int);
129 void playSelected(); 127 void playSelected();
130 128
131private: 129private:
132 bool fromSetDocument; 130 bool fromSetDocument;
133 bool insanityBool; 131 bool insanityBool;
134 QString setDocFileRef, currentPlayList; 132 QString setDocFileRef, currentPlayList;
135 int selected; 133 int selected;
134 QListView *currentFileListView;
136}; 135};
137 136
138#endif // PLAY_LIST_WIDGET_H 137#endif // PLAY_LIST_WIDGET_H
139 138