mirror of https://code.videolan.org/videolan/vlc
doc: QtPlayer: fix file opening on Windows
Using a raw path from the QFileDialog can lead to wrong native separators in the provided string. Using URLs instead of paths should be more cross-platform compliant.
This commit is contained in:
parent
f808bdd6b8
commit
f7d4afc821
|
@ -17,6 +17,7 @@
|
||||||
#include <QHBoxLayout>
|
#include <QHBoxLayout>
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
|
#include <QUrl>
|
||||||
|
|
||||||
Mwindow::Mwindow() {
|
Mwindow::Mwindow() {
|
||||||
vlcPlayer = NULL;
|
vlcPlayer = NULL;
|
||||||
|
@ -125,14 +126,14 @@ void Mwindow::initUI() {
|
||||||
void Mwindow::openFile() {
|
void Mwindow::openFile() {
|
||||||
|
|
||||||
/* The basic file-select box */
|
/* The basic file-select box */
|
||||||
QString fileOpen = QFileDialog::getOpenFileName(this, tr("Load a file"), "~");
|
QUrl url = QFileDialog::getOpenFileUrl(this, tr("Load a file"));
|
||||||
|
|
||||||
/* Stop if something is playing */
|
/* Stop if something is playing */
|
||||||
if (vlcPlayer && libvlc_media_player_is_playing(vlcPlayer))
|
if (vlcPlayer && libvlc_media_player_is_playing(vlcPlayer))
|
||||||
stop();
|
stop();
|
||||||
|
|
||||||
/* Create a new Media */
|
/* Create a new Media */
|
||||||
libvlc_media_t *vlcMedia = libvlc_media_new_path(qtu(fileOpen));
|
libvlc_media_t *vlcMedia = libvlc_media_new_location(qtu(url.toString(QUrl::FullyEncoded)));
|
||||||
if (!vlcMedia)
|
if (!vlcMedia)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue