mirror of
https://github.com/Nheko-Reborn/nheko.git
synced 2024-11-29 06:08:48 +03:00
Initial Refactoring into separate controls
This commit is contained in:
parent
c68c8de74f
commit
f6fcae124f
4 changed files with 115 additions and 88 deletions
|
@ -3,6 +3,7 @@
|
||||||
// SPDX-License-Identifier: GPL-3.0-or-later
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
import "../"
|
import "../"
|
||||||
|
import "../ui/media"
|
||||||
import QtMultimedia 5.15
|
import QtMultimedia 5.15
|
||||||
import QtQuick 2.15
|
import QtQuick 2.15
|
||||||
import QtQuick.Controls 2.15
|
import QtQuick.Controls 2.15
|
||||||
|
@ -50,6 +51,7 @@ ColumnLayout {
|
||||||
// desiredVolume is a float from 0.0 -> 1.0, MediaPlayer volume is an int from 0 to 100
|
// desiredVolume is a float from 0.0 -> 1.0, MediaPlayer volume is an int from 0 to 100
|
||||||
// this value automatically gets clamped for us between these two values.
|
// this value automatically gets clamped for us between these two values.
|
||||||
volume: volumeSlider.desiredVolume * 100
|
volume: volumeSlider.desiredVolume * 100
|
||||||
|
muted: volumeSlider.muted
|
||||||
}
|
}
|
||||||
|
|
||||||
Rectangle {
|
Rectangle {
|
||||||
|
@ -123,7 +125,7 @@ ColumnLayout {
|
||||||
id: controlRect
|
id: controlRect
|
||||||
property int controlHeight: 25
|
property int controlHeight: 25
|
||||||
property bool shouldShowControls: playerMouseArea.shouldShowControls ||
|
property bool shouldShowControls: playerMouseArea.shouldShowControls ||
|
||||||
volumeSliderRect.visible
|
volumeSlider.controlsVisible
|
||||||
|
|
||||||
anchors.bottom: playerMouseArea.bottom
|
anchors.bottom: playerMouseArea.bottom
|
||||||
// Window color with 128/255 alpha
|
// Window color with 128/255 alpha
|
||||||
|
@ -182,96 +184,13 @@ ColumnLayout {
|
||||||
from: 0
|
from: 0
|
||||||
to: mxcmedia.duration
|
to: mxcmedia.duration
|
||||||
}
|
}
|
||||||
// Volume slider activator
|
|
||||||
Image {
|
|
||||||
property color controlColor: (volumeImageArea.containsMouse) ?
|
|
||||||
Nheko.colors.highlight : Nheko.colors.text
|
|
||||||
|
|
||||||
// TODO: add icons for different volume levels
|
VolumeControl {
|
||||||
id: volumeImage
|
id: volumeSlider
|
||||||
source: (mxcmedia.volume > 0 && !mxcmedia.muted) ?
|
orientation: Qt.Vertical
|
||||||
"image://colorimage/:/icons/icons/ui/volume-up.png?"+ controlColor :
|
|
||||||
"image://colorimage/:/icons/icons/ui/volume-off-indicator.png?"+ controlColor
|
|
||||||
Layout.rightMargin: 5
|
Layout.rightMargin: 5
|
||||||
Layout.preferredHeight: controlRect.controlHeight
|
Layout.preferredHeight: controlRect.controlHeight
|
||||||
fillMode: Image.PreserveAspectFit
|
}
|
||||||
MouseArea {
|
|
||||||
id: volumeImageArea
|
|
||||||
anchors.fill: parent
|
|
||||||
hoverEnabled: true
|
|
||||||
onClicked: mxcmedia.muted = !mxcmedia.muted
|
|
||||||
onExited: volumeSliderHideTimer.start()
|
|
||||||
onPositionChanged: volumeSliderHideTimer.start()
|
|
||||||
// For hiding volume slider after a while
|
|
||||||
Timer {
|
|
||||||
id: volumeSliderHideTimer
|
|
||||||
interval: 1500
|
|
||||||
repeat: false
|
|
||||||
running: false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Rectangle {
|
|
||||||
id: volumeSliderRect
|
|
||||||
opacity: (visible) ? 1 : 0
|
|
||||||
Behavior on opacity {
|
|
||||||
OpacityAnimator {
|
|
||||||
duration: 100
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// TODO: figure out a better way to put the slider popup above controlRect
|
|
||||||
anchors.bottom: volumeImage.top
|
|
||||||
anchors.bottomMargin: 10
|
|
||||||
anchors.horizontalCenter: volumeImage.horizontalCenter
|
|
||||||
color: {
|
|
||||||
var wc = Nheko.colors.window
|
|
||||||
return Qt.rgba(wc.r, wc.g, wc.b, 0.5)
|
|
||||||
}
|
|
||||||
/* TODO: base width on the slider width (some issue with it not having a geometry
|
|
||||||
when using the width here?) */
|
|
||||||
width: volumeImage.width * 0.7
|
|
||||||
radius: volumeSlider.width / 2
|
|
||||||
height: controlRect.height * 2 //100
|
|
||||||
visible: volumeImageArea.containsMouse ||
|
|
||||||
volumeSliderHideTimer.running ||
|
|
||||||
volumeSliderRectMouseArea.containsMouse
|
|
||||||
Slider {
|
|
||||||
// TODO: the slider is slightly off-center on the left for some reason...
|
|
||||||
id: volumeSlider
|
|
||||||
|
|
||||||
value: 1.0
|
|
||||||
// Desired value to avoid loop onMoved -> media.volume -> value -> onMoved...
|
|
||||||
property real desiredVolume: QtMultimedia.convertVolume(volumeSlider.value,
|
|
||||||
QtMultimedia.LogarithmicVolumeScale,
|
|
||||||
QtMultimedia.LinearVolumeScale)
|
|
||||||
|
|
||||||
anchors.fill: parent
|
|
||||||
anchors.bottomMargin: parent.height * 0.1
|
|
||||||
anchors.topMargin: parent.height * 0.1
|
|
||||||
anchors.horizontalCenter: parent.horizontalCenter
|
|
||||||
orientation: Qt.Vertical
|
|
||||||
onDesiredVolumeChanged: {
|
|
||||||
mxcmedia.muted = !(desiredVolume > 0.0)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Used for resetting the timer on mouse moves on volumeSliderRect
|
|
||||||
MouseArea {
|
|
||||||
id: volumeSliderRectMouseArea
|
|
||||||
anchors.fill: parent
|
|
||||||
hoverEnabled: true
|
|
||||||
propagateComposedEvents: true
|
|
||||||
onExited: volumeSliderHideTimer.start()
|
|
||||||
|
|
||||||
onClicked: mouse.accepted = false
|
|
||||||
onPressed: mouse.accepted = false
|
|
||||||
onReleased: mouse.accepted = false
|
|
||||||
onPressAndHold: mouse.accepted = false
|
|
||||||
onPositionChanged: {
|
|
||||||
mouse.accepted = false
|
|
||||||
volumeSliderHideTimer.start()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
105
resources/qml/ui/media/VolumeControl.qml
Normal file
105
resources/qml/ui/media/VolumeControl.qml
Normal file
|
@ -0,0 +1,105 @@
|
||||||
|
// SPDX-FileCopyrightText: 2021 Nheko Contributors
|
||||||
|
//
|
||||||
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
|
||||||
|
import QtMultimedia 5.15
|
||||||
|
import QtQuick 2.15
|
||||||
|
import QtQuick.Controls 2.15
|
||||||
|
|
||||||
|
import im.nheko 1.0
|
||||||
|
|
||||||
|
// Volume slider activator
|
||||||
|
Image {
|
||||||
|
property alias desiredVolume: volumeSlider.desiredVolume
|
||||||
|
property alias orientation: volumeSlider.orientation
|
||||||
|
property alias controlsVisible: volumeSliderRect.visible
|
||||||
|
property bool muted: false
|
||||||
|
property color controlColor: (volumeImageArea.containsMouse) ?
|
||||||
|
Nheko.colors.highlight : Nheko.colors.text
|
||||||
|
|
||||||
|
// TODO: add icons for different volume levels
|
||||||
|
id: volumeImage
|
||||||
|
source: (desiredVolume > 0 && !muted) ?
|
||||||
|
"image://colorimage/:/icons/icons/ui/volume-up.png?"+ controlColor :
|
||||||
|
"image://colorimage/:/icons/icons/ui/volume-off-indicator.png?"+ controlColor
|
||||||
|
|
||||||
|
fillMode: Image.PreserveAspectFit
|
||||||
|
|
||||||
|
MouseArea {
|
||||||
|
id: volumeImageArea
|
||||||
|
anchors.fill: parent
|
||||||
|
hoverEnabled: true
|
||||||
|
onExited: volumeSliderHideTimer.start()
|
||||||
|
onPositionChanged: volumeSliderHideTimer.start()
|
||||||
|
onClicked: volumeImage.muted = !volumeImage.muted
|
||||||
|
// For hiding volume slider after a while
|
||||||
|
Timer {
|
||||||
|
id: volumeSliderHideTimer
|
||||||
|
interval: 1500
|
||||||
|
repeat: false
|
||||||
|
running: false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Rectangle {
|
||||||
|
id: volumeSliderRect
|
||||||
|
opacity: (visible) ? 1 : 0
|
||||||
|
Behavior on opacity {
|
||||||
|
OpacityAnimator {
|
||||||
|
duration: 100
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// TODO: figure out a better way to put the slider popup above controlRect
|
||||||
|
anchors.bottom: volumeImage.top
|
||||||
|
anchors.bottomMargin: 10
|
||||||
|
anchors.horizontalCenter: volumeImage.horizontalCenter
|
||||||
|
color: {
|
||||||
|
var wc = Nheko.colors.window
|
||||||
|
return Qt.rgba(wc.r, wc.g, wc.b, 0.5)
|
||||||
|
}
|
||||||
|
/* TODO: base width on the slider width (some issue with it not having a geometry
|
||||||
|
when using the width here?) */
|
||||||
|
width: volumeImage.width * 0.7
|
||||||
|
radius: volumeSlider.width / 2
|
||||||
|
height: controlRect.height * 2 //100
|
||||||
|
visible: volumeImageArea.containsMouse ||
|
||||||
|
volumeSliderHideTimer.running ||
|
||||||
|
volumeSliderRectMouseArea.containsMouse
|
||||||
|
Slider {
|
||||||
|
// TODO: the slider is slightly off-center on the left for some reason...
|
||||||
|
id: volumeSlider
|
||||||
|
|
||||||
|
value: 1.0
|
||||||
|
// Desired value to avoid loop onMoved -> media.volume -> value -> onMoved...
|
||||||
|
property real desiredVolume: QtMultimedia.convertVolume(volumeSlider.value,
|
||||||
|
QtMultimedia.LogarithmicVolumeScale,
|
||||||
|
QtMultimedia.LinearVolumeScale)
|
||||||
|
|
||||||
|
anchors.fill: parent
|
||||||
|
anchors.bottomMargin: volumeSliderRect.height * 0.1
|
||||||
|
anchors.topMargin: volumeSliderRect.height * 0.1
|
||||||
|
anchors.horizontalCenter: volumeSliderRect.horizontalCenter
|
||||||
|
orientation: Qt.Vertical
|
||||||
|
onDesiredVolumeChanged: {
|
||||||
|
volumeImage.muted = !(desiredVolume > 0.0)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
// Used for resetting the timer on mouse moves on volumeSliderRect
|
||||||
|
MouseArea {
|
||||||
|
id: volumeSliderRectMouseArea
|
||||||
|
anchors.fill: parent
|
||||||
|
hoverEnabled: true
|
||||||
|
propagateComposedEvents: true
|
||||||
|
onExited: volumeSliderHideTimer.start()
|
||||||
|
|
||||||
|
onClicked: mouse.accepted = false
|
||||||
|
onPressed: mouse.accepted = false
|
||||||
|
onReleased: mouse.accepted = false
|
||||||
|
onPressAndHold: mouse.accepted = false
|
||||||
|
onPositionChanged: {
|
||||||
|
mouse.accepted = false
|
||||||
|
volumeSliderHideTimer.start()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
2
resources/qml/ui/media/qmldir
Normal file
2
resources/qml/ui/media/qmldir
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
module im.nheko.UI.Media
|
||||||
|
VolumeSlider 1.0 VolumeSlider.qml
|
|
@ -183,6 +183,7 @@
|
||||||
<file>qml/ui/Ripple.qml</file>
|
<file>qml/ui/Ripple.qml</file>
|
||||||
<file>qml/ui/Spinner.qml</file>
|
<file>qml/ui/Spinner.qml</file>
|
||||||
<file>qml/ui/animations/BlinkAnimation.qml</file>
|
<file>qml/ui/animations/BlinkAnimation.qml</file>
|
||||||
|
<file>qml/ui/media/VolumeControl.qml</file>
|
||||||
<file>qml/voip/ActiveCallBar.qml</file>
|
<file>qml/voip/ActiveCallBar.qml</file>
|
||||||
<file>qml/voip/CallDevices.qml</file>
|
<file>qml/voip/CallDevices.qml</file>
|
||||||
<file>qml/voip/CallInvite.qml</file>
|
<file>qml/voip/CallInvite.qml</file>
|
||||||
|
|
Loading…
Reference in a new issue