author | harlekin <harlekin> | 2002-08-21 20:42:09 (UTC) |
---|---|---|
committer | harlekin <harlekin> | 2002-08-21 20:42:09 (UTC) |
commit | 462117a0f60287d5309932937c24da3ab1292476 (patch) (side-by-side diff) | |
tree | 1877224879c5d953b257712171637de87a2966dc | |
parent | 10739e8b7d203e56ef30011770f6d12d8b0bb270 (diff) | |
download | opie-462117a0f60287d5309932937c24da3ab1292476.zip opie-462117a0f60287d5309932937c24da3ab1292476.tar.gz opie-462117a0f60287d5309932937c24da3ab1292476.tar.bz2 |
started taking playlistwidget apart, also made gui a bit more beautiful
-rw-r--r-- | noncore/multimedia/opieplayer2/opieplayer2.pro | 11 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/playlistwidget.cpp | 455 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/playlistwidget.h | 69 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/playlistwidgetgui.cpp | 207 | ||||
-rw-r--r-- | noncore/multimedia/opieplayer2/playlistwidgetgui.h | 126 |
5 files changed, 507 insertions, 361 deletions
diff --git a/noncore/multimedia/opieplayer2/opieplayer2.pro b/noncore/multimedia/opieplayer2/opieplayer2.pro index 3a47c06..a83a624 100644 --- a/noncore/multimedia/opieplayer2/opieplayer2.pro +++ b/noncore/multimedia/opieplayer2/opieplayer2.pro @@ -1,4 +1,4 @@ TEMPLATE = app -CONFIG = qt warn_on release -#CONFIG = qt warn_on debug +#CONFIG = qt warn_on release +CONFIG = qt warn_on debug DESTDIR = $(OPIEDIR)/bin @@ -6,3 +6,3 @@ HEADERS = playlistselection.h mediaplayerstate.h xinecontrol.h mediadetect.h\ videowidget.h audiowidget.h playlistwidget.h mediaplayer.h inputDialog.h \ - frame.h lib.h xinevideowidget.h volumecontrol.h\ + frame.h lib.h xinevideowidget.h volumecontrol.h playlistwidgetgui.h\ alphablend.h yuv2rgb.h @@ -12,2 +12,3 @@ SOURCES = main.cpp \ frame.cpp lib.cpp nullvideo.c xinevideowidget.cpp volumecontrol.cpp\ + playlistwidgetgui.cpp\ alphablend.c yuv2rgb.c yuv2rgb_arm.c yuv2rgb_arm4l.S @@ -20,4 +21,4 @@ OBJECTS_DIR=qpeobj -INCLUDEPATH += $(OPIEDIR)/include -DEPENDPATH += $(OPIEDIR)/include +#INCLUDEPATH += $(OPIEDIR)/include +#DEPENDPATH += $(OPIEDIR)/include diff --git a/noncore/multimedia/opieplayer2/playlistwidget.cpp b/noncore/multimedia/opieplayer2/playlistwidget.cpp index 098322b..6c7f6ba 100644 --- a/noncore/multimedia/opieplayer2/playlistwidget.cpp +++ b/noncore/multimedia/opieplayer2/playlistwidget.cpp @@ -1,33 +1,43 @@ +/* + This file is part of the Opie Project + + Copyright (c) 2002 Max Reiss <harlekin@handhelds.org> + Copyright (c) 2002 L. Potter <ljp@llornkcor.com> + Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> + =. + .=l. + .>+-= + _;:, .> :=|. This program is free software; you can +.> <`_, > . <= redistribute it and/or modify it under +:`=1 )Y*s>-.-- : the terms of the GNU General Public +.="- .-=="i, .._ License as published by the Free Software + - . .-<_> .<> Foundation; either version 2 of the License, + ._= =} : or (at your option) any later version. + .%`+i> _;_. + .i_,=:_. -<s. This program is distributed in the hope that + + . -:. = it will be useful, but WITHOUT ANY WARRANTY; + : .. .:, . . . without even the implied warranty of + =_ + =;=|` MERCHANTABILITY or FITNESS FOR A + _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU +..}^=.= = ; Library General Public License for more +++= -. .` .: details. + : = ...= . :.=- + -. .:....=;==+<; You should have received a copy of the GNU + -_. . . )=. = Library General Public License along with + -- :-=` this library; see the file COPYING.LIB. + If not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. + +*/ -#define QTOPIA_INTERNAL_FSLP -#include <qpe/qpemenubar.h> #include <qpe/qpetoolbar.h> -#include <qpe/fileselector.h> #include <qpe/qpeapplication.h> -#include <qpe/lnkproperties.h> #include <qpe/storage.h> #include <qpe/mimetype.h> - -#include <qpe/applnk.h> -#include <qpopupmenu.h> -#include <qpe/config.h> #include <qpe/global.h> #include <qpe/resource.h> -#include <qaction.h> -#include <qcursor.h> -#include <qimage.h> -#include <qfile.h> + #include <qdir.h> -#include <qlayout.h> -#include <qlabel.h> -#include <qlist.h> -#include <qlistbox.h> -#include <qmainwindow.h> #include <qmessagebox.h> -#include <qtoolbutton.h> -#include <qtabwidget.h> -#include <qlistview.h> -#include <qpoint.h> -#include <qlineedit.h> -#include <qpushbutton.h> #include <qregexp.h> @@ -35,3 +45,2 @@ - #include "playlistselection.h" @@ -39,6 +48,7 @@ #include "mediaplayerstate.h" - #include "inputDialog.h" +//only needed for the random play #include <stdlib.h> + #include "audiowidget.h" @@ -46,6 +56,2 @@ -#define BUTTONS_ON_TOOLBAR -#define SIDE_BUTTONS -#define CAN_SAVE_LOAD_PLAYLISTS - extern MediaPlayerState *mediaPlayerState; @@ -53,70 +59,4 @@ extern MediaPlayerState *mediaPlayerState; -class PlayListWidgetPrivate { -public: - QToolButton *tbPlay, *tbFull, *tbLoop, *tbScale, *tbShuffle, *tbAddToList, *tbRemoveFromList, *tbMoveUp, *tbMoveDown, *tbRemove; - QFrame *playListFrame; - FileSelector *files; - PlayListSelection *selectedFiles; - bool setDocumentUsed; - DocLnk *current; -}; - - -class ToolButton : public QToolButton { -public: - ToolButton( QWidget *parent, const char *name, const QString& icon, QObject *handler, const QString& slot, bool t = FALSE ) - : QToolButton( parent, name ) { - setTextLabel( name ); - setPixmap( Resource::loadPixmap( icon ) ); - setAutoRaise( TRUE ); - setFocusPolicy( QWidget::NoFocus ); - setToggleButton( t ); - connect( this, t ? SIGNAL( toggled(bool) ) : SIGNAL( clicked() ), handler, slot ); - QPEMenuToolFocusManager::manager()->addWidget( this ); - } -}; - - -class MenuItem : public QAction { -public: - MenuItem( QWidget *parent, const QString& text, QObject *handler, const QString& slot ) - : QAction( text, QString::null, 0, 0 ) { - connect( this, SIGNAL( activated() ), handler, slot ); - addTo( parent ); - } -}; - - PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl ) - : QMainWindow( parent, name, fl ) { - - d = new PlayListWidgetPrivate; - d->setDocumentUsed = FALSE; - d->current = NULL; - fromSetDocument = FALSE; - insanityBool=FALSE; - audioScan = FALSE; - videoScan = FALSE; - - setBackgroundMode( PaletteButton ); - -// setCaption( tr("OpiePlayer") ); -// setIcon( Resource::loadPixmap( "opieplayer2/MPEGPlayer" ) ); - - setToolBarsMovable( FALSE ); - - // Create Toolbar - QPEToolBar *toolbar = new QPEToolBar( this ); - toolbar->setHorizontalStretchable( TRUE ); - - // Create Menubar - QPEMenuBar *menu = new QPEMenuBar( toolbar ); - menu->setMargin( 0 ); - - QPEToolBar *bar = new QPEToolBar( this ); - bar->setLabel( tr( "Play Operations" ) ); - - tbDeletePlaylist = new QPushButton( Resource::loadIconSet("trash"),"",bar,"close"); - tbDeletePlaylist->setFlat(TRUE); - tbDeletePlaylist->setFixedSize(20,20); + : PlayListWidgetGui( parent, name, fl ) { @@ -132,6 +72,3 @@ PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl ) mediaPlayerState, SLOT(setLooping(bool)), TRUE ); - tbDeletePlaylist->hide(); - QPopupMenu *pmPlayList = new QPopupMenu( this ); - menu->insertItem( tr( "File" ), pmPlayList ); (void)new MenuItem( pmPlayList, tr( "Clear List" ), this, SLOT( clearList() ) ); @@ -149,6 +86,2 @@ PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl ) - pmView = new QPopupMenu( this ); - menu->insertItem( tr( "View" ), pmView ); - pmView->isCheckable(); - pmView->insertItem( Resource::loadPixmap("fullscreen") , tr( "Full Screen"), mediaPlayerState, SLOT( toggleFullscreen() ) ); @@ -160,41 +93,2 @@ PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl ) - // pmView->insertItem( Resource::loadPixmap("opieplayer/scale") , tr( "Scale"), mediaPlayerState, SLOT(toggleScaled() ) ); - - pmView->insertSeparator(-1); - - skinsMenu = new QPopupMenu( this ); - pmView->insertItem( tr( "Skins" ), skinsMenu ); - skinsMenu->isCheckable(); - populateSkinsMenu(); - - QVBox *vbox5 = new QVBox( this ); vbox5->setBackgroundMode( PaletteButton ); - QVBox *vbox4 = new QVBox( vbox5 ); vbox4->setBackgroundMode( PaletteButton ); - - QHBox *hbox6 = new QHBox( vbox4 ); hbox6->setBackgroundMode( PaletteButton ); - - tabWidget = new QTabWidget( hbox6, "tabWidget" ); - // tabWidget->setTabShape(QTabWidget::Triangular); - - QWidget *pTab; - pTab = new QWidget( tabWidget, "pTab" ); - tabWidget->insertTab( pTab,"Playlist"); - - - QGridLayout *Playout = new QGridLayout( pTab ); - Playout->setSpacing( 2); - Playout->setMargin( 2); - - // Add the playlist area - - QVBox *vbox3 = new QVBox( pTab ); vbox3->setBackgroundMode( PaletteButton ); - d->playListFrame = vbox3; - - QHBox *hbox2 = new QHBox( vbox3 ); hbox2->setBackgroundMode( PaletteButton ); - - d->selectedFiles = new PlayListSelection( hbox2); - QVBox *vbox1 = new QVBox( hbox2 ); vbox1->setBackgroundMode( PaletteButton ); - - QPEApplication::setStylusOperation( d->selectedFiles->viewport(),QPEApplication::RightOnHold); - - QVBox *stretch1 = new QVBox( vbox1 ); stretch1->setBackgroundMode( PaletteButton ); // add stretch (void)new ToolButton( vbox1, tr( "Move Up" ), "opieplayer2/up", d->selectedFiles, SLOT(moveSelectedUp()) ); @@ -202,78 +96,7 @@ PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl ) (void)new ToolButton( vbox1, tr( "Move Down" ), "opieplayer2/down", d->selectedFiles, SLOT(moveSelectedDown()) ); - QVBox *stretch2 = new QVBox( vbox1 ); stretch2->setBackgroundMode( PaletteButton ); // add stretch - - - Playout->addMultiCellWidget( vbox3, 0, 0, 0, 1 ); - - QWidget *aTab; - aTab = new QWidget( tabWidget, "aTab" ); - - QGridLayout *Alayout = new QGridLayout( aTab ); - Alayout->setSpacing( 2); - Alayout->setMargin( 2); - - audioView = new QListView( aTab, "Audioview" ); - audioView->addColumn( tr("Title"),140); - audioView->addColumn(tr("Size"), -1); - audioView->addColumn(tr("Media"),-1); - audioView->setColumnAlignment(1, Qt::AlignRight); - audioView->setColumnAlignment(2, Qt::AlignRight); - audioView->setAllColumnsShowFocus(TRUE); - audioView->setSorting(0,TRUE); - - audioView->setMultiSelection( TRUE ); - audioView->setSelectionMode( QListView::Extended); - - Alayout->addMultiCellWidget( audioView, 0, 0, 0, 1 ); - - tabWidget->insertTab(aTab,tr("Audio")); - - QPEApplication::setStylusOperation( audioView->viewport(),QPEApplication::RightOnHold); - - QWidget *vTab; - vTab = new QWidget( tabWidget, "vTab" ); - - QGridLayout *Vlayout = new QGridLayout( vTab ); - Vlayout->setSpacing( 2); - Vlayout->setMargin( 2); - - videoView = new QListView( vTab, "Videoview" ); - - videoView->addColumn(tr("Title"),140); - videoView->addColumn(tr("Size"),-1); - videoView->addColumn(tr("Media"),-1); - videoView->setColumnAlignment(1, Qt::AlignRight); - videoView->setColumnAlignment(2, Qt::AlignRight); - videoView->setAllColumnsShowFocus(TRUE); - videoView->setSorting(0,TRUE); - - videoView->setMultiSelection( TRUE ); - videoView->setSelectionMode( QListView::Extended); - - Vlayout->addMultiCellWidget( videoView, 0, 0, 0, 1 ); - - QPEApplication::setStylusOperation( videoView->viewport(),QPEApplication::RightOnHold); - - tabWidget->insertTab( vTab,tr("Video")); - - //playlists list - QWidget *LTab; - LTab = new QWidget( tabWidget, "LTab" ); - QGridLayout *Llayout = new QGridLayout( LTab ); - Llayout->setSpacing( 2); - Llayout->setMargin( 2); - - playLists = new FileSelector( "playlist/plain", LTab, "fileselector" , FALSE, FALSE); //buggy - Llayout->addMultiCellWidget( playLists, 0, 0, 0, 1 ); - - tabWidget->insertTab(LTab,tr("Lists")); + QVBox *stretch2 = new QVBox( vbox1 ); connect(tbDeletePlaylist,(SIGNAL(released())),SLOT( deletePlaylist())); - connect( pmView, SIGNAL( activated(int)), this, SLOT( pmViewActivated(int) ) ); - connect( skinsMenu, SIGNAL( activated(int)), this, SLOT(skinsMenuActivated(int) ) ); - - // connect( scaleButton, SIGNAL(activated()), mediaPlayerState, SLOT(toggleScaled() ) ); - connect( d->selectedFiles, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), @@ -298,4 +121,2 @@ PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl ) - setCentralWidget( vbox5 ); - readConfig( cfg ); @@ -305,2 +126,4 @@ PlayListWidget::PlayListWidget( QWidget* parent, const char* name, WFlags fl ) + // see which skins are installed + populateSkinsMenu(); initializeStates(); @@ -313,3 +136,2 @@ PlayListWidget::~PlayListWidget() { // writeConfig( cfg ); - if ( d->current ) { @@ -322,3 +144,2 @@ PlayListWidget::~PlayListWidget() { void PlayListWidget::initializeStates() { - d->tbPlay->setOn( mediaPlayerState->playing() ); @@ -350,3 +171,2 @@ void PlayListWidget::readConfig( Config& cfg ) { void PlayListWidget::writeConfig( Config& cfg ) const { - d->selectedFiles->writeCurrent( cfg); @@ -402,2 +222,34 @@ void PlayListWidget::clearList() { +void PlayListWidget::viewPressed( int mouse, QListViewItem *, const QPoint& , int) { + switch (mouse) { + case 1: + break; + case 2: + { + QPopupMenu m; + m.insertItem( tr( "Play" ), this, SLOT( playSelected() )); + m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() )); + m.exec( QCursor::pos() ); + } + break; + } +} + + +void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *, const QPoint& , int ) { + switch (mouse) { + case 1: + break; + case 2: + { + QPopupMenu m; + m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() )); + m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() )); + m.exec( QCursor::pos() ); + } + break; + } +} + + void PlayListWidget::addAllToList() { @@ -426,6 +278,8 @@ void PlayListWidget::addAllVideoToList() { QListIterator<DocLnk> dit( vFiles.children() ); - for ( ; dit.current(); ++dit ) - if(QFileInfo( dit.current()->file()).exists()) + for ( ; dit.current(); ++dit ) { + if( QFileInfo( dit.current()->file() ).exists() ) { d->selectedFiles->addToSelection( **dit ); } + } +} @@ -433,3 +287,3 @@ void PlayListWidget::addAllVideoToList() { void PlayListWidget::setDocument(const QString& fileref) { - qDebug(fileref); + //qDebug( fileref ); fromSetDocument = TRUE; @@ -461,11 +315,2 @@ void PlayListWidget::setDocument(const QString& fileref) { -void PlayListWidget::setActiveWindow() { -// qDebug("SETTING active window"); - // When we get raised we need to ensure that it switches views - char origView = mediaPlayerState->view(); - mediaPlayerState->setView( 'l' ); // invalidate - mediaPlayerState->setView( origView ); // now switch back -} - - void PlayListWidget::useSelectedDocument() { @@ -476,3 +321,2 @@ void PlayListWidget::useSelectedDocument() { const DocLnk *PlayListWidget::current() { // this is fugly - switch (tabWidget->currentPageIndex()) { @@ -518,2 +362,3 @@ const DocLnk *PlayListWidget::current() { // this is fugly + bool PlayListWidget::prev() { @@ -528,4 +373,5 @@ bool PlayListWidget::prev() { if ( cur == current() ) - if ( !d->selectedFiles->next() ) + if ( !d->selectedFiles->next() ) { d->selectedFiles->first(); + } return TRUE; @@ -632,5 +478,5 @@ void PlayListWidget::loadList( const DocLnk & lnk) { } - } + void PlayListWidget::setPlaylist( bool shown ) { @@ -643,8 +489,2 @@ void PlayListWidget::setPlaylist( bool shown ) { -void PlayListWidget::setView( char view ) { - if ( view == 'l' ) - showMaximized(); - else - hide(); -} @@ -699,2 +539,3 @@ void PlayListWidget::addSelected() { + void PlayListWidget::removeSelected() { @@ -703,2 +544,3 @@ void PlayListWidget::removeSelected() { + void PlayListWidget::playIt( QListViewItem *it) { @@ -710,2 +552,3 @@ void PlayListWidget::playIt( QListViewItem *it) { + void PlayListWidget::addToSelection( QListViewItem *it) { @@ -742,2 +585,3 @@ void PlayListWidget::addToSelection( QListViewItem *it) { + void PlayListWidget::tabChanged(QWidget *) { @@ -747,4 +591,5 @@ void PlayListWidget::tabChanged(QWidget *) { { - if( !tbDeletePlaylist->isHidden()) + if( !tbDeletePlaylist->isHidden() ) { tbDeletePlaylist->hide(); + } d->tbRemoveFromList->setEnabled(TRUE); @@ -758,4 +603,5 @@ void PlayListWidget::tabChanged(QWidget *) { - if( !tbDeletePlaylist->isHidden()) + if( !tbDeletePlaylist->isHidden() ) { tbDeletePlaylist->hide(); + } d->tbRemoveFromList->setEnabled(FALSE); @@ -768,4 +614,5 @@ void PlayListWidget::tabChanged(QWidget *) { populateVideoView(); - if( !tbDeletePlaylist->isHidden()) + if( !tbDeletePlaylist->isHidden() ) { tbDeletePlaylist->hide(); + } d->tbRemoveFromList->setEnabled(FALSE); @@ -776,4 +623,5 @@ void PlayListWidget::tabChanged(QWidget *) { { - if( tbDeletePlaylist->isHidden()) + if( tbDeletePlaylist->isHidden() ) { tbDeletePlaylist->show(); + } playLists->reread(); @@ -784,4 +632,4 @@ void PlayListWidget::tabChanged(QWidget *) { -void PlayListWidget::btnPlay(bool b) { +void PlayListWidget::btnPlay(bool b) { // mediaPlayerState->setPlaying(b); @@ -832,15 +680,2 @@ void PlayListWidget::deletePlaylist() { -void PlayListWidget::viewPressed( int mouse, QListViewItem *, const QPoint& , int) { - switch (mouse) { - case 1: - break; - case 2:{ - QPopupMenu m; - m.insertItem( tr( "Play" ), this, SLOT( playSelected() )); - m.insertItem( tr( "Add to Playlist" ), this, SLOT( addSelected() )); - m.exec( QCursor::pos() ); - } - break; - }; -} @@ -850,18 +685,2 @@ void PlayListWidget::playSelected() { -void PlayListWidget::playlistViewPressed( int mouse, QListViewItem *, const QPoint& , int ) { - switch (mouse) { - case 1: - - break; - case 2: - { - QPopupMenu m; - m.insertItem( tr( "Play Selected" ), this, SLOT( playSelected() )); - m.insertItem( tr( "Remove" ), this, SLOT( removeSelected() )); - m.exec( QCursor::pos() ); - } - break; - }; -} - @@ -890,3 +709,2 @@ void PlayListWidget::scanForVideo() { void PlayListWidget::populateAudioView() { - audioView->clear(); @@ -894,3 +712,5 @@ void PlayListWidget::populateAudioView() { const QList<FileSystem> &fs = storageInfo.fileSystems(); - if(!audioScan) scanForAudio(); + if(!audioScan) { + scanForAudio(); + } @@ -904,3 +724,5 @@ void PlayListWidget::populateAudioView() { const QString path = (*it)->path(); - if(dit.current()->file().find(path) != -1 ) storage=name; + if(dit.current()->file().find(path) != -1 ) { + storage = name; + } } @@ -915,5 +737,5 @@ void PlayListWidget::populateAudioView() { } - } + void PlayListWidget::populateVideoView() { @@ -923,3 +745,5 @@ void PlayListWidget::populateVideoView() { - if(!videoScan ) scanForVideo(); + if(!videoScan ) { + scanForVideo(); + } @@ -933,3 +757,5 @@ void PlayListWidget::populateVideoView() { const QString path = (*it)->path(); - if( Vdit.current()->file().find(path) != -1 ) storage=name; + if( Vdit.current()->file().find(path) != -1 ) { + storage=name; + } } @@ -945,2 +771,3 @@ void PlayListWidget::populateVideoView() { + void PlayListWidget::openFile() { @@ -961,3 +788,2 @@ void PlayListWidget::openFile() { DocLnk lnk; - lnk.setName(filename); //sets file name @@ -980,4 +806,3 @@ void PlayListWidget::openFile() { -void PlayListWidget::keyReleaseEvent( QKeyEvent *e) -{ +void PlayListWidget::keyReleaseEvent( QKeyEvent *e ) { switch ( e->key() ) { @@ -1039,29 +864,3 @@ void PlayListWidget::keyReleaseEvent( QKeyEvent *e) -void PlayListWidget::keyPressEvent( QKeyEvent *) -{ - // qDebug("Key press"); - // switch ( e->key() ) { - // ////////////////////////////// Zaurus keys - // case Key_A: //add to playlist - // qDebug("Add"); - // addSelected(); - // break; - // case Key_R: //remove from playlist - // removeSelected(); - // break; - // case Key_P: //play - // qDebug("Play"); - // playSelected(); - // break; - // case Key_Space: - // qDebug("Play"); - // playSelected(); - // break; - // } -} - - - void PlayListWidget::readm3u(const QString &filename) { - qDebug("m3u filename is "+filename); @@ -1080,3 +879,2 @@ void PlayListWidget::readm3u(const QString &filename) { s=s.right(s.length()-2); - // if(QFile(s).exists()) { DocLnk lnk( s ); @@ -1091,3 +889,2 @@ void PlayListWidget::readm3u(const QString &filename) { d->selectedFiles->addToSelection( lnk); - // } } else { // is url @@ -1120,3 +917,2 @@ void PlayListWidget::readm3u(const QString &filename) { void PlayListWidget::writem3u() { - InputDialog *fileDlg; @@ -1133,2 +929,4 @@ void PlayListWidget::writem3u() { // qDebug(d->selectedFiles->current()->file()); + + // so maybe we should do some net checking to ,-) list += d->selectedFiles->current()->file()+"\n"; @@ -1138,7 +936,8 @@ void PlayListWidget::writem3u() { qDebug(list); - if(filename.left(1) != "/") + if( filename.left( 1) != "/" ) { filename=QPEApplication::documentDir()+"/"+filename; - if(filename.right(3) != "m3u") + } + if( filename.right( 3 ) != "m3u" ) { filename=filename+".m3u"; - + } QFile f(filename); @@ -1148,3 +947,5 @@ void PlayListWidget::writem3u() { } - if(fileDlg) delete fileDlg; + if( fileDlg ) { + delete fileDlg; + } } @@ -1176,6 +977,7 @@ void PlayListWidget::readPls(const QString &filename) { QString name = f.baseName(); - if(name.left(4)=="http") + if( name.left( 4 ) == "http" ) { name = s.right( s.length() - 7); - else + } else { name=s; + } name = name.right(name.length()-name.findRev("\\",-1,TRUE)-1); @@ -1185,4 +987,5 @@ void PlayListWidget::readPls(const QString &filename) { else { //if its a url - if( name.right(1).find('/') == -1) + if( name.right( 1 ).find( '/' ) == -1) { s+="/"; + } lnk.setFile( s); @@ -1191,3 +994,3 @@ void PlayListWidget::readPls(const QString &filename) { - qDebug("DocLnk add "+name); + //qDebug("DocLnk add "+name); d->selectedFiles->addToSelection( lnk); @@ -1204,3 +1007,2 @@ void PlayListWidget::pmViewActivated(int index) { { - mediaPlayerState->toggleFullscreen(); @@ -1210,3 +1012,2 @@ void PlayListWidget::pmViewActivated(int index) { cfg.writeEntry("FullScreen", b); - } @@ -1233,9 +1034,11 @@ void PlayListWidget::populateSkinsMenu() { qDebug( fi->fileName()); - if( skinName != "." && skinName != ".." && skinName !="CVS") + if( skinName != "." && skinName != ".." && skinName !="CVS" ) { item = skinsMenu->insertItem( fi->fileName()); - if( skinName == "default") + } + if( skinName == "default" ) { defaultSkinIndex = item; - if( skinName == skin) + } + if( skinName == skin ) { skinsMenu->setItemChecked( item, TRUE); - + } ++it; diff --git a/noncore/multimedia/opieplayer2/playlistwidget.h b/noncore/multimedia/opieplayer2/playlistwidget.h index 8710a99..2742252 100644 --- a/noncore/multimedia/opieplayer2/playlistwidget.h +++ b/noncore/multimedia/opieplayer2/playlistwidget.h @@ -1 +1,33 @@ +/* + This file is part of the Opie Project + + Copyright (c) 2002 Max Reiss <harlekin@handhelds.org> + Copyright (c) 2002 L. Potter <ljp@llornkcor.com> + Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> + =. + .=l. + .>+-= + _;:, .> :=|. This program is free software; you can +.> <`_, > . <= redistribute it and/or modify it under +:`=1 )Y*s>-.-- : the terms of the GNU General Public +.="- .-=="i, .._ License as published by the Free Software + - . .-<_> .<> Foundation; either version 2 of the License, + ._= =} : or (at your option) any later version. + .%`+i> _;_. + .i_,=:_. -<s. This program is distributed in the hope that + + . -:. = it will be useful, but WITHOUT ANY WARRANTY; + : .. .:, . . . without even the implied warranty of + =_ + =;=|` MERCHANTABILITY or FITNESS FOR A + _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU +..}^=.= = ; Library General Public License for more +++= -. .` .: details. + : = ...= . :.=- + -. .:....=;==+<; You should have received a copy of the GNU + -_. . . )=. = Library General Public License along with + -- :-=` this library; see the file COPYING.LIB. + If not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. + +*/ @@ -11,6 +43,6 @@ -/* #include <qtimer.h> */ +#include "playlistwidgetgui.h" -class PlayListWidgetPrivate; +//class PlayListWidgetPrivate; class Config; @@ -22,3 +54,3 @@ class QLabel; -class PlayListWidget : public QMainWindow { +class PlayListWidget : public PlayListWidgetGui { Q_OBJECT @@ -27,10 +59,4 @@ public: ~PlayListWidget(); - QTabWidget * tabWidget; -// MenuItem *fullScreenButton, *scaleButton; -// QAction *fullScreenButton, *scaleButton; DocLnkSet files; DocLnkSet vFiles; - QListView *audioView, *videoView, *playlistView; - QLabel *libString; - QPopupMenu *pmView ; bool fromSetDocument; @@ -41,6 +67,4 @@ public: void useSelectedDocument(); -/* QTimer * menuTimer; */ - FileSelector* playLists; - QPushButton *tbDeletePlaylist; int selected; + public slots: @@ -51,12 +75,8 @@ public slots: void writeConfig( Config& cfg ) const; -/* void setFullScreen(); */ -/* void setScaled(); */ + protected: -/* void contentsMousePressEvent( QMouseEvent * e ); */ -/* void contentsMouseReleaseEvent( QMouseEvent * e ); */ void keyReleaseEvent( QKeyEvent *e); -void keyPressEvent( QKeyEvent *e); + private: int defaultSkinIndex; - QPopupMenu *skinsMenu; bool audioScan, videoScan; @@ -64,8 +84,7 @@ private: void readPls(const QString &); - void initializeStates(); void readConfig( Config& cfg ); - PlayListWidgetPrivate *d; // Private implementation data void populateAudioView(); void populateVideoView(); + private slots: @@ -81,5 +100,3 @@ private slots: void addToSelection( QListViewItem* ); // Add a media file to the playlist - void setActiveWindow(); // need to handle this to show the right view void setPlaylist( bool ); // Show/Hide the playlist - void setView( char ); void clearList(); @@ -91,3 +108,2 @@ private slots: void playIt( QListViewItem *); - void btnPlay(bool); @@ -100,11 +116,4 @@ private slots: void playSelected(); - -protected slots: -/* void cancelMenuTimer(); */ -/* void showFileMenu(); */ - - }; - #endif // PLAY_LIST_WIDGET_H diff --git a/noncore/multimedia/opieplayer2/playlistwidgetgui.cpp b/noncore/multimedia/opieplayer2/playlistwidgetgui.cpp new file mode 100644 index 0000000..6ecd016 --- a/dev/null +++ b/noncore/multimedia/opieplayer2/playlistwidgetgui.cpp @@ -0,0 +1,207 @@ +/* + This file is part of the Opie Project + + Copyright (c) 2002 Max Reiss <harlekin@handhelds.org> + Copyright (c) 2002 L. Potter <ljp@llornkcor.com> + Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> + =. + .=l. + .>+-= + _;:, .> :=|. This program is free software; you can +.> <`_, > . <= redistribute it and/or modify it under +:`=1 )Y*s>-.-- : the terms of the GNU General Public +.="- .-=="i, .._ License as published by the Free Software + - . .-<_> .<> Foundation; either version 2 of the License, + ._= =} : or (at your option) any later version. + .%`+i> _;_. + .i_,=:_. -<s. This program is distributed in the hope that + + . -:. = it will be useful, but WITHOUT ANY WARRANTY; + : .. .:, . . . without even the implied warranty of + =_ + =;=|` MERCHANTABILITY or FITNESS FOR A + _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU +..}^=.= = ; Library General Public License for more +++= -. .` .: details. + : = ...= . :.=- + -. .:....=;==+<; You should have received a copy of the GNU + -_. . . )=. = Library General Public License along with + -- :-=` this library; see the file COPYING.LIB. + If not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. + +*/ + +#include <qpe/qpemenubar.h> +#include <qpe/qpetoolbar.h> +#include <qpe/fileselector.h> +#include <qpe/qpeapplication.h> +#include <qpe/storage.h> +#include <qpe/mimetype.h> +#include <qpe/config.h> +#include <qpe/global.h> +#include <qpe/resource.h> + +#include <qpopupmenu.h> +#include <qaction.h> +#include <qcursor.h> +#include <qdir.h> +#include <qlayout.h> + +#include "playlistselection.h" +#include "playlistwidget.h" +#include "mediaplayerstate.h" +#include "inputDialog.h" + +//only needed for the random play +#include <stdlib.h> + +#include "audiowidget.h" +#include "videowidget.h" +#include "mediaplayerstate.h" + +extern MediaPlayerState *mediaPlayerState; + +PlayListWidgetGui::PlayListWidgetGui( QWidget* parent, const char* name, WFlags fl ) + : QMainWindow( parent, name, fl ) { + + d = new PlayListWidgetPrivate; + d->setDocumentUsed = FALSE; + d->current = NULL; + + setBackgroundMode( PaletteButton ); + setToolBarsMovable( FALSE ); + + // Create Toolbar + QPEToolBar *toolbar = new QPEToolBar( this ); + toolbar->setHorizontalStretchable( TRUE ); + + // Create Menubar + QPEMenuBar *menu = new QPEMenuBar( toolbar ); + menu->setMargin( 0 ); + + bar = new QPEToolBar( this ); + bar->setLabel( tr( "Play Operations" ) ); + + tbDeletePlaylist = new QPushButton( Resource::loadIconSet( "trash" ), "", bar, "close" ); + tbDeletePlaylist->setFlat( TRUE ); + tbDeletePlaylist->setFixedSize( 20, 20 ); + + tbDeletePlaylist->hide(); + + pmPlayList = new QPopupMenu( this ); + menu->insertItem( tr( "File" ), pmPlayList ); + + pmView = new QPopupMenu( this ); + menu->insertItem( tr( "View" ), pmView ); + pmView->isCheckable(); + + skinsMenu = new QPopupMenu( this ); + pmView->insertItem( tr( "Skins" ), skinsMenu ); + skinsMenu->isCheckable(); + + vbox5 = new QVBox( this ); + QVBox *vbox4 = new QVBox( vbox5 ); + QHBox *hbox6 = new QHBox( vbox4 ); + + tabWidget = new QTabWidget( hbox6, "tabWidget" ); + + QWidget *pTab; + pTab = new QWidget( tabWidget, "pTab" ); + tabWidget->insertTab( pTab,"Playlist"); + + QGridLayout *Playout = new QGridLayout( pTab ); + Playout->setSpacing( 2); + Playout->setMargin( 2); + + // Add the playlist area + QVBox *vbox3 = new QVBox( pTab ); + d->playListFrame = vbox3; + + QHBox *hbox2 = new QHBox( vbox3 ); + d->selectedFiles = new PlayListSelection( hbox2 ); + + vbox1 = new QVBox( hbox2 ); + QPEApplication::setStylusOperation( d->selectedFiles->viewport(), QPEApplication::RightOnHold ); + QVBox *stretch1 = new QVBox( vbox1 ); // add stretch + + Playout->addMultiCellWidget( vbox3, 0, 0, 0, 1 ); + + QWidget *aTab; + aTab = new QWidget( tabWidget, "aTab" ); + + QGridLayout *Alayout = new QGridLayout( aTab ); + Alayout->setSpacing( 2 ); + Alayout->setMargin( 2 ); + audioView = new QListView( aTab, "Audioview" ); + audioView->addColumn( tr( "Title" ), 140 ); + audioView->addColumn( tr( "Size" ), -1 ); + audioView->addColumn( tr( "Media" ), -1 ); + audioView->setColumnAlignment( 1, Qt::AlignRight ); + audioView->setColumnAlignment( 2, Qt::AlignRight ); + audioView->setAllColumnsShowFocus( TRUE ); + audioView->setSorting( 0, TRUE ); + audioView->setMultiSelection( TRUE ); + audioView->setSelectionMode( QListView::Extended ); + Alayout->addMultiCellWidget( audioView, 0, 0, 0, 1 ); + tabWidget->insertTab( aTab, tr( "Audio" ) ); + + QPEApplication::setStylusOperation( audioView->viewport(), QPEApplication::RightOnHold ); + + QWidget *vTab; + vTab = new QWidget( tabWidget, "vTab" ); + + QGridLayout *Vlayout = new QGridLayout( vTab ); + Vlayout->setSpacing( 2 ); + Vlayout->setMargin( 2 ); + videoView = new QListView( vTab, "Videoview" ); + videoView->addColumn( tr( "Title" ), 140); + videoView->addColumn( tr( "Size" ), -1 ); + videoView->addColumn(tr( "Media" ), -1 ); + videoView->setColumnAlignment( 1, Qt::AlignRight ); + videoView->setColumnAlignment( 2, Qt::AlignRight ); + videoView->setAllColumnsShowFocus( TRUE ); + videoView->setSorting( 0, TRUE ); + videoView->setMultiSelection( TRUE ); + videoView->setSelectionMode( QListView::Extended ); + Vlayout->addMultiCellWidget( videoView, 0, 0, 0, 1 ); + + QPEApplication::setStylusOperation( videoView->viewport(), QPEApplication::RightOnHold ); + + tabWidget->insertTab( vTab, tr( "Video" ) ); + + //playlists list + QWidget *LTab; + LTab = new QWidget( tabWidget, "LTab" ); + QGridLayout *Llayout = new QGridLayout( LTab ); + Llayout->setSpacing( 2 ); + Llayout->setMargin( 2 ); + + playLists = new FileSelector( "playlist/plain", LTab, "fileselector" , FALSE, FALSE ); //buggy + Llayout->addMultiCellWidget( playLists, 0, 0, 0, 1 ); + + tabWidget->insertTab( LTab, tr( "Lists" ) ); + + setCentralWidget( vbox5 ); +} + + + +PlayListWidgetGui::~PlayListWidgetGui() { +} + +void PlayListWidgetGui::setView( char view ) { + if ( view == 'l' ) + showMaximized(); + else + hide(); +} + + +void PlayListWidgetGui::setActiveWindow() { + // qDebug("SETTING active window"); + // When we get raised we need to ensure that it switches views + char origView = mediaPlayerState->view(); + mediaPlayerState->setView( 'l' ); // invalidate + mediaPlayerState->setView( origView ); // now switch back +} + diff --git a/noncore/multimedia/opieplayer2/playlistwidgetgui.h b/noncore/multimedia/opieplayer2/playlistwidgetgui.h new file mode 100644 index 0000000..4c8d737 --- a/dev/null +++ b/noncore/multimedia/opieplayer2/playlistwidgetgui.h @@ -0,0 +1,126 @@ +/* + This file is part of the Opie Project + + Copyright (c) 2002 Max Reiss <harlekin@handhelds.org> + Copyright (c) 2002 L. Potter <ljp@llornkcor.com> + Copyright (c) 2002 Holger Freyther <zecke@handhelds.org> + =. + .=l. + .>+-= + _;:, .> :=|. This program is free software; you can +.> <`_, > . <= redistribute it and/or modify it under +:`=1 )Y*s>-.-- : the terms of the GNU General Public +.="- .-=="i, .._ License as published by the Free Software + - . .-<_> .<> Foundation; either version 2 of the License, + ._= =} : or (at your option) any later version. + .%`+i> _;_. + .i_,=:_. -<s. This program is distributed in the hope that + + . -:. = it will be useful, but WITHOUT ANY WARRANTY; + : .. .:, . . . without even the implied warranty of + =_ + =;=|` MERCHANTABILITY or FITNESS FOR A + _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU +..}^=.= = ; Library General Public License for more +++= -. .` .: details. + : = ...= . :.=- + -. .:....=;==+<; You should have received a copy of the GNU + -_. . . )=. = Library General Public License along with + -- :-=` this library; see the file COPYING.LIB. + If not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. + +*/ + +#ifndef PLAY_LIST_WIDGET_GUI_H +#define PLAY_LIST_WIDGET_GUI_H + +#include <qmainwindow.h> +#include <qpe/applnk.h> +#include <qpe/resource.h> +#include <qpe/qpemenubar.h> + +#include <qtabwidget.h> +#include <qpe/fileselector.h> +#include <qpushbutton.h> +#include <qpopupmenu.h> +#include <qaction.h> + + +class PlayListWidgetPrivate; +class PlayListSelection; + +class Config; +class QPEToolBar; +class QListViewItem; +class QListView; +class QPoint; +class QAction; +class QLabel; + +class PlayListWidgetPrivate { +public: + QToolButton *tbPlay, *tbFull, *tbLoop, *tbShuffle, *tbAddToList, *tbRemoveFromList, *tbMoveUp, *tbMoveDown, *tbRemove; + QFrame *playListFrame; + FileSelector *files; + PlayListSelection *selectedFiles; + bool setDocumentUsed; + DocLnk *current; +}; + + +class ToolButton : public QToolButton { +public: + ToolButton( QWidget *parent, const char *name, const QString& icon, QObject *handler, const QString& slot, bool t = FALSE ) + : QToolButton( parent, name ) { + setTextLabel( name ); + setPixmap( Resource::loadPixmap( icon ) ); + setAutoRaise( TRUE ); + setFocusPolicy( QWidget::NoFocus ); + setToggleButton( t ); + connect( this, t ? SIGNAL( toggled(bool) ) : SIGNAL( clicked() ), handler, slot ); + QPEMenuToolFocusManager::manager()->addWidget( this ); + } +}; + + +class MenuItem : public QAction { + +public: + MenuItem( QWidget *parent, const QString& text, QObject *handler, const QString& slot ) + : QAction( text, QString::null, 0, 0 ) { + connect( this, SIGNAL( activated() ), handler, slot ); + addTo( parent ); + } +}; + +class PlayListWidgetGui : public QMainWindow { + Q_OBJECT +public: + PlayListWidgetGui( QWidget* parent=0, const char* name=0, WFlags fl=0 ); + ~PlayListWidgetGui(); + +protected: + QTabWidget * tabWidget; + QListView *audioView, *videoView, *playlistView; + QLabel *libString; + QPopupMenu *pmView ; + bool fromSetDocument; + bool insanityBool; + QString setDocFileRef; + // retrieve the current playlist entry (media file link) + QPushButton *tbDeletePlaylist; + int selected; + QPopupMenu *pmPlayList; + FileSelector* playLists; + QPopupMenu *skinsMenu; + PlayListWidgetPrivate *d; // Private implementation data + QVBox *vbox1; + QVBox *vbox5; + QPEToolBar *bar; + void setActiveWindow(); // need to handle this to show the right view + void setView( char ); + +}; + +#endif + |