blob: 96875e0d8c9a999aff36d79e37cced7e3dc6bff9 (
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
/*
* Copyright 2016 Konsulko Group
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import QtQuick 2.6
import QtQuick.Layouts 1.1
import QtQuick.Controls 2.0
import AGL.Demo.Controls 1.0
import PaControlModel 1.0
ApplicationWindow {
id: root
Label {
id: title
font.pixelSize: 48
text: "Mixer"
anchors.horizontalCenter: parent.horizontalCenter
}
Component {
id: ctldesc
Label {
font.pixelSize: 32
width: listView.width
wrapMode: Text.WordWrap
property var typeString: {modelType ? "Output" : "Input"}
text: "[" + typeString + " #" + modelCIndex + "]: " + modelDesc
}
}
Component {
id: empty
Item {
}
}
ListView {
id: listView
anchors.left: parent.left
anchors.top: title.bottom
anchors.margins: 80
anchors.fill: parent
model: PaControlModel { objectName: "pacm" }
delegate: ColumnLayout {
width: parent.width
spacing: 40
Connections {
target: listView.model
onDataChanged: slider.value = volume
}
Loader {
property int modelType: type
property int modelCIndex: cindex
property string modelDesc: name
sourceComponent: (channel == 0) ? ctldesc : empty
}
RowLayout {
Layout.minimumHeight: 75
Label {
font.pixelSize: 24
text: cdesc
Layout.minimumWidth: 150
}
Label {
font.pixelSize: 24
text: "0 %"
}
Slider {
id: slider
Layout.fillWidth: true
from: 0
to: 65536
stepSize: 256
snapMode: Slider.SnapOnRelease
onValueChanged: volume = value
Component.onCompleted: value = volume
}
Label {
font.pixelSize: 24
text: "100 %"
}
}
}
}
}
|