1/**************************************************************************** 2** 3** Copyright (C) 2017 The Qt Company Ltd. 4** Contact: https://www.qt.io/licensing/ 5** 6** This file is part of the examples of the Qt Toolkit. 7** 8** $QT_BEGIN_LICENSE:BSD$ 9** Commercial License Usage 10** Licensees holding valid commercial Qt licenses may use this file in 11** accordance with the commercial license agreement provided with the 12** Software or, alternatively, in accordance with the terms contained in 13** a written agreement between you and The Qt Company. For licensing terms 14** and conditions see https://www.qt.io/terms-conditions. For further 15** information use the contact form at https://www.qt.io/contact-us. 16** 17** BSD License Usage 18** Alternatively, you may use this file under the terms of the BSD license 19** as follows: 20** 21** "Redistribution and use in source and binary forms, with or without 22** modification, are permitted provided that the following conditions are 23** met: 24** * Redistributions of source code must retain the above copyright 25** notice, this list of conditions and the following disclaimer. 26** * Redistributions in binary form must reproduce the above copyright 27** notice, this list of conditions and the following disclaimer in 28** the documentation and/or other materials provided with the 29** distribution. 30** * Neither the name of The Qt Company Ltd nor the names of its 31** contributors may be used to endorse or promote products derived 32** from this software without specific prior written permission. 33** 34** 35** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 36** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 37** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 38** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 39** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 40** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 41** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 42** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 43** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 44** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 45** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE." 46** 47** $QT_END_LICENSE$ 48** 49****************************************************************************/ 50 51import QtQuick 2.0 52 53Item { 54 id: slider; width: 400; height: 16 55 56 // value is read/write. 57 property real value 58 onValueChanged: { handle.x = 2 + (value - minimum) * slider.xMax / (maximum - minimum); } 59 property real maximum: 1 60 property real minimum: 1 61 property int xMax: slider.width - handle.width - 4 62 63 Rectangle { 64 anchors.fill: parent 65 border.color: "white"; border.width: 0; radius: 8 66 gradient: Gradient { 67 GradientStop { position: 0.0; color: "#66343434" } 68 GradientStop { position: 1.0; color: "#66000000" } 69 } 70 } 71 72 Rectangle { 73 id: handle; smooth: true 74 x: slider.width / 2 - handle.width / 2; y: 2; width: 30; height: slider.height-4; radius: 6 75 gradient: Gradient { 76 GradientStop { position: 0.0; color: "lightgray" } 77 GradientStop { position: 1.0; color: "gray" } 78 } 79 80 MouseArea { 81 anchors.fill: parent; drag.target: parent 82 drag.axis: Drag.XAxis; drag.minimumX: 2; drag.maximumX: slider.xMax+2 83 onPositionChanged: { value = (maximum - minimum) * (handle.x-2) / slider.xMax + minimum; } 84 } 85 } 86} 87