QML面试笔记--UI设计篇05容器控件

news2025/5/13 2:15:18
  • 1. QML中容器控件全解:构建灵活界面的基石
    • 1.1. Item(万物容器)
    • 1.2. Rectangle(视觉容器)
    • 1.3. ListView(动态列表容器)
    • 1.4. Frame(表单容器)
    • 1.5. SwipeView(页面容器)
    • 1.6. TabBar(导航容器)
    • 1.7. SwipeView 和 TabBar 的区别
      • 1.7.1. 功能和交互方式
      • 1.7.2. 交互方式
      • 1.7.3. 视觉表现
      • 1.7.4. 适用场景
  • 2. 容器设计黄金法则

1. QML中容器控件全解:构建灵活界面的基石

在智能设备井喷的时代,QML容器控件如同"数字乐高",通过巧妙的组合艺术,将简单元素转化为功能强大的交互界面。

本篇将揭秘工业HMI、车载中控等专业场景中最核心的容器控件,带您掌握界面架构设计的精髓。

1.1. Item(万物容器)

设计哲学‌:

作为QML世界的"原子单位",Item是其他所有控件的基类,承担着‌界面元素组织者‌的角色。


Item {

    id: sensorGroup
    width: 300; height: 200
    
    // 组合多个传感器显示模块
    TemperatureDisplay { anchors.left: parent.left }
    PressureIndicator { anchors.right: parent.right }
    StatusLed {
        anchors.horizontalCenter: parent.horizontalCenter
        anchors.bottom: parent.bottom
    }
    
    // 统一控制可见性
    visible: systemStatus === "normal"
}

实战技巧‌:

通过visible属性实现整体显隐控制

使用anchors进行相对定位

作为自定义组件的基容器

1.2. Rectangle(视觉容器)

工业场景‌:

在设备状态看板中,用于创建带背景色的信息区块,提升界面层次感。




Rectangle {

    radius: 8
    border.color: "#2196F3"
    color: "#E3F2FD"
    
    Column {
        spacing: 10
        anchors.fill: parent
        padding: 15
        
        Text { text: "电机状态监控"; font.bold: true }
        ProgressBar { value: motorStatus.speed }
        Row {
            spacing: 5
            CheckBox { text: "过热保护" }
            CheckBox { text: "震动报警" }
        }
    }
}

设计规范‌:

使用radius实现圆角现代化设计

通过嵌套布局构建复合组件

用颜色区分不同功能区域

1.3. ListView(动态列表容器)

车载系统应用‌:

用于音乐列表、导航历史等需要‌动态加载‌的滚动列表。


ListView {

    width: 240
    height: 300
    model: musicListModel
    spacing: 2
    clip: true
    
    delegate: Rectangle {
        width: ListView.view.width
        height: 40
        color: index%2 ? "#FAFAFA" : "white"
        
        Text {
            text: model.title
            anchors.verticalCenter: parent.verticalCenter
            color: model.isPlaying ? "#2196F3" : "black"
        }
        
        MouseArea {
            anchors.fill: parent
            onClicked: musicPlayer.selectTrack(model.id)
        }
    }
    
    ScrollBar.vertical: ScrollBar { policy: ScrollBar.AlwaysOn }
}

性能优化‌:

使用clip:true防止渲染溢出

通过delegate复用机制提升性能

集成自定义滚动条

1.4. Frame(表单容器)

医疗设备应用‌:

用于参数设置面板等需要明确视觉边界的表单组合。


Frame {

    background: Rectangle {
        color: "#FFF3E0"
        border.color: "#FFA726"
        radius: 4
    }
    
    ColumnLayout {
        spacing: 12
        
        TextField {
            placeholderText: "患者ID"
            Layout.fillWidth: true
        }
        
        Slider {
            id: pressureSlider
            from: 0
            to: 100
            Layout.fillWidth: true
        }
        
        Button {
            text: "保存预设"
            Layout.alignment: Qt.AlignRight
        }
    }
}

交互设计‌:

自定义边框颜色增强辨识度

内置padding保持内容间距

配合Layout控件实现自适应

1.5. SwipeView(页面容器)

工业平板应用‌:

实现多页面滑动切换,适用于设备监控的多视图场景。


SwipeView {

    id: view
    anchors.fill: parent
    currentIndex: 0
    
    // 页面1:实时监控
    RealTimeMonitor { }
    
    // 页面2:历史数据
    HistoryChart { }
    
    // 页面3:报警记录
    AlarmList { }
}



PageIndicator {

    count: view.count
    currentIndex: view.currentIndex
    anchors.bottom: view.bottom
}



进阶用法‌:

结合PageIndicator显示进度

通过currentIndex控制页面跳转

支持手势滑动操作

1.6. TabBar(导航容器)

智能家居中控应用‌:

实现多标签页导航,管理不同功能模块。


