diff options
Diffstat (limited to 'imports/shared/controls/Tool.qml')
-rw-r--r-- | imports/shared/controls/Tool.qml | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/imports/shared/controls/Tool.qml b/imports/shared/controls/Tool.qml new file mode 100644 index 0000000..ce874a7 --- /dev/null +++ b/imports/shared/controls/Tool.qml @@ -0,0 +1,64 @@ +/**************************************************************************** +** +** Copyright (C) 2016 Pelagicore AG +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the Neptune IVI UI. +** +** $QT_BEGIN_LICENSE:GPL-QTAS$ +** Commercial License Usage +** Licensees holding valid commercial Qt Automotive Suite 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$ +** +** SPDX-License-Identifier: GPL-3.0 +** +****************************************************************************/ + +import QtQuick 2.0 +import controls 1.0 +import utils 1.0 + +UIElement { + id: root + hspan: 1 + vspan: 2 + property alias name: icon.name + property alias size: icon.size + property bool active + scale: area.pressed ? 1.1 : 1.0 + Behavior on scale { NumberAnimation { duration: 25 } } + + signal clicked() + + function toggle() { + active = !active + } + + Symbol { + id: icon + anchors.fill: parent + active: area.pressed || root.active + opacity: 0.75 + } + + MouseArea { + id: area + anchors.fill: parent + onClicked: root.clicked() + } +} |