• Qml 实现星级评分组件 已发布


    【写在前面】

    在现代应用程序中,星级评分是一个常见的用户界面元素,它允许用户对产品、服务或内容进行评价。

    想必大家在用各种带有评分的软件中看到过这个组件:

    image

    本文将指导你如何使用 Qml 创建一个简单而美观的星级评分组件,并且支持高度自定义。


    【正文开始】

    先来看看效果图:

    image

    现在开始讲解思路:

    首先,我们需要考虑半星的情况,因此可以分为三个部分:

    image

    1、红色部分:满填充星星【fillDelegate】。

    2、绿色部分:半填充星星【halfDelegate】。

    3、蓝色部分:无填充星星【emptyDelegate】。

    这三部分都是通过代理实现的,因此如果需要自定义,则必须提供这三个组件:

        property Component fillDelegate: Component {
            Text {
                text: fillIcon
                color: root.iconColor
                font.family: fontAwesome.name
                font.pixelSize: iconFontSize
            }
        }
        property Component emptyDelegate: Component {
            Text {
                text: emptyIcon
                color: root.iconColor
                font.family: fontAwesome.name
                font.pixelSize: iconFontSize
            }
        }
        property Component halfDelegate: Component {
            Text {
                text: halfIcon
                color: root.iconColor
                font.family: fontAwesome.name
                font.pixelSize: iconFontSize
            }
        }
    

    接下来,我们需要计算每个部分的数量,其中半星必然只有一颗( 如果有 ):

        property int fillCount: Math.floor(root.value)
        property int emptyStartIndex: Math.round(root.value)
        property bool hasHalf: root.value - fillCount > 0
    

    然后用 Repeater + Loader 载入即可:

        Repeater {
            id: repeater
            model: root.count
            delegate: MouseArea {
                id: rootItem
                width: root.iconSize
                height: root.iconSize
                hoverEnabled: true
                onEntered: hovered = true;
                onExited: hovered = false;
                onClicked: {
                    root.isDone = !root.isDone;
                    if (root.isDone) {
                        __private.doneValue = root.value;
                        root.done(__private.doneValue);
                    }
                }
                onPositionChanged: function(mouse) {
                    if (root.allowHalf) {
                        if (mouse.x > (width * 0.5)) {
                            root.value = index + 1;
                        } else {
                            root.value = index + 0.5;
                        }
    
                    } else {
                        root.value = index + 1;
                    }
                }
                property bool hovered: false
    
                Loader {
                    active: index < repeater.fillCount
                    sourceComponent: fillDelegate
                    property bool hovered: rootItem.hovered
                }
    
                Loader {
                    active: repeater.hasHalf && index === (repeater.emptyStartIndex - 1)
                    sourceComponent: halfDelegate
                    property bool hovered: rootItem.hovered
                }
    
                Loader {
                    active: index >= repeater.emptyStartIndex
                    sourceComponent: emptyDelegate
                    property bool hovered: rootItem.hovered
                }
            }
    
            property int fillCount: Math.floor(root.value)
            property int emptyStartIndex: Math.round(root.value)
            property bool hasHalf: root.value - fillCount > 0
        }
    

    至此,核心部分讲解完了,其他部分直接看源码即可。


    【结语】

    最后:项目链接(多多star呀..⭐_⭐):

    Github 地址:https://github.com/mengps/QmlControls/tree/master/Rate


    __EOF__

  • 本文作者: 梦起丶
  • 本文链接: https://www.cnblogs.com/mengps/p/18415411
  • 关于博主:

    🎉🎉🎉专注于 C / C++ / Qt / JS / Python 编程技巧🎉🎉🎉

    ✨个人微信✨:MenPenS612 (交流合作都行~)

    ✨交流群✨:83986890 ヾ( ̄▽ ̄)欢迎来玩~

    ✨公众号✨:程序梦 (扫左侧二维码)

  • 版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
  • 声援博主: 如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。
  • 相关阅读:
    使用Java将PPT、PPTX和PDF转换为图片
    nginx目录穿越
    【Swift 60秒】08 - Simple types:Summary
    4月平板电脑行业线上销售数据分析
    二维数组多次排序 或 嵌套list多次排序
    驱动开发 day9
    Java面试丨Redis从基础到源码面试题(参考答案)
    GO微服务实战第三十二节 如何使用 ELK 进行日志采集以及统一处理?
    大模型日报|11 篇必读的大模型论文
    【源码解读】VUE2.0和VUE3.0响应式区别?
  • 原文地址:https://www.cnblogs.com/mengps/p/18415411