Column {

    anchors.fill: parent
    
    TabBar {
        id: bar
        width: parent.width
        
        TabButton { text: "环境监测" }
        TabButton { text: "设备控制" }
        TabButton { text: "能耗统计" }
    }
    
    StackLayout {
        width: parent.width
        height: parent.height - bar.height
        currentIndex: bar.currentIndex
        
        EnvironmentPanel { }
        DeviceController { }
        EnergyDashboard { }
    }
}

1.7. SwipeView 和 TabBar 的区别

1.7.1. 功能和交互方式

  • SwipeView
    SwipeView 是一个基于滑动的导航控件,用户可以通过水平滑动手势在不同页面之间切换。它适合需要通过滑动手势快速切换页面的场景,比如轮播图、选项卡、向导等。

  • TabBar
    TabBar 是一个标签栏控件,用户通过点击标签按钮切换页面。它适合需要通过标签明确指示当前页面的场景,比如多页面应用的导航栏。

1.7.2. 交互方式

  • SwipeView
    主要通过滑动手势进行页面切换,支持触摸屏设备的自然交互。

  • TabBar
    主要通过点击标签按钮进行页面切换,适合需要明确的页面导航和选择的场景。

1.7.3. 视觉表现

  • SwipeView
    SwipeView 本身是不可见的,通常需要与页面指示器(如 PageIndicator)结合使用,以显示当前页面的位置。

  • TabBar
    TabBar 是一个可视化的标签栏,通常显示在页面顶部或底部,提供明确的导航指示。

1.7.4. 适用场景

  • SwipeView
    适合需要滑动切换页面的场景,比如设置页面、欢迎引导页面等。

  • TabBar
    适合需要通过标签导航的场景,比如多页面应用的底部导航栏。

2. 容器设计黄金法则

文章配图

掌握这些容器控件,您将能像搭积木一样构建出专业级工业界面。立即用这些代码片段开启您的下一个项目吧!

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

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

相关文章

VSCode运行,各类操作缓慢,如何清理

VSCode写代码,随着项目逐步进展,代码量在增加,依赖的第三方头文件也在增加, 先是发现代码提示的速度变慢, 后来格式化代码速度太慢 然后c/c代码的语法检查有时候压根就失败,来个错误提示 还有source contro…

redis(2)-mysql-锁

1.数据倾斜: 解决:虚拟节点 2.缓存穿透:缓存雪崩、击穿 3.分布式锁 多把锁控制不同节点上的一致性问题。 锁是有失效时间的。 强制回收。 4.redis 和zookeeper的区别 redis 数据支持有效期 4.1 zookeeper 分布式一致性服务框架&am…

OpenLayers:海量图形渲染之矢量切片

最近由于在工作中涉及到了海量图形渲染的问题,因此我开始研究相关的解决方案。在咨询了许多朋友之后发现矢量切片似乎是行业内最常用的一种解决方案,于是我便开始研究它该如何使用。 一、什么是矢量切片 矢量切片按照我的理解就是用栅格切片的方式把矢…

AI智算-K8s+vLLM Ray:DeepSeek-r1 671B 满血版分布式推理部署实践

K8s + vLLM & Ray:DeepSeek-r1 671B 满血版分布式推理部署实践 前言环境准备1. 模型下载2. 软硬件环境介绍正式部署1. 模型切分2. 整体部署架构3. 安装 LeaderWorkerSet4. 通过 LWS 部署DeepSeek-r1模型5. 查看显存使用率6. 服务对外暴露7. 测试调用API7.1 通过 curl7.2 通…

深入浅出SPI通信协议与STM32实战应用(W25Q128驱动)(实战部分)

1. W25Q128简介 W25Q128 是Winbond推出的128M-bit(16MB)SPI接口Flash存储器,支持标准SPI、Dual-SPI和Quad-SPI模式。关键特性: 工作电压:2.7V~3.6V分页结构:256页/块,每块16KB,共1…

前端知识点---闭包(javascript)

文章目录 1.怎么理解闭包?2.闭包的特点3.闭包的作用?4 闭包注意事项&#xff1a;5 形象理解6 闭包的应用 1.怎么理解闭包? 函数里面包着另一个函数&#xff0c;并且内部函数可以访问外部函数的变量。 <script> function box() {//周围状态&#xff08;外部函数中定义的…

Java 泛型的逆变与协变:深入理解类型安全与灵活性

泛型是 Java 中强大的特性之一&#xff0c;它提供了类型安全的集合操作。然而&#xff0c;泛型的类型关系&#xff08;如逆变与协变&#xff09;常常让人感到困惑。 本文将深入探讨 Java 泛型中的逆变与协变&#xff0c;帮助你更好地理解其原理和应用场景。 一、什么是协变与…

多线程(进阶)(内涵面试题)

目录 一、常见的锁策略 1. 悲观锁 vs 乐观锁 2. 重量级锁 vs 轻量级锁 3. 挂起等待锁 vs 自旋锁 4. 普通互斥锁 vs 读写锁 5. 可重入锁 vs 不可重入锁 6. 公平锁 vs 非公平锁 7. 面试题 二、synchronized的原理 1. 基本特点 2. 加锁工作过程 1&#xff09;偏向锁&am…

