From bd3995d4f42e5c9e7f0c591494bfed867fae7dfe Mon Sep 17 00:00:00 2001 From: Kitteh Date: Fri, 26 Oct 2018 17:02:07 +0100 Subject: [PATCH] [UI] Fixed cache bar and added screenshotting keybinds. --- src/mpvobject.cpp | 5 +-- src/qml/main.qml | 88 ++++++++++++++++++++++++++++++++++++----------- 2 files changed, 70 insertions(+), 23 deletions(-) diff --git a/src/mpvobject.cpp b/src/mpvobject.cpp index 553adb6..39c2eb7 100644 --- a/src/mpvobject.cpp +++ b/src/mpvobject.cpp @@ -126,7 +126,8 @@ MpvObject::MpvObject(QQuickItem * parent) //mpp_set_option_string(mpv, "no-sub-ass", "yes) mpv_set_option_string(mpv, "slang", "en"); - /*mpv_set_option_string(mpv, "sub-font", "Noto Sans"); + mpv_set_option_string(mpv, "sub-font", "Noto Sans"); + mpv_set_option_string(mpv, "sub-font-size", "24"); mpv_set_option_string(mpv, "sub-ass-override", "force"); mpv_set_option_string(mpv, "sub-ass", "off"); mpv_set_option_string(mpv, "sub-border-size", "0"); @@ -134,7 +135,7 @@ MpvObject::MpvObject(QQuickItem * parent) mpv_set_option_string(mpv, "sub-scale-by-window", "on"); mpv_set_option_string(mpv, "sub-scale-with-window", "on"); - mpv_set_option_string(mpv, "sub-back-color", "#C0080808");*/ + mpv_set_option_string(mpv, "sub-back-color", "0.0/0.0/0.0/0.0"); mpv_set_option_string(mpv, "config", "yes"); //mpv_set_option_string(mpv, "sub-visibility", "no"); diff --git a/src/qml/main.qml b/src/qml/main.qml index 8a3c3f1..2d12539 100644 --- a/src/qml/main.qml +++ b/src/qml/main.qml @@ -153,11 +153,6 @@ ApplicationWindow { progressBar.value = val } - function setCachedDuration(val) { - cachedLength.width = progressBar.width / progressBar.to - * (val - progressBar.value) - (progressBar.handle.width / 2) - } - function skipToNinth(val) { console.log(val) var skipto = 0 @@ -219,10 +214,11 @@ ApplicationWindow { return subtitlesMenu.visible || settingsMenu.visible || fileMenuBarItem.opened || playbackMenuBarItem.opened || viewMenuBarItem.opened || tracksMenuBarItem.opened + || screenshotSaveDialog.visible } - function hideControls() { - if (!isAnyMenuOpen()) { + function hideControls(force) { + if (!isAnyMenuOpen() || force) { //player.setOption("sub-margin-y", "22") controlsBar.visible = false controlsBackground.visible = false @@ -243,6 +239,22 @@ ApplicationWindow { } } + Dialog { + id: screenshotSaveDialog + title: "Save Screenshot To" + standardButtons: StandardButton.Cancel | StandardButton.Open + onAccepted: { + player.grabToImage(function (result) { + result.saveToFile(screenshotFile.text) + nativeSubs.visible = true + }) + } + TextField { + id: screenshotFile + placeholderText: qsTr("~/screenshot.jpg") + } + } + FileDialog { id: fileDialog title: "Please choose a file" @@ -331,11 +343,14 @@ ApplicationWindow { property string statsForNerds: "I" property string forwardFrame: "." property string backwardFrame: "," - property string cycleSub: "S" - property string cycleSubBackwards: "Shift+S" + property string cycleSub: "Alt+S" + property string cycleSubBackwards: "Alt+Shift+S" property string cycleAudio: "A" property string cycleVideo: "V" property string cycleVideoAspect: "Shift+A" + property string screenshot: "S" + property string screenshotWithoutSubtitles: "Shift+S" + property string fullScreenshot: "Ctrl+S" } MenuBar { @@ -395,6 +410,30 @@ ApplicationWindow { onTriggered: loadDialog.open() shortcut: keybinds.openURI } + Action { + text: "Screenshot" + onTriggered: { + player.hideControls(true) + screenshotSaveDialog.open() + } + shortcut: keybinds.screenshot + } + Action { + text: "Screenshot w/o subtitles" + onTriggered: { + player.hideControls(true) + nativeSubs.visible = false + screenshotSaveDialog.open() + } + shortcut: keybinds.screenshotWithoutSubtitles + } + Action { + text: "Full Screenshot" + onTriggered: { + screenshotSaveDialog.open() + } + shortcut: keybinds.fullScreenshot + } Action { text: "Exit" onTriggered: Qt.quit() @@ -793,13 +832,18 @@ ApplicationWindow { color: Qt.rgba(0, 0, 0, 0.6) width: t_metrics.tightBoundingRect.width + 8 anchors.left: parent.left - anchors.leftMargin: (nativeSubtitles.width - t_metrics.tightBoundingRect.width) / 2 + anchors.leftMargin: (nativeSubtitles.width + - t_metrics.tightBoundingRect.width) / 2 anchors.right: parent.right anchors.rightMargin: anchors.leftMargin } } } + function setCachedDuration(val) { + cachedLength.width = (progressBar.width / progressBar.to) * val + } + Rectangle { id: controlsBar height: controlsBar.visible ? Screen.height / 24 : 0 @@ -872,22 +916,24 @@ ApplicationWindow { color: Qt.rgba(255, 255, 255, 0.4) Rectangle { + id: progressLength width: progressBar.visualPosition * parent.width height: parent.height color: "red" opacity: 1 } - } - Rectangle { - id: cachedLength - z: 1 - //anchors.left: progressBar.handle.right - anchors.left: progressBar.handle.horizontalCenter - anchors.bottom: progressBar.background.bottom - anchors.top: progressBar.background.top - height: progressBar.background.height - color: "white" - opacity: 0.8 + Rectangle { + id: cachedLength + z: 1 + anchors.left: progressLength.right + anchors.leftMargin: progressBar.handle.width / 2 + //anchors.left: progressBar.handle.horizontalCenter + anchors.bottom: progressBar.background.bottom + anchors.top: progressBar.background.top + height: progressBar.background.height + color: "white" + opacity: 0.8 + } } handle: Rectangle {