欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Qt5+QMediaPlayer實(shí)現(xiàn)音樂(lè)播放器的示例代碼

 更新時(shí)間:2022年12月12日 10:35:35   作者:音視頻開(kāi)發(fā)老舅  
這篇文章主要為大家詳細(xì)介紹了如何利用Qt5和QMediaPlayer實(shí)現(xiàn)簡(jiǎn)易的音樂(lè)播放器,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以參考一下

1、先上效果圖

好了,現(xiàn)在講講我是怎么寫(xiě)的吧,首先最基本的播放歌曲代碼應(yīng)該就是:

好了,現(xiàn)在講講我是怎么寫(xiě)的吧,首先最基本的播放歌曲代碼應(yīng)該就是:

QMediaPlayer  *music = new QMediaPlayer(this);//初始化音樂(lè)
 
QMediaPlaylist *playlist = new QMediaPlaylist(this);//初始化播放列表
 
playlist->setPlaybackMode(QMediaPlaylist::Loop);//設(shè)置播放模式(順序播放,單曲循環(huán),隨機(jī)播放等)
 
playlist->addMedia(QUrl::fromLocalFile("D:/xx/yy/mm.mp3"));//添加歌曲,這里添加的是歌曲的路徑
 
playlist->addMedia(QUrl::fromLocalFile("D:/xx/yy/mm2.mp3"));//添加歌曲,這里添加的是歌曲的路徑
 
music->setPlaylist(playlist);  //設(shè)置播放列表
music->play();//播放歌曲

這樣就能按播放列表來(lái)播放了

然后playlist里面的歌曲是看不到的,就需要一個(gè)列表來(lái)顯示歌曲,我用的是QListWidget,這樣的話(huà),只需要把列表項(xiàng)與playlist里面的歌曲對(duì)應(yīng)上就可以了,然后要保存歌曲,數(shù)據(jù)庫(kù)自然就少不了了,可以用Qt自帶的數(shù)據(jù)庫(kù)QSQLITE,然后創(chuàng)建數(shù)據(jù)庫(kù)和表,寫(xiě)個(gè)函數(shù)

static bool CreatConnection()
{
 
QSqlDatabase db=QSqlDatabase::addDatabase("QSQLITE");//建庫(kù)
db.setDatabaseName("mymusic.db");//給數(shù)據(jù)庫(kù)起名字
if(!db.open())
{
    return false;
}
QSqlQuery query;
 query.exec(QString("create table LocalMusic (id int,MusicName varchar,FileName varchar,     primary key(id,MusicName,FileName))"));//本地音樂(lè)列表數(shù)據(jù),把歌曲名和歌曲路徑給存起來(lái)
return true;
}

在main函數(shù)中先執(zhí)行這個(gè)函數(shù),創(chuàng)建個(gè)數(shù)據(jù)庫(kù)即可。

添加歌曲:

QListWidget *list = new QListWidget(this);
QSqlQuery query;
 
