Qt qml 滑块

核心代码:


    property int stepSize;
    property int offset;

    ListView {
        id: list;
        anchors.left: editBox.left;
        anchors.bottom: editBox.top;
        anchors.top: parent.top
        anchors.topMargin: 19
        width: 552;
        clip: true;

        model: c_detailListModel;  
        delegate: messageItemDelegate;


        //滑块
                onContentYChanged: {
                    var total = (list.contentHeight > list.height)?(list.contentHeight - list.height): list.height;
                    var percent = 100 * contentY / total;
                    if(percent < 0)
                        percent = 0;
                    if(percent > 100)
                        percent = 100;
                    offset = percent * (slider.height - stepSize) / 100;
                    console.log("onContentYChanged contentY:", contentY, " offset", offset, "total:", total, "stepSize:", stepSize);
                }
                onContentHeightChanged: {
                    stepSize = slider.height * list.height / list.contentHeight;
                    if(stepSize > slider.height)
                        stepSize = slider.height;
                }
    }


    //滑块
        Rectangle {
            id: slider;
            width: 5;
            anchors.top: list.top;
            anchors.topMargin: 9;
            anchors.bottom: list.bottom;
            anchors.bottomMargin: 9;
            anchors.right: list.right;
            anchors.rightMargin: 15;
            color: "transparent";


            Rectangle {
                id: control;
                color: "gray";
                opacity: 0.4;
                width: slider.width;
                height: stepSize;
                y: offset;
                radius: 8;
            }
        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值