使用QML Tumbler 实现时间日期选择器

目录

    • 引言
    • 相关阅读
    • 项目结构
    • 示例实现与代码解析
      • 示例一:时间选择器(TimePicker)
      • 示例二:日期时间选择器(DateTimePicker)
    • 主窗口整合
    • 运行效果
    • 总结
    • 下载链接

引言

在现代应用程序开发中,时间与日期选择是常见的用户界面需求。无论是在日程安排、预约系统还是任何需要时间录入的场景,一个直观易用的选择器组件可以大大提升用户体验。本文将详细介绍如何使用 QML 技术实现两种常用的选择器组件:时间选择器和日期时间选择器。

相关阅读

  • Tumbler 组件文档

项目结构

Main.qml
TimePicker.qml
DateTimePicker.qml
main.cpp
CMakeLists.txt

示例实现与代码解析

本项目实现了两个实用的选择器组件:时间选择器(TimePicker)和日期时间选择器(DateTimePicker)。下面将对这些组件进行详细解析。

示例一:时间选择器(TimePicker)

时间选择器允许用户通过滚动选择特定的小时和分钟值。这种交互方式类似于传统的模拟时钟调整,但提供了更为精确和直观的数字选择。

核心代码:

Rectangle {id: rootwidth: 280height: 400color: "#ffffff"radius: 10border.color: "#e0e0e0"border.width: 1property int hours: hoursTumbler.currentIndexproperty int minutes: minutesTumbler.currentIndexColumnLayout {anchors.fill: parentspacing: 10Text {Layout.alignment: Qt.AlignHCentertext: "选择时间"font.pixelSize: 20color: "#333333"Layout.topMargin: 20}Rectangle {Layout.alignment: Qt.AlignHCenterLayout.preferredWidth: parent.width - 40Layout.preferredHeight: 200color: "transparent"Row {anchors.centerIn: parentspacing: 10Tumbler {id: hoursTumblermodel: 24height: 200width: 80delegate: Text {text: modelData.toString().padStart(2, '0')color: Tumbler.tumbler.currentIndex === index ? "#1976D2" : "#666666"font.pixelSize: Tumbler.tumbler.currentIndex === index ? 22 : 18horizontalAlignment: Text.AlignHCenterverticalAlignment: Text.AlignVCenteropacity: 1.0 - Math.abs(Tumbler.displacement) / (Tumbler.tumbler.visibleItemCount / 2)}}Text {text: ":"font.pixelSize: 24anchors.verticalCenter: parent.verticalCentercolor: "#333333"}Tumbler {id: minutesTumblermodel: 60height: 200width: 80delegate: Text {text: modelData.toString().padStart(2, '0')color: Tumbler.tumbler.currentIndex === index ? "#1976D2" : "#666666"font.pixelSize: Tumbler.tumbler.currentIndex === index ? 22 : 18horizontalAlignment: Text.AlignHCenterverticalAlignment: Text.AlignVCenteropacity: 1.0 - Math.abs(Tumbler.displacement) / (Tumbler.tumbler.visibleItemCount / 2)}}}}Text {Layout.alignment: Qt.AlignHCentertext: hours.toString().padStart(2, '0') + ":" + minutes.toString().padStart(2, '0')font.pixelSize: 24color: "#1976D2"}}
}

代码解析:

