Qml 模型-视图-代理(贰)之 动态视图学习

news2024/11/24 10:47:11

目录

动态视图

动态视图用法

⽅向(Orientation) 

键盘导航和⾼亮 

 页眉与页脚

网格视图


 

动态视图

动态视图用法

Repeater 元素适合有限的静态数据, QtQuick 提供了 ListView 和 GridView, 这两个都是基于 Flickable(可滑动) 区域的元素 , ListView 与 Repeater 相比, ListView 使用了一个 model, 使用delegate 来 实例化,并且在两个 delegate之间能够设置间隔 sapcing

 代码:

Component :Component 用于定义一个可以被延迟实例化的QML 对象。可以被用来创建对象模板,这些模板可以在 运行时 根据需要被实例化多次。 通常用于动态创建或销毁对象。比如: 在列表视图中动态加载项目,或者根据用户操作创建新的窗口或对话框:

  • Component 必须有一个子类对象(有且只能有一个),而且在子类对象外不能有任何数据,除了Id。
  • Component  是在QQmlComponent继承而来的,他是由自己的顶层子类(Item、Rectangle)为其他的 动态视图 View提供可视化组件,但它本身是不可见元素

注意: 

由于 QtQuick 默认行为会导致一些问题;列表视图 不会限制  被显示的代理项(delegates) 只在 限制区域内 显示。ListView 通过设置 clip 属性为 true ,来激活裁剪功能。

如果不不设置 滚动时 会显示在区域外

 

⽅向(Orientation 

 使用orientation 来控制 方向

键盘导航和⾼亮
 
使用键盘导航做高亮:
首先使用 focus 属性设置为 true,它设置链表视图能够获得键盘焦点。然后是 highlight 属性,指出使⽤的 ⾼亮代理元素。

键盘导航和⾼亮 

键盘高亮导航效果

完整代码:

import QtQuick 2.15
//模型-视图-代理 --->动态视图(Dynamic Views)
Rectangle {

    // width: 80
    // width: 480
    width: 240
    height: 300


    color: "white"

    //ListView元素只会显⽰部分的链表内容。然后由于QtQuick的默认⾏为导致的问题,列表视图不会限制被显⽰的代理项(delegates)只在限制区域内显⽰
    //着代理项可以在列表视图外显⽰,⽤户可以看⻅在列表视图外动态的创建和销毁这些代理项动态视图(Dynamic Views)(delegates)
    ListView{
        anchors.fill: parent
        anchors.margins: 20

        //,ListView通过设置clip属性为true,来激活裁剪功能
        clip: true

        //链表视图的⽅向由属性orientation控制
        // orientation: ListView.Horizontal

        // layoutDirection: Qt.RightToLeft



        model: 100
        spacing: 5
        delegate: numberDelegate

        highlight: highlightComponent
        //是focus属性设置为true,它设置链表视图能够获得键盘焦点
        focus: true
    }

    Component{
        id: numberDelegate
        // Rectangle{
        //     width: 40
        //     height: 40
        //     color: "lightGreen"

        //     Text {
        //         id: txt
        //         anchors.centerIn: parent
        //         font.pixelSize: 10

        //         text: index
        //     }

        // }

        Item{
            width: 40
            height: 40
            // color: "lightGreen"

            Text {
                id: txt
                anchors.centerIn: parent
                font.pixelSize: 10

                text: index
            }

        }

    }


    // Component{
    //     id: highlightComponent

    //     Rectangle{
    //         width: ListView.view.width
    //         color: "red"
    //     }
    // }


    Component{
        id: highlightComponent

        Item{
            width: ListView.view.width
            height: ListView.view.currentItem.height
            y: ListView.view.currentItem.y

            Behavior on y{
                SequentialAnimation{
                    PropertyAnimation { target: highlightRectangle; property: "opacity"; to: 0; duration: 200 }
                    NumberAnimation { duration: 1 }
                    PropertyAnimation { target: highlightRectangle; property: "opacity"; to: 1; duration: 200 }
                }
            }

            Rectangle{
                id: highlightRectangle
                anchors.fill: parent
                color: "lightGreen"
            }

        }
    }
}

 页眉与页脚

向链表视图中插⼊⼀个⻚眉
header )元素和⼀个⻚脚( footer )元素

注意:页眉与页脚的 代理元素 不遵循链表视图(ListView) 的间隔属性,它们被 直接 放在在的链表 元素上下。页眉与页脚之前的间隔必须通过页眉与页脚元素自己设置。

效果图:

 

完整代码:

import QtQuick 2.15

