Qt/QML学习-RangeSlider

QML学习

main.qml

import QtQuick 2.15
import QtQuick.Window 2.15
import QtQuick.Controls 2.15

Window {
    width: 640
    height: 480
    visible: true
    title: qsTr("RangeSlider")

    RangeSlider {
        id: rangeSlider
        from: 0
        to: 100
        first {
            value: 10
            handle: Rectangle {
                implicitWidth: 30
                implicitHeight: 30
                border.width: 1
                x: rangeSlider.leftPadding
                   + rangeSlider.first.visualPosition
                   * (rangeSlider.availableWidth - width)
                y: rangeSlider.height / 2 - height / 2
                Text {
                    anchors.centerIn: parent
                    font.pointSize: 15
                    text: rangeSlider.first.value.toFixed(0)
                }
            }
        }
        second {
            value: 90
            handle: Rectangle {
                implicitWidth: 30
                implicitHeight: 30
                border.width: 1
                x: rangeSlider.leftPadding
                   + rangeSlider.second.visualPosition
                   * (rangeSlider.availableWidth - width)
                y: rangeSlider.height / 2 - height / 2
                Text {
                    anchors.centerIn: parent
                    font.pointSize: 15
                    text: rangeSlider.second.value.toFixed(0)
                }
            }
        }
        background: Rectangle {
            implicitWidth: 200
            implicitHeight: 40
            border.width: 1
            Rectangle {
                width: parent.width - rangeSlider.leftPadding
                       - rangeSlider.rightPadding
                height: 10
                radius: 5
                anchors.centerIn: parent
                color: "black"
            }
            Rectangle {
                x: rangeSlider.first.visualPosition * parent.width
                   + rangeSlider.leftPadding
                width: rangeSlider.second.visualPosition * parent.width
                       - x - rangeSlider.rightPadding
                height: 10
                anchors.verticalCenter: parent.verticalCenter
                color: "red"
            }
        }
    }
}

演示

视频讲解

相关推荐
Alueaxten(上学版)1 小时前
【软考】程序设计语言基础
经验分享·笔记·学习·软件工程·软考
walfar1 小时前
动手学深度学习(pytorch)学习记录29-网络中的网络(NiN)[学习记录]
pytorch·深度学习·学习
不染_是非2 小时前
Django学习实战篇三(适合略有基础的新手小白学习)(从0开发项目)
数据库·后端·学习·django·web
&&Citrus2 小时前
【Petri网导论学习笔记】Petri网导论入门学习(三)
笔记·学习·算法·入门·petri网·petri
凯U编程2 小时前
QT——事件处理机制(9.10)
开发语言·qt
林夕072 小时前
【C++\Qt项目实战】俄罗斯方块
c++·qt·项目实战·俄罗斯方块
自自Z2 小时前
9月11日:QT
开发语言·qt
艾伦~耶格尔3 小时前
常用Java API
java·开发语言·学习
yiyiy111yiy3 小时前
关于Harmony的学习
前端·javascript·学习·原型模式
天马行空工作坊3 小时前
Autosar学习----AUTOSAR_SWS_BSWGeneral(二)
运维·服务器·学习·架构·汽车·汽车电子