Files
qt-creator/share/qtcreator/qmldesigner/propertyEditorQmlSources/HelperWidgets/OriginControl.qml
Alessandro Portale 374f84acc7 Qt Quick Designer: License change to Qt Commercial + GPLv3
Change-Id: I7f7aecd02892b6c616cd148fa5d845e7bc0d3b4f
Reviewed-by: Tuukka Turunen <tuukka.turunen@digia.com>
Reviewed-by: Lars Knoll <lars.knoll@theqtcompany.com>
Reviewed-by: Eike Ziller <eike.ziller@theqtcompany.com>
Reviewed-by: Alessandro Portale <alessandro.portale@theqtcompany.com>
2015-09-18 12:12:57 +00:00

233 lines
7.1 KiB
QML

/****************************************************************************
**
** Copyright (C) 2015 The Qt Company Ltd.
** Contact: http://www.qt.io/licensing
**
** This file is part of Qt Creator.
**
** 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 http://www.qt.io/terms-conditions. For further information
** use the contact form at http://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.0 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPLv3 included in the
** packaging of this file. Please review the following information to
** ensure the GNU General Public License version 3.0 requirements will be
** met: http://www.gnu.org/copyleft/gpl.html.
**
****************************************************************************/
import QtQuick 2.1
Item {
width: grid.width
height: grid.height
id: originControl
property variant backendValue
property color highlightColor: "orange"
property color borderColor: colorLogic.textColor
property bool showTranslateCheckBox: true
ExtendedFunctionButton {
backendValue: originControl.backendValue
visible: originControl.enabled
anchors.left: grid.right
}
ColorLogic {
id: colorLogic
backendValue: originControl.backendValue
onValueFromBackendChanged: {
var enumString = originControl.backendValue.enumeration;
if (enumString === "")
enumString = originControl.backendValue.value
grid.select(enumString);
}
}
Grid {
rows: 3
columns: 3
spacing: 5
id: grid
function setValue(myValue) {
originControl.backendValue.setEnumeration("Item", myValue)
}
function select(myValue) {
for (var i = 0; i < grid.children.length; i++) {
grid.children[i].selected = false
}
if (myValue === "TopLeft") {
grid.children[0].selected = true
} else if (myValue === "Top") {
grid.children[1].selected = true
} else if (myValue === "TopRight") {
grid.children[2].selected = true
} else if (myValue === "Left") {
grid.children[3].selected = true
} else if (myValue === "Center") {
grid.children[4].selected = true
} else if (myValue === "Right") {
grid.children[5].selected = true
} else if (myValue === "BottomLeft") {
grid.children[6].selected = true
} else if (myValue === "Bottom") {
grid.children[7].selected = true
} else if (myValue === "BottomRight") {
grid.children[8].selected = true
}
}
Rectangle {
property bool selected: false
id: topLeft
width: 15
height: 15
color: selected ? "#4f4f4f" : "black"
border.color: originControl.borderColor
border.width: selected ? 2 : 0
MouseArea {
anchors.fill: parent
onClicked: {
grid.setValue("TopLeft")
}
}
}
Rectangle {
property bool selected: false
width: topLeft.width
height: topLeft.height
color: selected ? "#4f4f4f" : "black"
border.width: selected ? 2 : 0
border.color: originControl.borderColor
MouseArea {
anchors.fill: parent
onClicked: {
grid.setValue("Top")
}
}
}
Rectangle {
property bool selected: false
width: topLeft.width
height: topLeft.height
color: selected ? "#4f4f4f" : "black"
border.width: selected ? 2 : 0
border.color: originControl.borderColor
MouseArea {
anchors.fill: parent
onClicked: {
grid.setValue("TopRight")
}
}
}
Rectangle {
property bool selected: false
width: topLeft.width
height: topLeft.height
color: selected ? "#4f4f4f" : "black"
border.width: selected ? 2 : 0
border.color: originControl.borderColor
MouseArea {
anchors.fill: parent
onClicked: {
grid.setValue("Left")
}
}
}
Rectangle {
property bool selected: false
width: topLeft.width
height: topLeft.height
color: selected ? "#4f4f4f" : "black"
border.width: selected ? 2 : 0
border.color: originControl.borderColor
MouseArea {
anchors.fill: parent
onClicked: {
grid.setValue("Center")
}
}
}
Rectangle {
property bool selected: false
width: topLeft.width
height: topLeft.height
color: selected ? "#4f4f4f" : "black"
border.width: selected ? 2 : 0
border.color: originControl.borderColor
MouseArea {
anchors.fill: parent
onClicked: {
grid.setValue("Right")
}
}
}
Rectangle {
property bool selected: false
width: topLeft.width
height: topLeft.height
color: selected ? "#4f4f4f" : "black"
border.width: selected ? 2 : 0
border.color: originControl.borderColor
MouseArea {
anchors.fill: parent
onClicked: {
grid.setValue("BottomLeft")
}
}
}
Rectangle {
property bool selected: false
width: topLeft.width
height: topLeft.height
color: selected ? "#4f4f4f" : "black"
border.width: selected ? 2 : 0
border.color: originControl.borderColor
MouseArea {
anchors.fill: parent
onClicked: {
grid.setValue("Bottom")
}
}
}
Rectangle {
property bool selected: false
width: topLeft.width
height: topLeft.height
color: selected ? "#4f4f4f" : "black"
border.width: selected ? 2 : 0
border.color: originControl.borderColor
MouseArea {
anchors.fill: parent
onClicked: {
grid.setValue("BottomRight")
}
}
}
}
}