我正在评估从Qt 4.8到Qt 5.2的迁移,最重要的是多媒体后端。在Qt 5.2中,Qt 4.8中的Phonon后端没有提供一些重要功能。但至少老版本显示了字幕(SRT文件与视频文件在同一目录中)。
文档和反复试验均未向我提供任何结果。
那么,有谁知道如何FOR Qt 5来显示这些字幕?或者甚至不支持(将是一种耻辱)
感谢任何帮助..
PS: 我需要恰恰相反:Disable showing subtitle file in QMediaPlayer
答案 0 :(得分:0)
您必须在playbin2上设置标志GST_PLAY_FLAG_TEXT。 (它通常默认开启。如果需要,则在QGstreamerPlayerSession的ctor中更改它)。
如果您的字幕文件是外部文件,则必须在playbin2上设置“suburi”属性。 suburi属性的值是字幕文件的路径。此更改应在方法QGstreamerPlayerSession :: loadFromUri。
中完成在Qt5.2中,这些更改必须在文件qgstreamerplayersession.cpp中完成。您将在qtmultimedia / src / plugins / gstreamer / mediaplayer中找到该文件。较旧的4.x版本的文件位置可能不同。
我观察到的另一件事是插件代码设置了标志GST_PLAY_FLAG_NATIVE_VIDEO。如果设置了此标志,则不显示字幕。您必须阻止插件代码设置此标志。您可以注释掉设置此标志的代码,或者您必须将环境变量QT_GSTREAMER_PLAYBIN_FLAGS设置为0x00000017(这是GST_PLAY_FLAG_VIDEO | GST_PLAY_FLAG_AUDIO | GST_PLAY_FLAG_TEXT)。将其设置为任何值将跳过GST_PLAY_FLAG_NATIVE_VIDEO标志。
进行这些更改后,构建插件并使用它。
答案 1 :(得分:0)
我搜索了很多内容,显然Qt mediaplayer不支持字幕,我使用srt parser来显示字幕。
我的BackEnd类代码:
#include "backend.h"
BackEnd::BackEnd(QObject *parent) : QObject(parent)
{
readSubtitleFile("./en.srt");
}
void BackEnd::readSubtitleFile(QString directory)
{
cout<< "readSubtitleFile:"<< directory.toStdString()<<endl;
if(!isFileExist(directory.toStdString())) {
cout<< "file does not exist"<<endl;
return ;
}
SubtitleParserFactory *subParserFactory = new SubtitleParserFactory(directory.toStdString());
SubtitleParser *parser = subParserFactory->getParser();
sub = parser->getSubtitles();
}
QString BackEnd::getSubtitleText(double playTime)
{
for(SubtitleItem * element : sub) {
double startTime = element->getStartTime();
double endTime = element->getEndTime();
if( (startTime <= playTime) && (playTime <= endTime)) {
cout<< "getSubtitleText: founded"<< element->getText()<<endl;
return QString::fromStdString(element->getText());
}
}
cout<< "getSubtitleText: not founded"<< endl;
return "";
}
bool BackEnd::isFileExist(const string &temp)
{
if (FILE *file = fopen(temp.c_str(), "r")) {
fclose(file);
return true;
} else {
return false;
}
}
我的qml文件:
Window {
visible: true
width: 900
height: 700
title: qsTr("My Player")
Rectangle {
id: root
color: "black"
width: parent.width
height: parent.height
function msToTime(duration) {
var milliseconds=parseInt((duration%1000)/100),
seconds = Math.floor((duration / 1000) % 60),
minutes = Math.floor((duration / (1000 * 60)) % 60),
hours = Math.floor((duration / (1000 * 60 * 60)) % 24);
hours = (hours < 10) ? "0" + hours : hours;
minutes = (minutes < 10) ? "0" + minutes : minutes;
seconds = (seconds < 10) ? "0" + seconds : seconds;
return hours + ":" + minutes + ":" + seconds;
}
Column {
width: parent.width
height: parent.height
Item {
width: parent.width
height: parent.height-100
MediaPlayer {
id: mediaplayer
source: "file:///E:/1.mp4"
}
VideoOutput {
anchors.fill: parent
source: mediaplayer
}
}
Text {
id: subtitleText
text: qsTr("")
y: -150
font.pixelSize: 18
color: "white"
anchors.horizontalCenter:
parent.horizontalCenter
}
}
Timer {
id: refreshTimer
interval: 1000//30 // 60 Hz
running: true
repeat: true
onTriggered: {
durationPass.text =
root.msToTime(mediaplayer.position);
subtitleText.text =
BackEnd.getSubtitleText(mediaplayer.position);
}
}
}