Rectangle{
    width: 80
    height: 300

    color: 'white'

    ListView{
        anchors.fill: parent
        anchors.margins: 20

        clip: true
        model: 4

        delegate: numberDelegate
        spacing: 5

        header: headerComponent
        footer: footerComponent
    }

    Component{
        id: headerComponent

        Rectangle{
            width: 40
            height: 20

            color: 'yellow'
        }
    }

    Component{
        id: footerComponent
        Rectangle{
            width: 40
            height: 20
            color: 'red'
        }
    }

    Component{
        id: numberDelegate
        Rectangle{
            width: 40
            height: 40
            color: 'lightGreen'

            Text{
                anchors.centerIn: parent
                font.pixelSize: 10
                text: index
            }
        }
    }
}

 

网格视图

用网格视图(GridView)与 使用链表视图(ListVeiw)的方式类似,真正不同的地方是网格视图使用二维数组 存放元素,而链接视图使用的线性链表(一维数组)。

网格视图 不依赖元素间隔和大小 配置元素。它使用单元格宽度(cellWidth)与单元格高度(cellHeight)属性来控制数组内的二维数组的内容。

其它属性用法类似。

 完整代码

import QtQuick 2.15

Rectangle{
    id:root
    width: 400
    height: 400

    color: 'white'

    GridView{
        anchors.fill: parent
        anchors.margins: 20

        clip:  true
        model: 100

        cellWidth: 45
        cellHeight: 45

        delegate: numberDelegate
        // flow: GridView.RightToLeft
        // layoutDirection: GridView.RightToLeft

        header: headerComponent
        footer: footerComponent

    }
    Component{
        id: headerComponent

        Rectangle{
            width: root.width
            height: 20

            color: 'yellow'
        }
    }

    Component{
        id: footerComponent
        Rectangle{

            width: root.width
            height: 20
            color: 'red'
        }
    }

    Component {
        id: numberDelegate
        Rectangle {
            width: 40
            height: 40
            color: "lightGreen"
            Text {
                anchors.centerIn: parent
                font.pixelSize: 10
                text: index

            }


        }

    }
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2238249.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

新标准大学英语综合教程1课后习题答案PDF第三版

《新标准大学英语(第三版)综合教程1 》是“新标准大学英语(第三版)”系列教材之一。本书共包含6个单元,从难度和话题上贴近大一上学生的认知和语言水平,包括与学生个人生活领域和社会文化等相关内容&#x…

Python闭包|你应该知道的常见用例(下)

引言 在 Python 编程语言中,闭包通常指的是一个嵌套函数,即在一个函数内部定义的另一个函数。这个嵌套的函数能够访问并保留其外部函数作用域中的变量。这种结构就构成了一个闭包。 闭包在函数式编程语言中非常普遍。在 Python 中,闭包特别有…

Rocky、Almalinux、CentOS、Ubuntu和Debian系统初始化脚本v9版

Rocky、Almalinux、CentOS、Ubuntu和Debian系统初始化脚本 Shell脚本源码地址: Gitee:https://gitee.com/raymond9/shell Github:https://github.com/raymond999999/shell脚本可以去上面的Gitee或Github代码仓库拉取。 支持的功能和系统&am…

AUTOSAR OS模块详解(一) 概述

AUTOSAR OS模块详解(一) 概述 本文主要介绍AUTOSAR架构下的OS概述。 文章目录 AUTOSAR OS模块详解(一) 概述1 前言1.1 操作系统1.2 嵌入式操作系统1.3 AUTOSAR操作系统 2 AUTOSAR OS2.1 AUTOSAR OS组成2.2 AUTOSAR OS类别2.3 任务管理2.4 调度表2.5 资源管理2.6 多核特性2.7 …

5位机械工程师如何共享一台工作站的算力?

在现代化的工程领域中,算力已成为推动创新与技术进步的关键因素之一。对于机械工程师而言,强大的计算资源意味着能够更快地进行复杂设计、模拟分析以及优化工作,从而明显提升工作效率与项目质量。然而,资源总是有限的,…

Scala 中 set 的实战应用 :图书管理系统

1. 创建书籍集合 首先,我们创建一个可变的书籍集合,用于存储图书馆中的书籍信息。在Scala中,mutable.Set可以用来创建一个可变的集合。 val books mutable.Set("朝花惜拾", "活着") 2. 添加书籍 我们可以使用操作符…

DevCheck Pro手机硬件检测工具v5.33

前言 DevCheck Pro是一款手机硬件和操作系统信息检测查看工具,该软件的功能非常强大,为用户提供了系统、硬件、应用程序、相机、网络、电池等一系列信息查看功能 安装环境 [名称]:DevCheckPro [版本]:5.33 [大小]&a…

cv::intersectConvexConvex返回其中一个输入点集,两个点集不相交

问题:cv::intersectConvexConvex返回其中一个输入点集,但两个点集并不相交 版本:opencv 3.1.0 git上也有人反馈了intersectConvexConvex sometimes returning one of the input polygons in case of empty intersection #10044 是凸包嵌套判…

【刷题12】ctfshow刷题

来源:ctfshow easyPytHon_P 考点:代码审计,源代码查看 打开后查看源码,发现一个源码地址,打开看看 可以知道在此目录下有个flag.txt文件,再观察源码 from flask import request cmd: str request.form.get…

spark的学习-03

RDD的创建的两种方式: 方式一:并行化一个已存在的集合 方法:parallelize 并行的意思 将一个集合转换为RDD 方式二:读取外部共享存储系统 方法:textFile、wholeTextFile、newAPIHadoopRDD等 读取外部存储系统的数…

axios平替!用浏览器自带的fetch处理AJAX(兼容表单/JSON/文件上传)

fetch 是啥? fetch 函数是 JavaScript 中用于发送网络请求的内置 API,可以替代传统的 XMLHttpRequest。它可以发送 HTTP 请求(如 GET、POST 等),并返回一个 Promise,从而简化异步操作 基本用法 /* 下面是…

Linux(CentOS)安装 Nginx

CentOS版本:CentOS 7 Nginx版本:1.24.0 有两种安装方式 一、通过 yum 安装 需要 root 权限,普通用户使用 sudo 进行命令操作 参考:https://nginx.org/en/linux_packages.html#RHEL 1、安装依赖 sudo yum install yum-utils 2…

[原创]手把手教学之前端0基础到就业——day11( Javascript )

文章目录 day11(Javascript)01Javascript①Javascript是什么②JavaScript组成③ Javascript的书写位置1. 行内式 (不推荐)2 . 内部位置使用 ( 内嵌式 )3. 外部位置使用 ( 外链式 ) 02变量1. 什么是变量2. 定义变量及赋值3. 注意事项4. 命名规范 03输入和输出1) 输出形式12) 输出…

【C++笔记】C++三大特性之继承

【C笔记】C三大特性之继承 🔥个人主页:大白的编程日记 🔥专栏:C笔记 文章目录 【C笔记】C三大特性之继承前言一.继承的概念及定义1.1 继承的概念1.2继承的定义1.3继承基类成员访问方式的变化1.4继承类模板 二.基类和派生类间的转…

Colorful/七彩虹iGame G-ONE Plus 12代处理器 Win11原厂OEM系统 带COLORFUL一键还原

安装完毕自带原厂驱动和预装软件以及一键恢复功能,自动重建COLORFUL RECOVERY功能,恢复到新机开箱状态。 【格式】:iso 【系统类型】:Windows11 原厂系统下载网址:http://www.bioxt.cn 注意:安装系统会…

【LeetCode】分发糖果 解题报告

135. 分发糖果 - 题目链接 n个孩子站成一排。给你一个整数数组ratings表示每个孩子的评分。 你需要按照以下要求,给这些孩子分发糖果: 每个孩子至少分配到1个糖果。相邻两个孩子评分更高的孩子会获得更多的糖果。 请你给每个孩子分发糖果,…

ArcGIS从Excel表格文件导入XY数据并定义坐标系与投影的方法

本文介绍在ArcMap软件中,从Excel表格文件中批量导入坐标点数据,将其保存为.shp矢量格式,并定义坐标系、转为投影坐标系的方法。 已知我们有一个Excel表格文件(可以是.xls、.xlsx、.csv等多种不同的表格文件格式)&#…

爬虫 - 二手交易电商平台数据采集 (一)

背景: 近期有一个需求需要采集某电商网站平台的商品数据进行分析。因此,我计划先用Python实现一个简单的版本,以快速测试技术的实现可能性,再用PHP实现一个更完整的版本。文章中涉及的技术仅为学习和测试用途,请勿用于商业或非法用…

「C/C++」C++标准库 之 #include<iostream> 标准输入输出

✨博客主页何曾参静谧的博客📌文章专栏「C/C」C/C程序设计📚全部专栏「VS」Visual Studio「C/C」C/C程序设计「UG/NX」BlockUI集合「Win」Windows程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计「File」数据文件格式「PK」Parasoli…

AI出图,在家装行业杀疯了!

家装行业作为一个庞大的产业,长期以来面临着诸多难题,而随着AIGC技术的蓬勃发展,AI促进家装设计行业迎来了新的春天。 在传统家装设计流程中,相信大家对“设计环节充满了繁琐与复杂”有着非常深刻的体验,设计师需要花…