外观设计

  • 使用 Rectangle 作为容器,设置圆角和边框,营造现代化的界面风格
  • 采用简洁的配色方案,主色调为蓝色(#1976D2),与灰色搭配形成对比
  • 整体布局采用垂直方向的 ColumnLayout 排列元素

时间选择逻辑

  • 使用两个 Tumbler 组件分别控制小时(0-23)和分钟(0-59)
  • 通过属性绑定 property int hours: hoursTumbler.currentIndex 直接获取选择的值
  • 实时显示当前选择的时间,方便用户确认

视觉反馈

  • 当前选中项使用突出的蓝色和更大的字体
  • 通过 opacity 属性实现滚轮效果,让远离中心的项逐渐变淡
  • 使用 padStart(2, '0') 确保时间始终以两位数显示(如 “01” 而非 “1”)

示例二:日期时间选择器(DateTimePicker)

日期时间选择器扩展了时间选择的功能,增加了年、月、日的选择,提供了完整的日期时间设置能力。

核心代码:

Rectangle {id: rootwidth: 320height: 480color: "#ffffff"radius: 10border.color: "#e0e0e0"border.width: 1property date selectedDateTime: new Date()function updateDateTime() {if (!yearTumbler.currentItem || !dayTumbler.currentItem) return;let newDate = new Date(selectedDateTime)let year = parseInt(yearTumbler.currentItem.text)let month = monthTumbler.currentIndexlet day = parseInt(dayTumbler.currentItem.text)let hours = hoursTumbler.currentIndexlet minutes = minutesTumbler.currentIndex// 验证日期是否有效if (isNaN(year) || isNaN(day)) return;newDate.setFullYear(year)newDate.setMonth(month)newDate.setDate(day)newDate.setHours(hours)newDate.setMinutes(minutes)if (newDate.getTime() === selectedDateTime.getTime()) return;selectedDateTime = newDate}// 计算指定年月的天数function getDaysInMonth(year, month) {return new Date(year, month + 1, 0).getDate()}Component.onCompleted: {let currentDate = new Date()yearTumbler.currentIndex = yearTumbler.model.indexOf(currentDate.getFullYear().toString())monthTumbler.currentIndex = currentDate.getMonth()dayTumbler.currentIndex = currentDate.getDate() - 1hoursTumbler.currentIndex = currentDate.getHours()minutesTumbler.currentIndex = currentDate.getMinutes()}// ... Tumbler 组件实现 ...Text {Layout.alignment: Qt.AlignHCentertext: selectedDateTime.toLocaleString(Qt.locale(), "yyyy年MM月dd日 hh:mm")font.pixelSize: 18color: "#1976D2"}
}

代码解析:

日期时间管理

  • 使用 property date selectedDateTime 存储完整的日期时间信息
  • 实现 updateDateTime() 函数统一处理所有 Tumbler 的变更
  • 加入错误处理和有效性检查,确保日期合法

月份天数处理

  • 通过 getDaysInMonth() 函数动态计算每月天数
  • 在月份变化时自动调整日期选择器的可选范围
  • 避免出现无效日期(如 2 月 31 日)

初始化与数据绑定

  • Component.onCompleted 中设置初始值为当前系统时间
  • 使用 Qt.callLater() 延迟更新,避免组件初始化时的问题
  • 通过 toLocaleString() 格式化显示完整的日期时间

错误处理与优化

  • 增加空值检查,防止访问空对象属性
  • 添加数据有效性验证,避免设置非法日期
  • 使用日期相等性比较,减少不必要的更新

主窗口整合

在 Main.qml 中,我们将两个选择器组件集成到一个统一的界面中,由于篇幅过长,此处代码省略,详情请看下载链接。

运行效果

日期选择器


总结

本文介绍了使用 QML 实现时间选择器和日期时间选择器的方法与技巧。通过这个项目,我们可以得出以下几点经验:

  • 将 UI 元素封装为独立组件,增强代码复用性和可维护性
  • 加入适当的错误检查和边界条件处理,增强程序健壮性
  • 充分利用 QML 的数据绑定特性,简化状态管理

下载链接

完整项目代码可以从以下链接获取:GitCode - DateTimePicker

GitCode

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

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

相关文章

R语言中的常用内置函数

常用的数值函数 常用的字符函数 与概率分布相关的函数 有用的统计函数 数据来源:《数据挖掘与数据分析:基于R语言》王阳 2024年1月出版

org.springframework.core.env.PropertiesPropertySource 类详解

org.springframework.core.env.PropertiesPropertySource 类详解 1. 基本概述 类路径: org.springframework.core.env.PropertiesPropertySource继承关系: 继承自 PropertySource<Properties>&#xff0c;实现 PropertySource 接口。作用: 将 Java Properties 对象&…

2025-04-22 李沐深度学习5 —— 线性回归

文章目录 1 案例介绍1.1 应用场景&#xff1a;美国房价预测1.2 核心假设1.3 线性回归与神经网络的关系1.4 平方损失&#xff08;L2 Loss&#xff09;1.5 训练模型&#xff1a;最小化损失 2 基础优化算法2.1 梯度下降2.2 小批量随机梯度下降&#xff08;Mini-batch SGD&#xff…

你的大模型服务如何压测:首 Token 延迟、并发与 QPS

写在前面 大型语言模型(LLM)API,特别是遵循 OpenAI 规范的接口(无论是 OpenAI 官方、Azure OpenAI,还是 DeepSeek、Moonshot 等众多兼容服务),已成为驱动下一代 AI 应用的核心引擎。然而,随着应用规模的扩大和用户量的增长,仅仅关注模型的功能是不够的,API 的性能表…

数字化转型避坑指南:中钧科技如何用“四个锚点”破解转型深水区

数字化转型浪潮下&#xff0c;企业常陷入四大典型陷阱&#xff1a;跟风式投入、数据沼泽化、流程伪在线、安全裸奔化。中钧科技旗下产品以“经营帮”平台为核心&#xff0c;通过针对性方案帮助企业绕开深坑。 陷阱一&#xff1a;盲目跟风&#xff0c;为数字化而数字化 许…

时分复用、频分复用和码分复用简要比较分析

时分复用&#xff08;TDM&#xff09;、频分复用&#xff08;FDM&#xff09;和码分复用&#xff08;CDM&#xff09;是经典的多路复用技术&#xff0c;它们通过不同的方式共享信道资源。以下是两者的详细比较及其优缺点&#xff1a; 1. 原理对比 时分复用&#xff08;TDM&…

MCP认证难题破解:常见技术难题实战分析与解决方案

MCP认证难题破解:常见技术难题实战分析与解决方案 一、引言:MCP认证——智能协作领域的“技术试金石” MCP(Multi-agent Communication Protocol)认证作为多智能体系统领域的权威认证,旨在考察考生对MCP协议设计、智能体协作架构、分布式系统优化等核心技术的掌握程度。…

最新iOS性能测试方法与教程

一、工具instrument介绍 使用Xcode的instrument进行测试&#xff0c;instrument自带了很多性能方面的测试工具&#xff0c;如图所示&#xff1a; 二、常见性能测试内容 不管是安卓还是iOS的性能测试&#xff0c;常见的性能测试都要包含这五个方面&#xff1a; 1、内存&#xff…

Vue el-checkbox 虚拟滚动解决多选框全选卡顿问题 - 高性能处理大数据量选项列表

一、背景 在我们开发项目中&#xff0c;经常会遇到需要展示大量选项的多选框场景&#xff0c;比如权限配置、数据筛选等。当选项数量达到几百甚至上千条时&#xff0c;传统的渲染方式全选时会非常卡顿&#xff0c;导致性能问题。本篇文章&#xff0c;记录我使用通过虚拟滚动实现…

JWT的token泄露要如何应对

文章目录 前言✅ 一、预防措施&#xff08;防泄露&#xff09;&#x1f6a8; 二、应急响应机制&#xff08;发现已泄露&#xff09;&#x1f512; 1. **启用 Token 黑名单机制**&#x1f501; 2. **启用 Refresh Token 机制 旋转令牌**&#x1f4cd; 3. **强制下线机制**&…

24.中医知识问答删除历史对话功能前端代码实现

前端实现对话删除功能的完整指南 功能概述 前篇文章介绍了删除历史对话的后端开发&#xff0c;本篇将介绍如何在前端实现一个完整的对话删除功能&#xff0c;包括用户确认、API调用、状态管理和错误处理等关键环节。 功能拆解 1. 用户确认机制 javascript const confirmDe…

如何在 Python 项目中引入 Rust 函数

目录 1. 初始化 Python 项目2. 添加 Rust 开发工具3. 初始化 Rust 项目4. 开发模式构建5. 验证模块是否成功安装6. 测试 Rust 函数总结 (封面pid: 129416070) Python 是一门非常流行的编程语言&#xff0c;具有易于使用和开发的特点。然而&#xff0c;随着项目需求的增长和性能…

Java基础系列-HashMap源码解析2-AVL树

文章目录 AVL树左旋右旋左旋右旋的4种情况LL 型RR 型LR 型RL 型 实际插入时怎么判断是那种类型&#xff1f;插入时注意事项删除节点 AVL树 为避免BST树退化成链表的极端情况&#xff0c; AVL 树应运而生。 平衡因子取值&#xff08;-1&#xff0c;0&#xff0c;1&#xff09;…

新书速览|Hadoop与Spark大数据全景解析(视频教学版)

《Hadoop与Spark大数据全景解析:视频教学版》 01 本书内容 《Hadoop与Spark大数据全景解析:视频教学版》结合作者多年在大数据领域的开发实践经验&#xff0c;采用“理论实战”的形式&#xff0c;以大量实例全面介绍Hadoop和Spark的基础知识及其高级应用。作者将丰富的教学经…

TapData × 梦加速计划 | 与 AI 共舞,TapData 携 AI Ready 实时数据平台亮相加速营,企业数据基础设施现代化

在实时跃动的数据节拍中&#xff0c;TapData 与 AI 共舞&#xff0c;踏出智能未来的新一步。 4月10日&#xff0c;由前海产业发展集团、深圳市前海梦工场、斑马星球科创加速平台等联合发起的「梦加速计划下一位独角兽营」正式启航。 本次加速营以“打造下一位独角兽企业”为目…

[密码学基础]密码学常用名词深度解析:从基础概念到实战应用

密码学常用名词深度解析&#xff1a;从基础概念到实战应用 密码学是信息安全的基石&#xff0c;但其专业术语常令人望而生畏。本文系统梳理密码学领域的核心名词&#xff0c;结合技术原理、实际应用与攻击场景&#xff0c;帮助开发者快速构建密码学知识框架。文中代码示例基于…

GD32H7单片机使用segger_rtt,rtt-viewer看不到输出的问题,怎样解决?

jlink版本目前是792&#xff0c;但估计只要能支持h7的jlink版本应该都可以。 将segger/JLink_V792n中&#xff0c;samples文件夹、RTT中四个文件拷贝出来放在单片机目录中 在任意代码部分引用segger_rtt.h&#xff0c;再调用函数 即可使用rtt打印功能&#xff0c;在rtt-viewe…

快速生成安卓证书并打包生成安卓apk(保姆教程)

一.生成安卓证书 目前市面上生成可以快速生成安卓证书的网站有很多个人推荐香蕉云编以下是网站链接 香蕉云编-app打包上架工具类平台 1.进入网站如下图 2.点击生成签名证书 3.点击立即创建证书 4.点击创建安卓证书 5.按照指引完成创建 6.点击下载就可使用 二.打包安卓apk …

前端面试场景题

目录 1.项目第一次加载太慢优化 / vue 首屏加载过慢如何优化 2.说说了解的es6-es10的东西有哪些 ES6&#xff08;ES2015&#xff09;之后&#xff0c;JavaScript 新增了许多实用的数组和对象方法&#xff0c;下面为你详细介绍&#xff1a; 3.常见前端安全性问题 XSS&#…

Spring JDBC 的开发步骤(注解方式)

Spring JDBC 的开发步骤主要包括以下关键环节&#xff0c;结合代码示例说明如下&#xff1a; 1. 添加依赖 在 pom.xml 中引入 Spring JDBC 和数据库驱动依赖&#xff08;以 HikariCP 连接池和 MySQL 为例&#xff09;&#xff1a; <!-- Spring JDBC --> <dependency…