chore: add fallback when taglib don't have related metadata
This commit is contained in:
parent
c672a597b3
commit
15ffe5a85e
@ -114,12 +114,12 @@ void MainWindow::setAudioPropertyInfoForDisplay(int sampleRate, int bitrate, int
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
if (sampleRate >= 0) {
|
if (sampleRate > 0) {
|
||||||
uiStrs << QString("%1 Hz").arg(sampleRate);
|
uiStrs << QString("%1 Hz").arg(sampleRate);
|
||||||
tooltipStrs << tr("Sample Rate: %1 Hz").arg(sampleRate);
|
tooltipStrs << tr("Sample Rate: %1 Hz").arg(sampleRate);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bitrate >= 0) {
|
if (bitrate > 0) {
|
||||||
uiStrs << QString("%1 Kbps").arg(bitrate);
|
uiStrs << QString("%1 Kbps").arg(bitrate);
|
||||||
tooltipStrs << tr("Bitrate: %1 Kbps").arg(bitrate);
|
tooltipStrs << tr("Bitrate: %1 Kbps").arg(bitrate);
|
||||||
}
|
}
|
||||||
@ -440,6 +440,8 @@ void MainWindow::initConnections()
|
|||||||
if (!fileRef.isNull() && fileRef.audioProperties()) {
|
if (!fileRef.isNull() && fileRef.audioProperties()) {
|
||||||
TagLib::AudioProperties *prop = fileRef.audioProperties();
|
TagLib::AudioProperties *prop = fileRef.audioProperties();
|
||||||
setAudioPropertyInfoForDisplay(prop->sampleRate(), prop->bitrate(), prop->channels(), suffix);
|
setAudioPropertyInfoForDisplay(prop->sampleRate(), prop->bitrate(), prop->channels(), suffix);
|
||||||
|
} else {
|
||||||
|
qDebug() << "No Audio Properties from TagLib";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!fileRef.isNull() && fileRef.tag()) {
|
if (!fileRef.isNull() && fileRef.tag()) {
|
||||||
@ -447,6 +449,10 @@ void MainWindow::initConnections()
|
|||||||
setAudioMetadataForDisplay(QString::fromStdString(tag->title().to8Bit(true)),
|
setAudioMetadataForDisplay(QString::fromStdString(tag->title().to8Bit(true)),
|
||||||
QString::fromStdString(tag->artist().to8Bit(true)),
|
QString::fromStdString(tag->artist().to8Bit(true)),
|
||||||
QString::fromStdString(tag->album().to8Bit(true)));
|
QString::fromStdString(tag->album().to8Bit(true)));
|
||||||
|
m_urlMissingTagLibMetadata.clear();
|
||||||
|
} else {
|
||||||
|
qDebug() << "No Audio Metadata from TagLib";
|
||||||
|
m_urlMissingTagLibMetadata = fileUrl;
|
||||||
}
|
}
|
||||||
#endif // NO_TAGLIB
|
#endif // NO_TAGLIB
|
||||||
}
|
}
|
||||||
@ -458,12 +464,17 @@ void MainWindow::initConnections()
|
|||||||
// see `02 Yoiyami Hanabi.mp3`'s Title. So we don't use Qt's one if tablib is available.
|
// see `02 Yoiyami Hanabi.mp3`'s Title. So we don't use Qt's one if tablib is available.
|
||||||
qDebug() << metadata.stringValue(QMediaMetaData::Title) << metadata.stringValue(QMediaMetaData::Author);
|
qDebug() << metadata.stringValue(QMediaMetaData::Title) << metadata.stringValue(QMediaMetaData::Author);
|
||||||
#ifdef NO_TAGLIB
|
#ifdef NO_TAGLIB
|
||||||
|
bool needMetadataFromQt = true;
|
||||||
|
#else
|
||||||
|
bool needMetadataFromQt = m_urlMissingTagLibMetadata == m_mediaPlayer->source();
|
||||||
|
#endif // NO_TAGLIB
|
||||||
|
if (needMetadataFromQt) {
|
||||||
setAudioMetadataForDisplay(metadata.stringValue(QMediaMetaData::Title),
|
setAudioMetadataForDisplay(metadata.stringValue(QMediaMetaData::Title),
|
||||||
metadata.stringValue(QMediaMetaData::Author),
|
metadata.stringValue(QMediaMetaData::Author),
|
||||||
metadata.stringValue(QMediaMetaData::AlbumTitle));
|
metadata.stringValue(QMediaMetaData::AlbumTitle));
|
||||||
setAudioPropertyInfoForDisplay(-1, metadata.value(QMediaMetaData::AudioBitRate).toInt() / 1000,
|
setAudioPropertyInfoForDisplay(-1, metadata.value(QMediaMetaData::AudioBitRate).toInt() / 1000,
|
||||||
-1, metadata.stringValue(QMediaMetaData::FileFormat));
|
-1, metadata.stringValue(QMediaMetaData::FileFormat));
|
||||||
#endif // NO_TAGLIB
|
}
|
||||||
QVariant coverArt(metadata.value(QMediaMetaData::ThumbnailImage));
|
QVariant coverArt(metadata.value(QMediaMetaData::ThumbnailImage));
|
||||||
if (!coverArt.isNull()) {
|
if (!coverArt.isNull()) {
|
||||||
ui->coverLabel->setPixmap(QPixmap::fromImage(coverArt.value<QImage>()));
|
ui->coverLabel->setPixmap(QPixmap::fromImage(coverArt.value<QImage>()));
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
|
|
||||||
#include <QMainWindow>
|
#include <QMainWindow>
|
||||||
#include <QVariant>
|
#include <QVariant>
|
||||||
|
#include <QUrl>
|
||||||
|
|
||||||
QT_BEGIN_NAMESPACE
|
QT_BEGIN_NAMESPACE
|
||||||
namespace Ui { class MainWindow; }
|
namespace Ui { class MainWindow; }
|
||||||
@ -89,6 +90,7 @@ private:
|
|||||||
bool m_playbackSliderPressed = false;
|
bool m_playbackSliderPressed = false;
|
||||||
QLinearGradient m_bgLinearGradient;
|
QLinearGradient m_bgLinearGradient;
|
||||||
QPixmap m_skin;
|
QPixmap m_skin;
|
||||||
|
QUrl m_urlMissingTagLibMetadata;
|
||||||
enum PlaybackMode m_playbackMode = CurrentItemInLoop;
|
enum PlaybackMode m_playbackMode = CurrentItemInLoop;
|
||||||
|
|
||||||
Ui::MainWindow *ui;
|
Ui::MainWindow *ui;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user