蓝桥杯补题

方法技巧&#xff1a; 1.进行循环暴力骗分&#xff0c;然后每一层的初始进行判断&#xff0c;如果已经不满足题意了&#xff0c;那么久直接continue&#xff0c;后面的循环就不用浪费时间了。我们可以把题目所给的等式&#xff0c;比如说有四个未知量&#xff0c;那么我们可以用…

【MySQL篇】mysqlpump和mysqldump参数区别总汇

&#x1f4ab;《博主主页》&#xff1a;奈斯DB-CSDN博客 &#x1f525;《擅长领域》&#xff1a;擅长阿里云AnalyticDB for MySQL(分布式数据仓库)、Oracle、MySQL、Linux、prometheus监控&#xff1b;并对SQLserver、NoSQL(MongoDB)有了解 &#x1f496;如果觉得文章对你有所帮…

SQL:DDL(数据定义语言)和DML(数据操作语言)

目录 什么是SQL&#xff1f; 1. DDL&#xff08;Data Definition Language&#xff0c;数据定义语言&#xff09; 2. DML&#xff08;Data Manipulation Language&#xff0c;数据操作语言&#xff09; DDL和DML的区别 什么是SQL&#xff1f; SQL&#xff08;Structured …

神舟平板电脑怎么样?平板电脑能当电脑用吗?

在如今的数码产品市场上&#xff0c;神舟平板电脑会拥有独特的优势&#xff0c;其中比较受到大家关注的就是神舟PCpad为例&#xff0c;无论是设计还是规格也会有很多的亮点&#xff0c;那么是不是可以直接当成电脑一起来使用呢&#xff1f; 这款平板电脑就会配备10.1英寸显示屏…

【力扣hot100题】(075)数据流的中位数

一开始只建立了一个优先队列&#xff0c;每次查询中位数时都要遍历一遍于是喜提时间超限&#xff0c;看了答案才恍然大悟原来还有这么聪明的办法。 方法是建立两个优先队列&#xff0c;一个大根堆一个小根堆&#xff0c;大根堆记录较小的数&#xff0c;小根堆记录较大的数。 …

Java——pdf增加水印

文章目录 前言方式一 itextpdf项目依赖引入编写PDF添加水印工具类测试效果展示 方式二 pdfbox依赖引入编写实现类效果展示 扩展1、将inputstream流信息添加水印并导出zip2、部署出现找不到指定字体文件 资料参考 前言 近期为了知识库文件导出&#xff0c;文件数据安全处理&…

leetcode_19. 删除链表的倒数第 N 个结点_java

19. 删除链表的倒数第 N 个结点https://leetcode.cn/problems/remove-nth-node-from-end-of-list/ 1、题目 给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff0c;并且返回链表的头结点。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], n 2 输出&#…

41、web前端开发之Vue3保姆教程(五 实战案例)

一、项目简介和需求概述 1、项目目标 1.能够基于Vue3创建项目 2.能够基本Vue3相关的技术栈进行项目开发 3.能够使用Vue的第三方组件进行项目开发 4.能够理解前后端分离的开发模式 2、项目概述 使用Vue3结合ElementPlus,ECharts工具实现后台管理系统页面,包含登录功能,…

zsh: command not found: hdc - 鸿蒙 HarmonyOS Next

终端中执行 hdc 命令抛出如下错误; zsh: command not found: hdc 解决办法 首先,查找到 DevEco-Studio 的 toolchains 目录路径; 其次,按照类似如下的文件夹层级结果推理到 toolchains 子级路径下,其中 sdk 后一级的路径可能会存在差异,以实际本地路径结构为主,直至找到 ope…

蓝桥杯--寻找整数

题解 public static void main(String[] args) {int[] mod {0, 0, 1, 2, 1, 4, 5, 4, 1, 2, 9, 0, 5, 10, 11, 14, 9, 0, 11, 18, 9, 11, 11, 15, 17, 9, 23, 20, 25, 16, 29, 27, 25, 11, 17, 4, 29, 22, 37, 23, 9, 1, 11, 11, 33, 29, 15, 5, 41, 46};long t lcm(2, 3);lo…

自然语言处理入门6——RNN生成文本

一、文本生成 我们在前面的文章中介绍了LSTM&#xff0c;根据输入时序数据可以输出下一个可能性最高的数据&#xff0c;如果应用在文字上&#xff0c;就是根据输入的文字&#xff0c;可以预测下一个可能性最高的文字。利用这个特点&#xff0c;我们可以用LSTM来生成文本。输入…

FPGA_DDR错误总结

1otp 31-67 解决 端口没连接 必须赋值&#xff1b; 2.PLACE 30-58 TERM PLINITCALIBZ这里有问题 在顶层输出但是没有管脚约束报错 3.ERROR: [Place 30-675] 这是时钟不匹配IBUF不在同一个时钟域&#xff0c;时钟不在同一个时钟域里&#xff0c;推荐的不建议修改 问题 原本…