利用QT实现主界面APP应用开发之经典

简介: 利用QT实现主界面APP应用开发之经典

 在嵌入式的开发过程中,利用好应用开发也是不错的选择。


    今天主要和大家聊一聊,如何利用Qt来开发APP主界面,在Qt中提供了QStackedWdget与QTableView这样的控件方便页面切换,但是这种方法比较生硬,体验感较差。也可以自己实现对应滑动界面的设计。

7f5eed7bf8de96e01812c2ed9121e08b.png

第一:滑动界面的设计基础

#include "slidepage.h"
#include <QDebug>
#include <QPropertyAnimation>
SlidePage::SlidePage(QWidget *parent):QWidget(parent),pageIndex(0),pageCount(0),draggingFlag(false)
{
 pageIndicator.clear();
 this->setMinimumSize(400, 300);
 this->setAttribute(Qt::WA_TranslucentBackground, true);
 scrollArea = new QScrollArea(this);
 scrollArea->setAlignment(Qt::AlignCenter);
 mainWidget = new QWidget();
 mainWidget->setStyleSheet("background: transparent");
 scrollArea->setWidget(mainWidget);
 scrollArea->setStyleSheet("background: transparent");
 bottomWidget = new QWidget(this);
 bottomWidget->setStyleSheet("background: transparent");
 bottomHBoxLayout = new QHBoxLayout();
 bottomWidget->setLayout(bottomHBoxLayout);
 bottomHBoxLayout->setContentsMargins(0, 0, 0, 0);
 bottomHBoxLayout->setAlignment(Qt::AlignCenter);
/* 关闭滚动条显示 */
 scrollArea->setVerticalScrollBarPolicy(
 Qt::ScrollBarAlwaysOff);
 scrollArea->setHorizontalScrollBarPolicy(
 Qt::ScrollBarAlwaysOff);
 /* 滚屏对象 */
 scroller = QScroller::scroller(scrollArea);
 QScroller::ScrollerGestureType gesture =
 QScroller::LeftMouseButtonGesture;
 scroller->grabGesture(scrollArea, gesture);
/* 获取属性 */
 QScrollerProperties properties = scroller->scrollerProperties();
/* 设置滑动的时间,值越大,时间越短 */
 properties.setScrollMetric(QScrollerProperties::SnapTime, 0.5);
/* 设置滑动速度 */
 properties.setScrollMetric(QScrollerProperties::MinimumVelocity, 1);
 scroller->setScrollerProperties(properties);
/* 布局 */
 hBoxLayout = new QHBoxLayout();
 hBoxLayout->setContentsMargins(0, 0, 0, 0);
 hBoxLayout->setSpacing(0);
 mainWidget->setLayout(hBoxLayout);
/* 定时器,用于判断用户是否是拖动屏幕,区分滑动,超过 300ms 表示拖动 */
 timer = new QTimer(this);
 connect(scrollArea->horizontalScrollBar(),SIGNAL(valueChanged(int)), this, SLOT(hScrollBarValueChanged(int)));
 connect(scroller, SIGNAL(stateChanged(QScroller::State)), this,
SLOT(onStateChanged(QScroller::State)));
 connect(timer, SIGNAL(timeout()), this, SLOT(onTimerTimeOut()));
 connect(this, SIGNAL(currentPageIndexChanged(int)), this,SLOT(onCurrentPageIndexChanged(int)));
}

  上面的这些描述,只是一个滑动界面的类,如果需要控制的话,还需要往里面添加对应的内容。


第二:APP主界面实现方法


    在项目正常运行之后,可以看到一个APP主界面,这个界面不能点击,如果需要控制的话再通过链接到界面上的按钮点击信号,可以是点击按钮之后打开一个新界面,完成事件的交互。

d7c06c08681469ec728a0e5149d8970d.png


项目文件夹下内容解释:

03_appmainview.pro 项目下:

1、appdemo 文件夹为车载音乐 APP 页面,只是界面,不带实际功能!

2、slidepage 文件夹为笔者原创的一个滑动页面类,在这个类里,我们可以使用 addPage()方法来添加页面,当添加的页面大于 2 页时,就可以滑动切换页面了。

3、Headers 文件夹为 03_appmainview.pro 的头文件。

3、Headers 文件夹为 03_appmainview.pro 的头文件。

4、Sources 文件夹为 03_appmainview.pro 的源文件。

5、Resource 文件夹为 03_appmainview.pro 的源文件。主要是存放一张背景图片。


第三:实现分析


   在运行的过程中,会有三个界面,可以利用利用手动的方式进行滑动,从运行效果上来说,还是不错的。


总结:在编写实现APP的过程中,需要对其中的API函数的非常熟悉,这个就要投入大量的精力在里面,学习各个函数的用法。

目录
相关文章
|
4月前
|
缓存 移动开发 JavaScript
如何优化UniApp开发的App的启动速度?
如何优化UniApp开发的App的启动速度?
841 139
|
4月前
|
移动开发 JavaScript weex
UniApp开发的App在启动速度方面有哪些优势和劣势?
UniApp开发的App在启动速度方面有哪些优势和劣势?
427 137
|
4月前
|
数据采集 JavaScript 前端开发
开发比分App?你缺的不是程序员
开发体育比分App,关键不在代码,而在懂体育、懂数据、懂用户。明确定位、理清需求、选好数据源,再找专业的产品、数据与技术人才协同,才能少走弯路。程序员最后入场,效率最高。
283 154
|
5月前
|
移动开发 小程序 Android开发
基于 uni-app 开发的废品回收类多端应用功能与界面说明
本文将对一款基于 uni-app 开发的废品回收类多端应用,从多端支持范围、核心功能模块及部分界面展示进行客观说明,相关资源信息也将一并呈现。
196 0
|
7月前
|
人工智能 文字识别 小程序
旅游社用什么工具收报名 + 资料?不开发 App 也能自动收集信息
本文探讨了旅游行业中报名信息收集的常见痛点及解决方案,重点介绍了二维码表单工具在提升信息收集效率、简化操作流程方面的优势。通过对比多种工具,分析其适用场景与实际应用逻辑,为一线旅游从业者提供高效、低成本的执行参考。
|
8月前
|
容器
HarmonyOS NEXT仓颉开发语言实战案例:外卖App
仓颉语言实战分享,教你如何用仓颉开发外卖App界面。内容包括页面布局、导航栏自定义、搜索框实现、列表模块构建等,附完整代码示例。轻松掌握Scroll、List等组件使用技巧,提升HarmonyOS应用开发能力。
|
4月前
|
移动开发 前端开发 Android开发
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
468 12
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
7月前
|
Rust 安全 前端开发
Github 轻松斩获30k+ Star,桌面应用开发太丝滑啦,Tauri框架能重塑桌面App开发?别错过,抓紧上车
Tauri 是一个基于 Rust 的开源框架,用于构建轻量级、高性能、安全的跨平台桌面及移动应用。它利用系统 WebView 渲染前端界面,后端由 Rust 编写,具备出色的性能和安全性。相比 Electron,Tauri 应用体积更小、启动更快,且默认权限更安全。它支持 React、Vue、Svelte 等主流前端框架,并提供自动更新、CLI 工具链、资源注入优化等功能,适用于生产力工具、开发者工具、数据分析、AI 应用等多种场景。目前 Tauri 在 GitHub 上已获得超过 30,000 Star,社区活跃,是现代桌面应用开发的理想选择。
904 0
|
4月前
|
移动开发 JavaScript 应用服务中间件
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
441 5
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡

推荐镜像

更多
  • qt