/****************************************************************************
**
** Copyright (C) 2021 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of Qt Quick Designer Components.
**
** $QT_BEGIN_LICENSE:GPL$
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 or (at your option) any later version
** approved by the KDE Free Qt Foundation. The licenses are as published by
** the Free Software Foundation and appearing in the file LICENSE.GPL3
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
** $QT_END_LICENSE$
**
****************************************************************************/
import QtQuick 2.15
import QtQuick.Layouts 1.15
import HelperWidgets 2.0
import StudioTheme 1.0 as StudioTheme
Column {
anchors.left: parent.left
anchors.right: parent.right
Section {
caption: qsTr("Arc Item")
anchors.left: parent.left
anchors.right: parent.right
SectionLayout {
PropertyLabel {
text: qsTr("Fill color")
tooltip: qsTr("Sets the color inside the Arc stroke. This only works if the Full outline option is selected and the Arc stroke is not thick enough to fill the space.")
}
ColorEditor {
backendValue: backendValues.fillColor
supportGradient: true
shapeGradients: true
}
PropertyLabel {
text: qsTr("Stroke color")
tooltip: qsTr("Sets the color of the Arc.")
}
ColorEditor {
backendValue: backendValues.strokeColor
supportGradient: false
}
PropertyLabel {
text: qsTr("Stroke width")
tooltip: qsTr("Sets the thickness of the Arc.")
}
SecondColumnLayout {
SpinBox {
id: strokeWidthSpinBox
implicitWidth: StudioTheme.Values.twoControlColumnWidth
+ StudioTheme.Values.actionIndicatorWidth
backendValue: backendValues.strokeWidth
decimals: 1
minimumValue: -1
maximumValue: 200
stepSize: 1
property real previousValue: 0
onValueChanged: {
if (strokeWidthSpinBox.value > 0)
strokeWidthSpinBox.previousValue = strokeWidthSpinBox.value
}
Component.onCompleted: strokeWidthSpinBox.previousValue
= Math.max(1, backendValues.strokeWidth.value)
}
Spacer {
implicitWidth: StudioTheme.Values.twoControlColumnGap
+ StudioTheme.Values.actionIndicatorWidth
}
CheckBox {
id: strokeWidthCheckBox
text: qsTr("Hide")
implicitWidth: StudioTheme.Values.twoControlColumnWidth
checked: (backendValues.strokeWidth.value < 0)
actionIndicator.visible: false
onCheckedChanged: backendValues.strokeWidth.value
= (strokeWidthCheckBox.checked ? -1 : strokeWidthSpinBox.previousValue)
}
ExpandingSpacer {}
}
PropertyLabel {
text: qsTr("Arc start")
tooltip: qsTr("Sets the start angle of the Arc.")
}
SecondColumnLayout {
SpinBox {
implicitWidth: StudioTheme.Values.twoControlColumnWidth
+ StudioTheme.Values.actionIndicatorWidth
backendValue: backendValues.begin
decimals: 1
minimumValue: -720
maximumValue: 720
stepSize: 1
}
Spacer { implicitWidth: StudioTheme.Values.controlLabelGap }
ControlLabel { text: "°" }
ExpandingSpacer {}
}
PropertyLabel {
text: qsTr("Arc end")
tooltip: qsTr("Sets the end angle of the Arc.")
}
SecondColumnLayout {
SpinBox {
implicitWidth: StudioTheme.Values.twoControlColumnWidth
+ StudioTheme.Values.actionIndicatorWidth
backendValue: backendValues.end
decimals: 1
minimumValue: -720
maximumValue: 720
stepSize: 1
}
Spacer { implicitWidth: StudioTheme.Values.controlLabelGap }
ControlLabel { text: "°" }
ExpandingSpacer {}
}
}
}
StrokeDetailsSection {}
Section {
caption: qsTr("Outline")
anchors.left: parent.left
anchors.right: parent.right
SectionLayout {
PropertyLabel {
text: qsTr("Outline width")
tooltip: qsTr("Sets the width of the outline that follows the Arc.")
}
SecondColumnLayout {
SpinBox {
implicitWidth: StudioTheme.Values.twoControlColumnWidth
+ StudioTheme.Values.actionIndicatorWidth
backendValue: backendValues.arcWidth
decimals: 1
minimumValue: 0
maximumValue: backendValues.maxArcWidth.value
stepSize: 1
}
Spacer { implicitWidth: StudioTheme.Values.twoControlColumnGap }
CheckBox {
text: qsTr("Full outline")//backendValues.outlineArc.valueToString
implicitWidth: StudioTheme.Values.twoControlColumnWidth
+ StudioTheme.Values.actionIndicatorWidth
backendValue: backendValues.outlineArc
}
ExpandingSpacer {}
}
PropertyLabel {
text: qsTr("Round outline")
tooltip: qsTr("Toggles the Full outline to have rounded edges.")
}
SecondColumnLayout {
CheckBox {
text: backendValues.round.valueToString
implicitWidth: StudioTheme.Values.twoControlColumnWidth
+ StudioTheme.Values.actionIndicatorWidth
backendValue: backendValues.round
}
ExpandingSpacer {}
}
PropertyLabel {
text: qsTr("Round start")
tooltip: qsTr("Toggles the starting edge of the Full outline to be rounded.")
}
SecondColumnLayout {
CheckBox {
text: backendValues.roundBegin.valueToString
implicitWidth: StudioTheme.Values.twoControlColumnWidth
+ StudioTheme.Values.actionIndicatorWidth
backendValue: backendValues.roundBegin
}
ExpandingSpacer {}
}
PropertyLabel {
text: qsTr("Round end")
tooltip: qsTr("Toggles the end edge of the Full outline to be rounded.")
}
SecondColumnLayout {
CheckBox {
text: backendValues.roundEnd.valueToString
implicitWidth: StudioTheme.Values.twoControlColumnWidth
+ StudioTheme.Values.actionIndicatorWidth
backendValue: backendValues.roundEnd
}
ExpandingSpacer {}
}
}
}
}