当前位置: 首页 > wzjs >正文

网易做网站精准获客

网易做网站,精准获客,做网站虚拟主机要多大,做网站1核1g服务器够吗目录 引言相关阅读项目结构示例实现与代码解析示例一:时间选择器(TimePicker)示例二:日期时间选择器(DateTimePicker) 主窗口整合运行效果总结下载链接 引言 在现代应用程序开发中,时间与日期选…

目录

    • 引言
    • 相关阅读
    • 项目结构
    • 示例实现与代码解析
      • 示例一:时间选择器(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.dtcms.com/wzjs/67228.html

相关文章:

  • wordpress 升级 ftp成都百度快照优化排名
  • 动漫建模代做网站百度一下seo优化软件大全
  • seo 网站关键词福州seo网站推广优化
  • 阿里云 个人网站备案seo培训学什么
  • 电子商务网站策划书3500字女孩短期技能培训班
  • 电商营销型网站建设论坛推广工具
  • 厦门做网站的百度推广业务电话
  • pc网站建设费用seo sem
  • 摇滚中国发展史日本人做的网站公众号怎么推广和引流
  • 销售型网站建设体验营销
  • 用dreammwea怎么做视频网站百度推广客户端下载网址
  • 旅游网站建设公司网络广告的发布方式包括
  • 哪里建设网站比较好软文写作实训总结
  • 怎么建设好一个外贸购物网站seo服务方案
  • 网站滚动公告怎么做客户引流的最快方法是什么
  • 品牌建设卓有成效佛山做seo推广公司
  • 网站首页一般做多大外链在线生成
  • vs 团队网站开发seo职位要求
  • 虚拟主机怎么发布网站吗it培训学校
  • 常州模板网站建设咨询爱站网站排名查询工具
  • 深圳市罗湖区网站建设企业网站建设方案范文
  • 微信小程序怎么做网站如何优化关键词提升相关度
  • 青海高端网站建设多少钱福州网seo
  • 全国封城名单seo培训价格
  • 国外优秀排版设计网站官网站内推广内容
  • 个人团购网站 转入备案关键词歌词含义
  • 嘉善在线做网站吗网页设计与制作模板
  • seo 成功网站太原seo网站优化
  • 做网站时会遇到什么问题各大搜索引擎入口
  • wordpress wp-syntax上海百度seo网站优化