QStringList list=QFileDialog::getOpenFileNames(this,QString::fromLocal8Bit("文
件"),currentFileName[1],QString::fromLocal8Bit("音頻文件(*.mp3)"));//用個(gè)文件登陸框來(lái)選擇.mp3文件,包括多個(gè)文件
 
if(!list.isEmpty()){
 
for(int i=0;i<list.size();i++){
 
QString path=QDir::toNativeSeparators(list.at(i));
 
playlist->addMedia(QUrl::fromLocalFile(path));
QString Name=path.split("\\").last();
QListWidgetItem *item = new QListWidgetItem(QIcon("圖片.png"),Name);
item->setToolTip(Name);
list->addItem(item);
query.exec(QString("insert into values(%1,'%2','%3')").arg(i).arg(Name).arg(path);
 
}
 
}

這樣就列表上就可以顯示歌曲了,并且把歌曲信息保存到數(shù)據(jù)庫(kù)里了,可以在初始化的時(shí)候把數(shù)據(jù)庫(kù)的歌名添加到列表中即list,把歌曲路徑添加到播放列表中即playlist,但是顯示的歌曲如果太多就會(huì)出現(xiàn)滾動(dòng)條,默認(rèn)的滾動(dòng)條貌似不是很好看,可以用一下代碼美化滾動(dòng)條

QString listWidgetStyle = "QScrollBar:vertical"
                                  "{"
                                      "width:8px;"
                                      "background-color:transparent;"
                                      "margin:0px,0px,0px,0px;"
                                     " padding-top:12px;   /*上預(yù)留位置*/"
                                     " padding-bottom:12px;    /*下預(yù)留位置*/"
                                  "}"
 
 
                                 "QScrollBar::handle:vertical"
                                 " {"
                                 "     width:8px;"
                                 "     background-color:rgba(255,255,255,0.2);"
                                 "     border-radius:4px;"
                                 "     min-height:20px;"
                                 " }"
 
 
                                 "QScrollBar::handle:vertical:hover"
                                 "{"
                                 "    width:9px;"
                                 "    background-color:rgba(255,255,255,0.5);"
                                 "    border-radius:4px;"
                                 "    min-height:20;"
                                 "}"
 
                                 "QScrollBar::add-line:vertical"
                                 "{"
                                 "     height:12px;"
                                 "     width:10px;"
                                 "     border-image:url(:/selectfile/scroll/3.png);"
                                 "     subcontrol-position:bottom;"
                                 "}"
 
                                 "QScrollBar::sub-line:vertical"
                                 "{"
                                 "     height:12px;"
                                 "     width:10px;"
                                 "     border-image:url(:/selectfile/scroll/1.png);"
                                 "     subcontrol-position:top;"
                                 "}"
                                 "QScrollBar::add-line:vertical:hover"
                                 "{"
                                 "     height:12px;"
                                 "     width:10px;"
                                 "     border-image:url(:/selectfile/scroll/4.png);"
                                 "     subcontrol-position:bottom;"
                                 " }"
 
 
                                 " QScrollBar::sub-line:vertical:hover"
                                 " {"
                                 "     height:12px;"
                                 "     width:10px;"
                                 "     border-image:url(:/selectfile/scroll/2.png);"
                                 "     subcontrol-position:top;"
                                 " }"
 
                                 " QScrollBar::add-page:vertical,"
                                 "QScrollBar::sub-page:vertical"
                                 " {"
                                 "     background-color:transparent;"
                                 "     border-radius:4px;"
                                 "}";
 
    ui->list->verticalScrollBar()->setStyleSheet(listWidgetStyle);

然后就是得有個(gè)進(jìn)度條,和歌曲時(shí)間

進(jìn)度條,進(jìn)度條自然是用QHorizontalSlider了,主要就是歌曲進(jìn)度得隨著播放進(jìn)度變化,所以可以使用信號(hào)和槽,QMediaPlayer有兩個(gè)信號(hào),QMediaPlayer::positionChanged和QMediaPlayer::durationChanged,分別是當(dāng)前歌曲播放位置的變化,和切換歌曲時(shí)的歌曲長(zhǎng)度,那么就需要寫(xiě)兩個(gè)槽來(lái)接收這兩個(gè)信號(hào)了

//1.
 
void Widget::updatePosition(qint64 position)//接收歌曲位置改變,那么滑塊的位置也要變
{
ui->horizontalSlider->setValue(position);//設(shè)置滑塊位置
}
//2
void Widget::updateDuration(qint64 duration)//更新播放歌曲的時(shí)間
{
 
ui->horizontalSlider->setRange(0,duration);//根據(jù)播放時(shí)長(zhǎng)來(lái)設(shè)置滑塊的范圍
ui->horizontalSlider->setEnabled(duration>0);
 
ui->horizontalSlider->setPageStep(duration/10);//以及每一步的步數(shù)
 
}

然后將他們連接就可以了

connect(music,&QMediaPlayer::positionChanged,this,&Widget::updatePosition);
 
connect(music,&QMediaPlayer::durationChanged,this,&Widget::updateDuration);

還有就是列表選中的歌曲也要跟著playlist的歌曲變化來(lái)變化,需要利用QMediaPlaylist::currentIndexChanged信號(hào),故寫(xiě)槽:

void Widget::updateList(int value){
 
ui->list->item(value)->setSelected(true);
 
}

然后connect(playlist,&QMediaPlaylist::currentIndexChanged,this,&Widget::updateList);

播放暫停的話(huà)就直接點(diǎn)播放個(gè)按鈕就music->play();點(diǎn)個(gè)暫停按鈕就music->puase();

然后還有就是時(shí)間的轉(zhuǎn)換,mp3的時(shí)間是用毫秒來(lái)算的,那么就要變成 分鐘:秒 的格式,可以寫(xiě)個(gè)函數(shù)來(lái)轉(zhuǎn)換:

static QString Time(qint64 time)//轉(zhuǎn)換時(shí)間
{
    qint64 seconds=time/1000;
    const qint64 minutes=seconds/60;
    seconds-=minutes*60;
    return QStringLiteral("%1:%2")
            .arg(minutes, 2, 10, QLatin1Char('0'))
            .arg(seconds, 2, 10, QLatin1Char('0'));
}

然后還有播放模式,其實(shí)就是為playlist設(shè)置播放模式就可以了,比如順序播放playlist->setPlaybackMode(QMediaPlaylist::Loop);

單曲循環(huán)playlist->setPlaybackMode(QMediaPlaylist::CurrentItemInLoop);,隨機(jī)播放playlist->setPlaybackMode(QMediaPlaylist::Random);等

上一首和下一首也很容易

上一首:當(dāng)上一首按鈕點(diǎn)擊執(zhí)行

void Widget::preMusic(){
int row = playlist->mediaCount();//獲取歌曲數(shù)量
int current  = playlist->currentIndex();//獲取當(dāng)前位置
if(--current<0){
current=0;
}
playlist->setCurrentIndex(current);//設(shè)置當(dāng)前音樂(lè)
ui->list->scrollToItem(ui->list->item(current));//滾動(dòng)到當(dāng)前音樂(lè)
music->play();//播放
 
}

下一首:點(diǎn)擊下一首按鈕時(shí)執(zhí)行

void Widget::nextMusic(){
int row = playlist->mediaCount();//獲取歌曲數(shù)量
int current  = playlist->currentIndex();//獲取當(dāng)前位置
if(++current>row){
current=0;
}
playlist->setCurrentIndex(current);//設(shè)置當(dāng)前音樂(lè)
ui->list->scrollToItem(ui->list->item(current));//滾動(dòng)到當(dāng)前音樂(lè)
music->play();//播放
 
}

歌曲定位也很好做,歌曲定位:點(diǎn)擊歌曲定位按鈕執(zhí)行

void getIndex(){
 
ui->list->item(playlist->currentIndex())->setSelected(true);
 
}

基本這樣就可以做出來(lái)了。

到此這篇關(guān)于Qt5+QMediaPlayer實(shí)現(xiàn)音樂(lè)播放器的示例代碼的文章就介紹到這了,更多相關(guān)Qt5 MediaPlayer音樂(lè)播放器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論