connected vlc to play audio

This commit is contained in:
Anika Raemer 2018-11-27 22:05:56 +01:00
parent 20094b0cf2
commit 71f7652a8a
4 changed files with 44 additions and 19 deletions

View file

@ -2,19 +2,20 @@
#include <QDebug>
#include <models/MusicModel.h>
#include <VLCQtCore/Audio.h>
#include <VLCQtCore/MediaPlayer.h>
MusicController::MusicController(QObject *parent) : QObject(parent)
{
mVlc = new VlcInstance(VlcCommon::args(), this);
mModel = new MusicModel(mVlc, this);
mPlayer = new VlcMediaPlayer(mVlc);
connect(mPlayer, &VlcMediaPlayer::error, [this](){
qDebug() << "playerError";
});
mPlayer = new VlcMediaListPlayer(mVlc);
connect(mModel, &MusicModel::navigateTo, this, &MusicController::navigateTo);
connect(mModel, &MusicModel::play, mPlayer, &VlcMediaListPlayer::play);
connect(mModel, &MusicModel::pause, mPlayer->mediaPlayer(), &VlcMediaPlayer::pause);
connect(mModel, &MusicModel::navigateTo, [this](NavigationItemModel*){
if(mModel->isPlaying()) mModel->playPause();
});
}
MusicController::~MusicController()
@ -25,7 +26,8 @@ MusicController::~MusicController()
void MusicController::initPlayer(NavigationItemModel *item)
{
mModel->init(item);
mPlayer->open(mModel->getMedia());
mPlayer->stop();
mPlayer->setMediaList(mModel->getMedia());
}
void MusicController::setContext(QQmlContext *context)

View file

@ -7,7 +7,7 @@
#include <VLCQtCore/Common.h>
#include <VLCQtCore/Instance.h>
#include <VLCQtCore/MediaPlayer.h>
#include <VLCQtCore/MediaListPlayer.h>
class MusicModel;
@ -34,7 +34,7 @@ private:
MusicModel* mModel;
VlcInstance* mVlc;
VlcMediaPlayer* mPlayer;
VlcMediaListPlayer* mPlayer;
};
#endif // MUSICCONTROLLER_H

View file

@ -1,15 +1,18 @@
#include "MusicModel.h"
#include <QDir>
#include <QDebug>
#include <VLCQtCore/Media.h>
MusicModel::MusicModel(VlcInstance* instance, QObject *parent) : QObject(parent),
mVlc(instance)
mVlc(instance)//, mMedia(new VlcMediaList(instance))
{
}
MusicModel::~MusicModel()
{
if(mMedia)
mMedia->deleteLater();
//if(mMedia)
// mMedia->deleteLater();
}
void MusicModel::init(NavigationItemModel *item)
@ -17,9 +20,23 @@ void MusicModel::init(NavigationItemModel *item)
mCurrentItem = item;
emit currentItemChanged();
if(mMedia)
delete mMedia;
mMedia = new VlcMedia(mCurrentItem->getPath()+"/Pink Panther.mp3", true, mVlc);
/*for(int i = 0; i < mMedia->count(); i++){
mMedia->removeMedia(i);
}
qDebug() << mMedia->count();
*/
if(mMedia) delete mMedia;
mMedia = new VlcMediaList(mVlc);
auto dir = QDir(mCurrentItem->getPath());
if(!dir.exists()) return;
auto fileNames = dir.entryList(QDir::Files);
for(auto file:fileNames){
if(file.endsWith(".flac") || file.endsWith(".mp3")){
mMedia->addMedia(new VlcMedia(dir.filePath(file), true, mVlc));
}
}
}
void MusicModel::navigateBack()
@ -30,6 +47,10 @@ void MusicModel::navigateBack()
void MusicModel::playPause()
{
mIsPlaying = !mIsPlaying;
if(mIsPlaying)
emit play();
else
emit pause();
}
NavigationItemModel *MusicModel::getCurrentItem()
@ -37,7 +58,7 @@ NavigationItemModel *MusicModel::getCurrentItem()
return mCurrentItem;
}
VlcMedia *MusicModel::getMedia()
VlcMediaList *MusicModel::getMedia()
{
return mMedia;
}

View file

@ -4,7 +4,7 @@
#include <QObject>
#include <models/NavigationItemModel.h>
#include <VLCQtCore/Media.h>
#include <VLCQtCore/MediaList.h>
class MusicModel : public QObject
{
@ -15,6 +15,8 @@ class MusicModel : public QObject
signals:
void navigateTo(NavigationItemModel *item);
void currentItemChanged();
void play();
void pause();
public:
MusicModel(VlcInstance* instance, QObject *parent = Q_NULLPTR);
@ -27,14 +29,14 @@ public:
NavigationItemModel *getCurrentItem();
VlcMedia *getMedia();
VlcMediaList *getMedia();
bool isPlaying();
private:
bool mIsPlaying = false;
NavigationItemModel* mCurrentItem = Q_NULLPTR;
VlcMedia* mMedia = Q_NULLPTR;
VlcMediaList* mMedia = Q_NULLPTR;
VlcInstance* mVlc;
};