summaryrefslogtreecommitdiffstats
path: root/qml/Viper/Slider.qml
diff options
context:
space:
mode:
Diffstat (limited to 'qml/Viper/Slider.qml')
-rwxr-xr-xqml/Viper/Slider.qml117
1 files changed, 117 insertions, 0 deletions
diff --git a/qml/Viper/Slider.qml b/qml/Viper/Slider.qml
new file mode 100755
index 00000000..058bfd8e
--- /dev/null
+++ b/qml/Viper/Slider.qml
@@ -0,0 +1,117 @@
+/******************************************************************************
+ Copyright (C) 2013-2016 Wang Bin <wbsecg1@gmail.com>
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+ This library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+ You should have received a copy of the GNU Lesser General Public
+ License along with this library; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+******************************************************************************/
+
+import QtQuick 2.0
+import "utils.js" as Utils
+
+Item {
+ id: root
+ property alias value: grip.value
+ property color fillColor: "white"
+ property color lineColor: "blue"
+ property real lineWidth: Utils.scaled(6)
+ property color gripColor: "white"
+ property real gripSize: Utils.scaled(12)
+ property real gripTolerance: Utils.scaled(3.0)
+ property int orientation: Qt.Horizontal
+ property bool hovered: false //mouseArea.containsMouse || gripMouseArea.containsMouse
+ property real max: 1
+ property real min: 0
+
+ Rectangle {
+ anchors.centerIn: parent
+ height: orientation === Qt.Horizontal ? lineWidth : parent.height
+ width: orientation === Qt.Horizontal ? parent.width : lineWidth
+ color: lineColor
+ }
+
+ MouseArea {
+ id: mouseArea
+ anchors.fill: parent
+ hoverEnabled: true
+
+ onHoveredChanged: {
+ if (mouseX > 65535) //qt5.6 touch screen release finger becomes very large e.g. 0x7fffffff
+ return
+ hovered = mouseArea.containsMouse
+ }
+
+ onClicked: {
+ var newValue = min + (mouse.x / parent.width)*(max-min)
+ if (orientation === Qt.Horizontal) {
+ newValue = min + (mouse.x / parent.width)*(max-min)
+ } else {
+ newValue = min + (mouse.y / parent.height)*(max-min)
+ }
+ var increment = 1.0/width
+ if (Math.abs(newValue - parent.value) > parent.increment*(max-min)) {
+ if (newValue > parent.value)
+ parent.value = Math.min(max, parent.value + parent.increment*(max-min))
+ else
+ parent.value = Math.max(min, parent.value - parent.increment*(max-min))
+ }
+ }
+ }
+
+ Item {
+ id: grip
+ property real value: 0.5
+ x: orientation === Qt.Horizontal ? ((value-min)/(max-min) * parent.width - width/2) : (parent.width - width)/2
+ y: orientation === Qt.Horizontal ? (parent.height - height)/2 : ((value-min)/(max-min) * parent.height - height/2)
+ width: root.gripTolerance * root.gripSize
+ height: width
+ readonly property real radius: width/2
+
+ MouseArea {
+ id: gripMouseArea
+ anchors.fill: parent
+ hoverEnabled: true
+ onHoveredChanged: {
+ if (mouseX > 65535) //qt5.6 touch screen release finger becomes very large e.g. 0x7fffffff
+ return
+ hovered = gripMouseArea.containsMouse
+ }
+
+ drag {
+ target: grip
+ axis: orientation === Qt.Horizontal ? Drag.XAxis : Drag.YAxis
+ minimumX: orientation === Qt.Horizontal ? -parent.radius : 0
+ maximumX: orientation === Qt.Horizontal ? root.width - parent.radius : 0
+ minimumY: orientation === Qt.Horizontal ? 0 : -parent.radius
+ maximumY: orientation === Qt.Horizontal ? 0 : root.height - parent.radius
+ }
+
+ onPositionChanged: {
+ if (drag.active)
+ updatePosition()
+ }
+ onReleased: updatePosition()
+ function updatePosition() {
+ if (orientation === Qt.Horizontal)
+ value = min + ((grip.x + grip.radius) / grip.parent.width)*(max-min)
+ else
+ value = min + ((grip.y + grip.radius) / grip.parent.height)*(max-min)
+ }
+ }
+
+ Rectangle {
+ anchors.centerIn: parent
+ width: root.gripSize
+ height: width
+ radius: width/2
+ color: root.gripColor
+ }
+ }
+}