Qt5+QMediaPlayer實現(xiàn)音樂播放器的示例代碼
1、先上效果圖



好了,現(xiàn)在講講我是怎么寫的吧,首先最基本的播放歌曲代碼應(yīng)該就是:
好了,現(xiàn)在講講我是怎么寫的吧,首先最基本的播放歌曲代碼應(yīng)該就是:
QMediaPlayer *music = new QMediaPlayer(this);//初始化音樂
QMediaPlaylist *playlist = new QMediaPlaylist(this);//初始化播放列表
playlist->setPlaybackMode(QMediaPlaylist::Loop);//設(shè)置播放模式(順序播放,單曲循環(huán),隨機播放等)
playlist->addMedia(QUrl::fromLocalFile("D:/xx/yy/mm.mp3"));//添加歌曲,這里添加的是歌曲的路徑
playlist->addMedia(QUrl::fromLocalFile("D:/xx/yy/mm2.mp3"));//添加歌曲,這里添加的是歌曲的路徑
music->setPlaylist(playlist); //設(shè)置播放列表
music->play();//播放歌曲
這樣就能按播放列表來播放了
然后playlist里面的歌曲是看不到的,就需要一個列表來顯示歌曲,我用的是QListWidget,這樣的話,只需要把列表項與playlist里面的歌曲對應(yīng)上就可以了,然后要保存歌曲,數(shù)據(jù)庫自然就少不了了,可以用Qt自帶的數(shù)據(jù)庫QSQLITE,然后創(chuàng)建數(shù)據(jù)庫和表,寫個函數(shù)
static bool CreatConnection()
{
QSqlDatabase db=QSqlDatabase::addDatabase("QSQLITE");//建庫
db.setDatabaseName("mymusic.db");//給數(shù)據(jù)庫起名字
if(!db.open())
{
return false;
}
QSqlQuery query;
query.exec(QString("create table LocalMusic (id int,MusicName varchar,FileName varchar, primary key(id,MusicName,FileName))"));//本地音樂列表數(shù)據(jù),把歌曲名和歌曲路徑給存起來
return true;
}
在main函數(shù)中先執(zhí)行這個函數(shù),創(chuàng)建個數(shù)據(jù)庫即可。
添加歌曲:
QListWidget *list = new QListWidget(this);
QSqlQuery query;
QStringList list=QFileDialog::getOpenFileNames(this,QString::fromLocal8Bit("文
件"),currentFileName[1],QString::fromLocal8Bit("音頻文件(*.mp3)"));//用個文件登陸框來選擇.mp3文件,包括多個文件
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ù)庫里了,可以在初始化的時候把數(shù)據(jù)庫的歌名添加到列表中即list,把歌曲路徑添加到播放列表中即playlist,但是顯示的歌曲如果太多就會出現(xiàn)滾動條,默認的滾動條貌似不是很好看,可以用一下代碼美化滾動條
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);然后就是得有個進度條,和歌曲時間
進度條,進度條自然是用QHorizontalSlider了,主要就是歌曲進度得隨著播放進度變化,所以可以使用信號和槽,QMediaPlayer有兩個信號,QMediaPlayer::positionChanged和QMediaPlayer::durationChanged,分別是當前歌曲播放位置的變化,和切換歌曲時的歌曲長度,那么就需要寫兩個槽來接收這兩個信號了
//1.
void Widget::updatePosition(qint64 position)//接收歌曲位置改變,那么滑塊的位置也要變
{
ui->horizontalSlider->setValue(position);//設(shè)置滑塊位置
}
//2
void Widget::updateDuration(qint64 duration)//更新播放歌曲的時間
{
ui->horizontalSlider->setRange(0,duration);//根據(jù)播放時長來設(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的歌曲變化來變化,需要利用QMediaPlaylist::currentIndexChanged信號,故寫槽:
void Widget::updateList(int value){
ui->list->item(value)->setSelected(true);
}
然后connect(playlist,&QMediaPlaylist::currentIndexChanged,this,&Widget::updateList);
播放暫停的話就直接點播放個按鈕就music->play();點個暫停按鈕就music->puase();
然后還有就是時間的轉(zhuǎn)換,mp3的時間是用毫秒來算的,那么就要變成 分鐘:秒 的格式,可以寫個函數(shù)來轉(zhuǎn)換:
static QString Time(qint64 time)//轉(zhuǎn)換時間
{
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'));
}
然后還有播放模式,其實就是為playlist設(shè)置播放模式就可以了,比如順序播放playlist->setPlaybackMode(QMediaPlaylist::Loop);
單曲循環(huán)playlist->setPlaybackMode(QMediaPlaylist::CurrentItemInLoop);,隨機播放playlist->setPlaybackMode(QMediaPlaylist::Random);等
上一首和下一首也很容易
上一首:當上一首按鈕點擊執(zhí)行
void Widget::preMusic(){
int row = playlist->mediaCount();//獲取歌曲數(shù)量
int current = playlist->currentIndex();//獲取當前位置
if(--current<0){
current=0;
}
playlist->setCurrentIndex(current);//設(shè)置當前音樂
ui->list->scrollToItem(ui->list->item(current));//滾動到當前音樂
music->play();//播放
}
下一首:點擊下一首按鈕時執(zhí)行
void Widget::nextMusic(){
int row = playlist->mediaCount();//獲取歌曲數(shù)量
int current = playlist->currentIndex();//獲取當前位置
if(++current>row){
current=0;
}
playlist->setCurrentIndex(current);//設(shè)置當前音樂
ui->list->scrollToItem(ui->list->item(current));//滾動到當前音樂
music->play();//播放
}
歌曲定位也很好做,歌曲定位:點擊歌曲定位按鈕執(zhí)行
void getIndex(){
ui->list->item(playlist->currentIndex())->setSelected(true);
}
基本這樣就可以做出來了。
到此這篇關(guān)于Qt5+QMediaPlayer實現(xiàn)音樂播放器的示例代碼的文章就介紹到這了,更多相關(guān)Qt5 MediaPlayer音樂播放器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實現(xiàn)字符串類型相互轉(zhuǎn)換的代碼示例
在C/C++編程中,字符串是非常基礎(chǔ)且常用的數(shù)據(jù)類型,但是由于不同的編程語言或標準庫可能采用不同的字符串類型,因此在不同的應(yīng)用場景下可能需要進行字符串類型的相互轉(zhuǎn)換,本文將介紹如何在C/C++中將char*,std::string,QString,CString/MFC?String相互轉(zhuǎn)換2023-06-06

