X-Git-Url: https://vcs.maemo.org/git/?a=blobdiff_plain;f=groove.cpp;h=7d0df67158ac74d31721b72423ca5be1f1cee645;hb=4adbefb36e52cb33564e704d8ea6a49425db8caf;hp=3bd7b6a73d2bf9daebe83be9ac637872e6cc9906;hpb=b7de84bdd106700e348771f0b897240161cb55ec;p=groove diff --git a/groove.cpp b/groove.cpp index 3bd7b6a..7d0df67 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) @@ -14,9 +17,11 @@ groove::groove(QWidget *parent) : QVBoxLayout *vlayout = new QVBoxLayout(); QHBoxLayout *bottomLayout = new QHBoxLayout(); button = new QPushButton("Search"); - QPushButton *dButton = new QPushButton("Play"); - QPushButton *stopButton = new QPushButton("Stop"); - QPushButton *moreButton = new QPushButton(); + 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(); @@ -25,6 +30,13 @@ groove::groove(QWidget *parent) : pushMenu->addAction("Song:"); //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()); @@ -42,22 +54,33 @@ groove::groove(QWidget *parent) : resultView->setColumnHidden(2,true); resultView->setColumnHidden(3,true); resultView->setAutoScroll(false); + resultView->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff); /*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->addLayout(bottomLayout); + //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 @@ -65,10 +88,35 @@ 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(dButton,SIGNAL(clicked()),this, SLOT(addSongPlaylist())); connect(stopButton,SIGNAL(clicked()),this,SLOT(stop())); - connect(gs,SIGNAL(sKeyFound()),this,SLOT(startP())); + 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())); + connect(bBar,SIGNAL(nextB()),player,SLOT(playNext())); + connect(bBar,SIGNAL(pause()),this,SLOT(stop())); + connect(bBar,SIGNAL(back()),player,SLOT(back())); + bBar->setPlaybackProgress(80,100); + } +void groove::performSearch(QString s) +{ + qDebug() << s; + resultView->setModel(gs->getSongModel(s)); +} + void groove::search() { if(!lineEdit->text().isEmpty()) @@ -114,6 +162,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); @@ -123,21 +178,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->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 }