mirror of
https://github.com/Serial-Studio/Serial-Studio.git
synced 2025-01-15 05:22:53 +08:00
300 lines
8.0 KiB
QML
300 lines
8.0 KiB
QML
/*
|
|
* Copyright (c) 2020-2021 Alex Spataru <https://github.com/alex-spataru>
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
|
|
import QtQuick 2.12
|
|
import QtQuick.Window 2.12
|
|
import QtQuick.Layouts 1.12
|
|
import QtQuick.Controls 2.12
|
|
|
|
import Qt.labs.settings 1.0
|
|
|
|
import "Windows"
|
|
|
|
ApplicationWindow {
|
|
id: app
|
|
|
|
//
|
|
// Global properties
|
|
//
|
|
readonly property int spacing: 8
|
|
property bool firstValidPacket: false
|
|
readonly property color windowBackgroundColor: "#121920"
|
|
readonly property string monoFont: {
|
|
switch (Qt.platform.os) {
|
|
case "osx":
|
|
return "Menlo"
|
|
case "windows":
|
|
return "Consolas"
|
|
default:
|
|
return "Monospace"
|
|
}
|
|
}
|
|
|
|
//
|
|
// Window geometry
|
|
//
|
|
visible: false
|
|
minimumWidth: 1080
|
|
minimumHeight: 660
|
|
title: CppAppName + " v" + CppAppVersion
|
|
|
|
//
|
|
// Theme options
|
|
//
|
|
palette.text: "#fff"
|
|
palette.buttonText: "#fff"
|
|
palette.windowText: "#fff"
|
|
palette.window: app.windowBackgroundColor
|
|
|
|
//
|
|
// Startup code
|
|
//
|
|
Component.onCompleted: {
|
|
timer.start()
|
|
|
|
about.hide()
|
|
devices.show()
|
|
|
|
data.opacity = 0
|
|
terminal.opacity = 1
|
|
widgets.opacity = 0
|
|
|
|
CppJsonGenerator.readSettings()
|
|
}
|
|
|
|
//
|
|
// Clears the console text & displays a mini-tutorial
|
|
//
|
|
function showWelcomeGuide() {
|
|
terminal.text = CppTranslator.welcomeConsoleText() + "\n\n"
|
|
}
|
|
|
|
//
|
|
// Startup timer
|
|
//
|
|
Timer {
|
|
id: timer
|
|
interval: 500
|
|
onTriggered: {
|
|
// Startup verifications to ensure that bad settings
|
|
// do not make our app reside outside screen
|
|
if (x < 0 || x >= Screen.desktopAvailableWidth)
|
|
x = 100
|
|
if (y < 0 || y >= Screen.desktopAvailableHeight)
|
|
y = 100
|
|
|
|
// Startup verifications to ensure that app fits in current screen
|
|
if (width > Screen.desktopAvailableWidth) {
|
|
x = 100
|
|
width = Screen.desktopAvailableWidth - x
|
|
}
|
|
|
|
// Startup verifications to ensure that app fits in current screen
|
|
if (height > Screen.desktopAvailableHeight) {
|
|
y = 100
|
|
height = Screen.desktopAvailableHeight - y
|
|
}
|
|
|
|
// Show app window
|
|
app.visible = true
|
|
app.showWelcomeGuide()
|
|
}
|
|
}
|
|
|
|
//
|
|
// Hide console & device manager when we receive first valid packet
|
|
//
|
|
Connections {
|
|
target: CppJsonGenerator
|
|
enabled: !app.firstValidPacket
|
|
function onPacketReceived() {
|
|
app.firstValidPacket = true
|
|
uiConfigTimer.start()
|
|
}
|
|
} Timer {
|
|
id: uiConfigTimer
|
|
interval: 250
|
|
onTriggered: {
|
|
devices.hide()
|
|
toolbar.dataClicked()
|
|
}
|
|
}
|
|
|
|
//
|
|
// Show console tab on serial disconnect
|
|
//
|
|
Connections {
|
|
target: CppDataProvider
|
|
function onDataReset() {
|
|
toolbar.consoleClicked()
|
|
devices.show()
|
|
app.firstValidPacket = false
|
|
}
|
|
}
|
|
|
|
//
|
|
// Save window size & position
|
|
//
|
|
Settings {
|
|
property alias appX: app.x
|
|
property alias appY: app.y
|
|
property alias appW: app.width
|
|
property alias appH: app.height
|
|
}
|
|
|
|
//
|
|
// About window
|
|
//
|
|
About {
|
|
id: about
|
|
}
|
|
|
|
//
|
|
// Main layout
|
|
//
|
|
ColumnLayout {
|
|
spacing: 0
|
|
anchors.fill: parent
|
|
|
|
Toolbar {
|
|
z: 1
|
|
id: toolbar
|
|
Layout.fillWidth: true
|
|
Layout.minimumHeight: 48
|
|
Layout.maximumHeight: 48
|
|
dataChecked: data.visible
|
|
aboutChecked: about.visible
|
|
consoleChecked: terminal.visible
|
|
widgetsChecked: widgets.visible
|
|
devicesChecked: devices.visible
|
|
onAboutClicked: about.visible ? about.hide() : about.show()
|
|
onDevicesClicked: devices.visible ? devices.hide() : devices.show()
|
|
|
|
onDataClicked: {
|
|
data.opacity = 1
|
|
terminal.opacity = 0
|
|
widgets.opacity = 0
|
|
dataChecked = true
|
|
consoleChecked = false
|
|
widgetsChecked = false
|
|
}
|
|
|
|
onConsoleClicked: {
|
|
data.opacity = 0
|
|
terminal.opacity = 1
|
|
widgets.opacity = 0
|
|
consoleChecked = true
|
|
dataChecked = false
|
|
widgetsChecked = false
|
|
}
|
|
|
|
onWidgetsClicked: {
|
|
data.opacity = 0
|
|
terminal.opacity = 0
|
|
widgets.opacity = 1
|
|
dataChecked = false
|
|
widgetsChecked = true
|
|
consoleChecked = false
|
|
}
|
|
}
|
|
|
|
RowLayout {
|
|
spacing: 0
|
|
clip: true
|
|
Layout.fillWidth: true
|
|
Layout.fillHeight: true
|
|
|
|
Item {
|
|
Layout.fillWidth: true
|
|
Layout.fillHeight: true
|
|
|
|
Console {
|
|
id: terminal
|
|
anchors.fill: parent
|
|
|
|
// Animate on show
|
|
enabled: opacity > 0
|
|
visible: opacity > 0
|
|
Behavior on opacity {NumberAnimation{}}
|
|
|
|
// Show translated welcome text on lang. change
|
|
Connections {
|
|
target: CppTranslator
|
|
function onLanguageChanged() {
|
|
app.showWelcomeGuide()
|
|
}
|
|
}
|
|
}
|
|
|
|
DataGrid {
|
|
id: data
|
|
anchors.fill: parent
|
|
|
|
// Animate on show
|
|
visible: opacity > 0
|
|
Behavior on opacity {NumberAnimation{}}
|
|
}
|
|
|
|
Widgets {
|
|
id: widgets
|
|
anchors.fill: parent
|
|
|
|
// Animate on show
|
|
enabled: opacity > 0
|
|
visible: opacity > 0
|
|
Behavior on opacity {NumberAnimation{}}
|
|
}
|
|
}
|
|
|
|
DeviceManager {
|
|
id: devices
|
|
property int displayedWidth: 320
|
|
|
|
function show() {
|
|
opacity = 1
|
|
displayedWidth = 320
|
|
}
|
|
|
|
function hide() {
|
|
opacity = 0
|
|
displayedWidth = 0
|
|
}
|
|
|
|
visible: opacity > 0
|
|
Layout.fillHeight: true
|
|
Layout.minimumWidth: displayedWidth
|
|
Layout.maximumWidth: displayedWidth
|
|
|
|
Behavior on opacity {NumberAnimation{}}
|
|
Behavior on displayedWidth {NumberAnimation{}}
|
|
}
|
|
}
|
|
}
|
|
|
|
//
|
|
// CSV player window
|
|
//
|
|
CsvPlayer {
|
|
id: csvPlayer
|
|
}
|
|
}
|