Flat风格的Qml轮选框

基于Qml的SpinBox控件修改而成。

demo.gif

轮选框代码

import QtQuick 2.0
import QtQuick.Controls 2.0
import QtGraphicalEffects 1.0

SpinBox {
    id: root

    property color color: "#3498DB"

    value: 50
    editable: true

    contentItem: TextInput {
        text: root.value

        font.pixelSize: 15
        font.family: "Arial"
        font.weight: Font.Thin

        horizontalAlignment: Qt.AlignHCenter
        verticalAlignment: Qt.AlignVCenter

        readOnly: !root.editable
        validator: root.validator
    }

    up.indicator: Rectangle {
        x: root.mirrored ? 0 : parent.width - width
        implicitWidth: 37
        implicitHeight: implicitWidth
        color: root.up.pressed ? "#EBEDEF" : root.color

        Text {
            text: "+"
            anchors.fill: parent
            color: root.up.pressed ? root.color : "white"

            font.bold: true
            font.pixelSize: root.font.pixelSize * 2
            fontSizeMode: Text.Fit

            horizontalAlignment: Text.AlignHCenter
            verticalAlignment: Text.AlignVCenter
        }
    }

    down.indicator: Rectangle {
        x: root.mirrored ? parent.width - width : 0
        implicitWidth: root.up.indicator.implicitWidth
        implicitHeight: implicitWidth
        color: root.down.pressed ? "#EBEDEF" : root.color

        Text {
            text: "-"
            anchors.fill: parent
            color: root.down.pressed ? root.color : "white"

            font.bold: true
            font.pixelSize: root.font.pixelSize * 2
            fontSizeMode: Text.Fit

            horizontalAlignment: Text.AlignHCenter
            verticalAlignment: Text.AlignVCenter
        }
    }

    background: Rectangle {
        implicitWidth: 138
        border.color: "#EBEDEF"

        layer.enabled: root.hovered
        layer.effect: DropShadow {
            id: dropShadow
            transparentBorder: true
            color: "#EEF2F7"
            samples: 8 
        }
    }
}

轮选框样式代码

main_page2.png
GridLayout {
    width: root.width
    rows: 3
    columns: 3

    Repeater {
        model: ["#727CF5", "#0ACF97", "#F9375E",
                "#FFBC00", "#2B99B9", "#5A6268",
                "#EEF2F7", "#212730", "#3498DB"]

        SpinBox {
            value: Math.random() * 10
            color: modelData
        }
    }
}
  • 更多精彩内容请关注公众号Qt君
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 如果有人问我,你最喜欢的明星是谁啊?我一定会毫不犹豫的骄傲的告诉他:杨幂,她是我的偶像,是我最最喜欢的姑娘啊。 今...
    橙子NY阅读 423评论 1 1
  • 记得有一次,我打鼓刚刚回来,姐姐便羡慕地对我说:“成成,我也想去打鼓,你下次去问问老师我可不可以学呢?要不,...
    阳光成子阅读 133评论 0 2
  • 周五晚上下班,去超市买上一箱科罗娜啤酒,再称上两个柠檬。她拧着两个柠檬在前面,我抱着啤酒在后边,一同往地下车库走着...
    阳光小渣T阅读 142评论 0 0