forked from mixxxdj/mixxx
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
ac3c551
commit eff07d8
Showing
31 changed files
with
2,639 additions
and
194 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
<?xml version='1.0' encoding='utf-8'?> | ||
<MixxxControllerPreset mixxxVersion="2.4.0" schemaVersion="1"> | ||
<info> | ||
<name>Dummy Device (Screens)</name> | ||
<author>A. Colombier</author> | ||
<description>Dummy device screens</description> | ||
<devices> | ||
<product protocol="hid" vendor_id="0xdead" product_id="0xbeaf" /> | ||
</devices> | ||
</info> | ||
<controller id="DummyDevice"> | ||
<screens> | ||
<screen identifier="main" width="480" height="360" targetFps="20" pixelType="RBGA" splashoff="2000" /> | ||
</screens> | ||
<scriptfiles> | ||
<file filename="DummyDeviceDefaultScreen.qml" /> | ||
</scriptfiles> | ||
<qmllibraries> | ||
</qmllibraries> | ||
</controller> | ||
</MixxxControllerPreset> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,221 @@ | ||
import QtQuick 2.15 | ||
import QtQuick.Window 2.3 | ||
import QtQuick.Scene3D 2.14 | ||
|
||
import QtQuick.Controls 2.15 | ||
import QtQuick.Shapes 1.11 | ||
import QtQuick.Layouts 1.3 | ||
import QtQuick.Window 2.15 | ||
|
||
import Qt5Compat.GraphicalEffects | ||
|
||
import Mixxx 1.0 as Mixxx | ||
import Mixxx.Controls 1.0 as MixxxControls | ||
|
||
Item { | ||
id: root | ||
|
||
required property string screenId | ||
property color fontColor: Qt.rgba(242/255,242/255,242/255, 1) | ||
property color smallBoxBorder: Qt.rgba(44/255,44/255,44/255, 1) | ||
|
||
property string group: "[Channel1]" | ||
property var deckPlayer: Mixxx.PlayerManager.getPlayer(root.group) | ||
|
||
function init(controlerName, isDebug) { | ||
console.log(`Screen ${root.screenId} has started`) | ||
loader.sourceComponent = live | ||
} | ||
|
||
function shutdown() { | ||
console.log(`Screen ${root.screenId} is stopping`) | ||
loader.sourceComponent = splashoff | ||
} | ||
|
||
function transformFrame(input, timestamp) { | ||
return new ArrayBuffer(0); | ||
} | ||
|
||
Timer { | ||
id: channelchange | ||
|
||
interval: 2000 | ||
repeat: true | ||
running: true | ||
|
||
onTriggered: { | ||
root.group = root.group === "[Channel1]" ? "[Channel2]" : "[Channel1]" | ||
} | ||
} | ||
|
||
Component { | ||
id: splashoff | ||
Rectangle { | ||
color: "black" | ||
anchors.fill: parent | ||
Image { | ||
anchors.fill: parent | ||
fillMode: Image.PreserveAspectFit | ||
source: "../images/templates/logo_mixxx.png" | ||
} | ||
} | ||
} | ||
|
||
Component { | ||
id: live | ||
|
||
Rectangle { | ||
anchors.fill: parent | ||
color: 'black' | ||
|
||
antialiasing: true | ||
|
||
ColumnLayout { | ||
id: column | ||
anchors.fill: parent | ||
anchors.leftMargin: 0 | ||
anchors.rightMargin: 0 | ||
anchors.topMargin: 0 | ||
anchors.bottomMargin: 0 | ||
spacing: 6 | ||
|
||
RowLayout { | ||
Layout.fillWidth: true | ||
spacing: 0 | ||
|
||
Repeater { | ||
id: debugColor | ||
|
||
model: [ | ||
"black", | ||
"white", | ||
"red", | ||
"green", | ||
"blue", | ||
Qt.rgba(0, 1, 1), | ||
] | ||
|
||
Rectangle { | ||
required property var modelData | ||
|
||
color: modelData | ||
Layout.fillWidth: true | ||
height: 80 | ||
} | ||
} | ||
} | ||
|
||
RowLayout { | ||
anchors.leftMargin: 6 | ||
anchors.rightMargin: 6 | ||
anchors.topMargin: 6 | ||
anchors.bottomMargin: 6 | ||
|
||
Layout.fillWidth: true | ||
Layout.fillHeight: true | ||
spacing: 6 | ||
|
||
Rectangle { | ||
color: 'transparent' | ||
Layout.fillWidth: true | ||
Layout.fillHeight: true | ||
Text { | ||
text: qsTr("Group") | ||
font.pixelSize: 24 | ||
font.family: "Noto Sans" | ||
font.letterSpacing: -1 | ||
color: fontColor | ||
} | ||
} | ||
|
||
Rectangle { | ||
color: 'transparent' | ||
Layout.fillWidth: true | ||
Layout.fillHeight: true | ||
Text { | ||
text: `${root.group}` | ||
font.pixelSize: 24 | ||
font.family: "Noto Sans" | ||
font.letterSpacing: -1 | ||
color: fontColor | ||
} | ||
} | ||
} | ||
|
||
Repeater { | ||
id: debugValue | ||
|
||
model: [{ | ||
controllerKey: "beatloop_size", | ||
title: "Beatloop Size" | ||
}, { | ||
controllerKey: "track_samples", | ||
title: "Track sample" | ||
}, { | ||
controllerKey: "track_samplerate", | ||
title: "Track sample rate" | ||
}, { | ||
controllerKey: "playposition", | ||
title: "Play position" | ||
}, { | ||
controllerKey: "rate_ratio", | ||
title: "Rate ratio" | ||
}, { | ||
controllerKey: "waveform_zoom", | ||
title: "Waveform zoom" | ||
} | ||
] | ||
|
||
RowLayout { | ||
id: row | ||
anchors.leftMargin: 6 | ||
anchors.rightMargin: 6 | ||
anchors.topMargin: 6 | ||
anchors.bottomMargin: 6 | ||
Layout.fillWidth: true | ||
Layout.fillHeight: true | ||
spacing: 6 | ||
required property var modelData | ||
|
||
Mixxx.ControlProxy { | ||
id: mixxxValue | ||
group: root.group | ||
key: modelData.controllerKey | ||
} | ||
|
||
Rectangle { | ||
color: 'transparent' | ||
Layout.fillWidth: true | ||
Layout.fillHeight: true | ||
Text { | ||
text: qsTr(modelData.title) | ||
font.pixelSize: 24 | ||
font.family: "Noto Sans" | ||
font.letterSpacing: -1 | ||
color: fontColor | ||
} | ||
} | ||
|
||
Rectangle { | ||
color: 'transparent' | ||
Layout.fillWidth: true | ||
Layout.fillHeight: true | ||
Text { | ||
text: `${mixxxValue.value}` | ||
font.pixelSize: 24 | ||
font.family: "Noto Sans" | ||
font.letterSpacing: -1 | ||
color: fontColor | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
Loader { | ||
id: loader | ||
anchors.fill: parent | ||
sourceComponent: live | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.