[vlc-devel] [PATCH 12/25] qml: remove autoHide from ControlBar
Prince Gupta
guptaprince8832 at gmail.com
Thu Mar 11 09:16:20 UTC 2021
---
modules/gui/qt/player/qml/ControlBar.qml | 7 ++++---
modules/gui/qt/player/qml/ControlButtons.qml | 15 +++++++++------
modules/gui/qt/player/qml/Player.qml | 18 ++++--------------
.../gui/qt/player/qml/PlayerButtonsLayout.qml | 4 ++++
4 files changed, 21 insertions(+), 23 deletions(-)
diff --git a/modules/gui/qt/player/qml/ControlBar.qml b/modules/gui/qt/player/qml/ControlBar.qml
index cbf00ab26b..705c7b197c 100644
--- a/modules/gui/qt/player/qml/ControlBar.qml
+++ b/modules/gui/qt/player/qml/ControlBar.qml
@@ -42,9 +42,8 @@ Widgets.NavigableFocusScope {
readonly property alias sliderY: row2.y
property int textPosition: ControlBar.TimeTextPosition.AboveSlider
property VLCColors colors: VLCStyle.nightColors
- property bool autoHide: _lockAutoHide === 0 && !lockAutoHide
- property bool lockAutoHide: false
- property int _lockAutoHide: 0 //count the number of element locking the autoHide
+
+ signal requestLockUnlockAutoHide(bool lock, var source)
Keys.priority: Keys.AfterItem
Keys.onPressed: defaultKeyAction(event, 0)
@@ -149,6 +148,8 @@ Widgets.NavigableFocusScope {
navigationUpItem: trackPositionSlider.enabled ? trackPositionSlider : root.navigationUpItem
colors: root.colors
+
+ onRequestLockUnlockAutoHide: root.requestLockUnlockAutoHide(lock, source)
}
}
}
diff --git a/modules/gui/qt/player/qml/ControlButtons.qml b/modules/gui/qt/player/qml/ControlButtons.qml
index 9729bc537f..d961d1f53c 100644
--- a/modules/gui/qt/player/qml/ControlButtons.qml
+++ b/modules/gui/qt/player/qml/ControlButtons.qml
@@ -33,6 +33,8 @@ Item{
property bool isMiniplayer: false
property var parentWindow: undefined
+ signal requestLockUnlockAutoHide(bool lock, var source)
+
property var buttonL: [
{ id: PlayerControlBarModel.PLAY_BUTTON, label: VLCIcons.play, text: i18n.qtr("Play")},
{ id: PlayerControlBarModel.STOP_BUTTON, label: VLCIcons.stop, text: i18n.qtr("Stop")},
@@ -432,10 +434,7 @@ Item{
size: VLCStyle.icon_medium
iconText: VLCIcons.audiosub
- onClicked: {
- root._lockAutoHide += 1
- langMenu.open()
- }
+ onClicked: langMenu.open()
text: i18n.qtr("Languages and tracks")
@@ -448,9 +447,13 @@ Item{
y: (!!rootPlayer) ? (rootPlayer.positionSliderY - height) : 0
z: 1
- onOpened: rootPlayer._menu = langMenu
+ onOpened: {
+ controlButtons.requestLockUnlockAutoHide(true, controlButtons)
+ rootPlayer._menu = langMenu
+ }
+
onMenuClosed: {
- root._lockAutoHide -= 1
+ controlButtons.requestLockUnlockAutoHide(false, controlButtons)
langBtn.forceActiveFocus()
rootPlayer._menu = undefined
}
diff --git a/modules/gui/qt/player/qml/Player.qml b/modules/gui/qt/player/qml/Player.qml
index ac8862191b..b98c55bfe2 100644
--- a/modules/gui/qt/player/qml/Player.qml
+++ b/modules/gui/qt/player/qml/Player.qml
@@ -432,7 +432,6 @@ Widgets.NavigableFocusScope {
Widgets.DrawerExt {
id: controlBarView
- property var autoHide: controlBarView.contentItem.autoHide
readonly property int sliderY: contentItem.sliderY
anchors {
@@ -447,13 +446,14 @@ Widgets.NavigableFocusScope {
component: MouseArea {
id: controllerMouseArea
- property alias autoHide: controllerId.autoHide
readonly property alias sliderY: controllerId.sliderY
height: controllerId.implicitHeight + controllerId.anchors.bottomMargin
width: controlBarView.width
hoverEnabled: true
+ onContainsMouseChanged: rootPlayer.lockUnlockAutoHide(containsMouse, topcontrolView)
+
ControlBar {
id: controllerId
focus: true
@@ -462,18 +462,10 @@ Widgets.NavigableFocusScope {
anchors.rightMargin: VLCStyle.applicationHorizontalMargin
anchors.bottomMargin: VLCStyle.applicationVerticalMargin
colors: rootPlayer.colors
-
- lockAutoHide: playlistpopup.state === "visible"
- || !player.hasVideoOutput
- || !rootPlayer.hasEmbededVideo
- || controllerMouseArea.containsMouse
- onAutoHideChanged: {
- if (autoHide)
- toolbarAutoHide.restart()
- }
-
navigationParent: rootPlayer
navigationUpItem: playlistpopup.showPlaylist ? playlistpopup : (audioControls.visible ? audioControls : topcontrolView)
+
+ onRequestLockUnlockAutoHide: rootPlayer.lockUnlockAutoHide(lock, source)
}
}
}
@@ -549,8 +541,6 @@ Widgets.NavigableFocusScope {
{
if (!rootPlayer._autoHide)
return;
- if (!controlBarView.autoHide)
- return;
controlBarView.state = "hidden"
topcontrolView.state = "hidden"
videoSurface.forceActiveFocus()
diff --git a/modules/gui/qt/player/qml/PlayerButtonsLayout.qml b/modules/gui/qt/player/qml/PlayerButtonsLayout.qml
index a4c0dc56b0..ec531b5494 100644
--- a/modules/gui/qt/player/qml/PlayerButtonsLayout.qml
+++ b/modules/gui/qt/player/qml/PlayerButtonsLayout.qml
@@ -43,6 +43,8 @@ Widgets.NavigableFocusScope {
property real spacing: VLCStyle.margin_normal // spacing between controls
property real layoutSpacing: VLCStyle.margin_xlarge // spacing between layouts (left, center, and right)
+ signal requestLockUnlockAutoHide(bool lock, var source)
+
enum Alignment {
Left = 0,
Center = 1,
@@ -66,6 +68,8 @@ Widgets.NavigableFocusScope {
isMiniplayer: false
parentWindow: g_root
+
+ onRequestLockUnlockAutoHide: playerButtonsLayout.requestLockUnlockAutoHide(lock, source)
}
ButtonsLayout {
--
2.25.1
More information about the vlc-devel
mailing list