blob: 0b61223350652e7fd7ab1a301a318e34f0c1f70e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
import QtQuick 2.0
import "custom" as Components
import QtDesktop 0.2
// jens: ContainsMouse breaks drag functionality
Components.Slider{
id: slider
property bool tickmarksEnabled: false
property string tickPosition: "Below" // "Above", "Below", "BothSides"
StyleItem {
id:buttonitem
elementType: "slider"
contentWidth:23
contentHeight:23
}
property int orientation: Qt.Horizontal
implicitWidth: orientation === Qt.Horizontal ? 200 : buttonitem.implicitHeight
implicitHeight: orientation === Qt.Horizontal ? buttonitem.implicitHeight : 200
property string styleHint;
groove: StyleItem {
anchors.fill:parent
elementType: "slider"
sunken: pressed
maximum: slider.maximumValue*100
minimum: slider.minimumValue*100
step: slider.stepSize*100
value: slider.value*100
horizontal: slider.orientation == Qt.Horizontal
enabled: slider.enabled
hasFocus: slider.focus
hint: slider.styleHint
activeControl: tickmarksEnabled ? tickPosition.toLowerCase() : ""
}
handle: null
valueIndicator: null
Keys.onRightPressed: value += (maximumValue - minimumValue)/10.0
Keys.onLeftPressed: value -= (maximumValue - minimumValue)/10.0
WheelArea {
id: wheelarea
anchors.fill: parent
horizontalMinimumValue: slider.minimumValue
horizontalMaximumValue: slider.maximumValue
verticalMinimumValue: slider.minimumValue
verticalMaximumValue: slider.maximumValue
property double step: (slider.maximumValue - slider.minimumValue)/100
onVerticalWheelMoved: {
value += verticalDelta/4*step
}
onHorizontalWheelMoved: {
value += horizontalDelta/4*step
}
}
}
|