X-Git-Url: http://git.maemo.org/git/?p=groove;a=blobdiff_plain;f=groove.cpp;h=f763ae2a56e66e4b29d1b37dbc58b741717d664e;hp=46da9d3bca73c1a2313aeea14bd10f3ff67c160f;hb=59ffc920954b530fd1b867f5edf9d5d910510636;hpb=2023a504eae2a6023e99f4782a501b71455cdc7d diff --git a/groove.cpp b/groove.cpp index 46da9d3..f763ae2 100644 --- a/groove.cpp +++ b/groove.cpp @@ -1,6 +1,9 @@ #include "groove.h" - - +#if defined(Q_WS_MAEMO_5) || defined(Q_WS_HILDON) +#include "qmaemo5rotator.h" +#endif +#include +#include "bottombar.h" groove::groove(QWidget *parent) : QWidget(parent) @@ -12,16 +15,28 @@ groove::groove(QWidget *parent) : player = new sPlayer(); QHBoxLayout *layout = new QHBoxLayout(); QVBoxLayout *vlayout = new QVBoxLayout(); + QHBoxLayout *bottomLayout = new QHBoxLayout(); button = new QPushButton("Search"); - QPushButton *dButton = new QPushButton("Play"); + QPushButton *dButton = new QPushButton("Queue"); + QPushButton *stopButton = new QPushButton("Pause"); + QPushButton *moreButton = new QPushButton("..."); + QPushButton *nextB = new QPushButton("->"); + topBar *ok = new topBar(this); resultView = new QTableView(); QMenu *pushMenu = new QMenu(); //showFullScreen(); lineEdit->insert(""); lineEdit->setDisabled(true); pushMenu->addAction("Song:"); - pushMenu->addAction("Artist:"); - pushMenu->addAction("Album:"); + //pushMenu->addAction("Artist:"); + //pushMenu->addAction("Album:"); + pd = new grooveProgressBar(this); + pd->hide(); + QMenu *moreAction = new QMenu(); + //moreAction->addAction("Playlist"); + connect(moreAction->addAction("Play Now"),SIGNAL(triggered()),this,SLOT(play())); + connect(moreAction->addAction("Show download Progress"),SIGNAL(triggered()),pd,SLOT(show())); + moreButton->setMenu(moreAction); //sMethod->setSizePolicy(QSizePolicy::Fixed,QSizePolicy::Maximum); sMethod->setMaximumWidth(sMethod->sizeHint().rwidth()); @@ -37,17 +52,34 @@ groove::groove(QWidget *parent) : resultView->setSelectionMode(QAbstractItemView::SingleSelection); resultView->setEditTriggers(QAbstractItemView::NoEditTriggers); resultView->setColumnHidden(2,true); + resultView->setColumnHidden(3,true); resultView->setAutoScroll(false); - + /*QPalette pal = resultView->palette(); + pal.setBrush(QPalette::Highlight,QBrush(Qt::transparent,Qt::NoBrush)); + resultView->setPalette(pal);*/ + portrait = false; layout->addWidget(sMethod); +#if defined(Q_WS_MAEMO_5) || defined(Q_WS_HILDON) + rot = new QMaemo5Rotator(QMaemo5Rotator::AutomaticBehavior,this); +#endif + //this->setAttribute(Qt::WA_Maemo5AutoOrientation); layout->addWidget(lineEdit); layout->addWidget(button); - vlayout->addLayout(layout); + vlayout->addWidget(ok); + //vlayout->addLayout(layout); vlayout->addWidget(resultView); - vlayout->addWidget(dButton); + //vlayout->addLayout(bottomLayout); + bottomBar *bBar = new bottomBar(); + vlayout->addWidget(bBar); + vlayout->setSpacing(0); + bottomLayout->addWidget(dButton); + bottomLayout->addWidget(stopButton); + bottomLayout->addWidget(nextB); + bottomLayout->addWidget(moreButton); vlayout->setMenuBar(mBar); + vlayout->setContentsMargins(QMargins()); setLayout(vlayout); - setWindowTitle("GrooveShark"); + setWindowTitle("Groove"); //Create New Grooveshark connection gs = new gscom(); //Connections @@ -55,9 +87,30 @@ groove::groove(QWidget *parent) : connect(gs, SIGNAL(finishedSearch()), this, SLOT(finishedS())); connect(lineEdit,SIGNAL(returnPressed()),this, SLOT(search())); connect(pushMenu,SIGNAL(triggered(QAction*)),this,SLOT(changeS(QAction*))); - connect(dButton,SIGNAL(clicked()),this, SLOT(play())); - connect(gs,SIGNAL(sKeyFound()),this,SLOT(startP())); + connect(dButton,SIGNAL(clicked()),this, SLOT(addSongPlaylist())); + connect(stopButton,SIGNAL(clicked()),this,SLOT(stop())); + connect(moreButton,SIGNAL(clicked()),this,SLOT(moreB())); + //connect(rotator,SIGNAL(orientationChanged(Orientation)),this,SLOT(orientationChanged())); + pl = new playlist(); + pl->setGscom(gs); + player->setPlaylist(pl); + connect(pl,SIGNAL(downloadProgress(int,qint64,qint64)),this,SLOT(progressUpdate(int,qint64,qint64))); + connect(pl,SIGNAL(bufferReady(int)),pd,SLOT(close())); + connect(pl,SIGNAL(freeze(bool)),resultView,SLOT(setDisabled(bool))); + connect(pl,SIGNAL(freeze(bool)),pushMenu,SLOT(setDisabled(bool))); + connect(pl,SIGNAL(freeze(bool)),dButton,SLOT(setDisabled(bool))); + connect(nextB,SIGNAL(clicked()),player,SLOT(playNext())); + connect(ok,SIGNAL(changeTask()),this,SLOT(showOthers())); + connect(ok,SIGNAL(searchRequest(QString)),this,SLOT(performSearch(QString))); + connect(ok,SIGNAL(closeApp()),this,SLOT(close())); + connect(bBar,SIGNAL(addB()),this,SLOT(addSongPlaylist())); +} +void groove::performSearch(QString s) +{ + qDebug() << s; + resultView->setModel(gs->getSongModel(s)); } + void groove::search() { if(!lineEdit->text().isEmpty()) @@ -103,6 +156,13 @@ void groove::changeS( QAction * action) sMethod->setText(action->text()); sMethod->setMaximumWidth(sMethod->sizeHint().rwidth()); } +void groove::showOthers() +{ + QDBusConnection c = QDBusConnection::sessionBus(); + QDBusMessage m = QDBusMessage::createSignal("/", "com.nokia.hildon_desktop", "exit_app_view"); + c.send(m); +} + void groove::play() { QModelIndexList selected = resultView->selectionModel()->selectedRows(0); @@ -112,17 +172,62 @@ void groove::play() if(item == 0) return; //gs->getSong(); - gs->getSong(item->text()); + player->play(pl->addSong(item)); + pd->setMaximum(100); + pd->setValue(0); + pd->show(); } //selected. //if } -void groove::startP() +void groove::addSongPlaylist() { - if(!gs->sku.isValid()) - return; - player->~sPlayer(); - player = new sPlayer(); - player->play(gs->streamID,gs->sku); + QModelIndexList selected = resultView->selectionModel()->selectedRows(0); + if(!selected.isEmpty()) + { + QStandardItem *item = model->item(selected.first().row(),2); + if(item == 0) + return; + //gs->getSong(); + if(pl->currentplaying() == -1) + { + player->play(pl->addSong(item)); + } + else + pl->addSong(item); + pd->setMaximum(100); + pd->setValue(0); + pd->show(); + model->item(selected.first().row(),1)->setText("Added to Playlist");; + } +} +void groove::stop() +{ + player->pause(); +} +void groove::moreB() +{ + qDebug() << "He pressed the button"; +} +void groove::progressUpdate(int p, qint64 d, qint64 t) +{ + //if(!pd->isHidden()) + //{ + + + pd->setMaximum(t); + pd->setValue(d); + //} +} + +void groove::orientationChanged() +{ +#ifdef Q_WS_MAEMO_5 + QRect screenGeometry = QApplication::desktop()->screenGeometry(); + if (screenGeometry.width() > screenGeometry.height()) + portrait = false; + else + portrait = true; +#endif }