利用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函数的非常熟悉,这个就要投入大量的精力在里面,学习各个函数的用法。

目录
相关文章
|
1月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
485 7
|
1月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
540 1
|
19天前
|
小程序 数据挖掘 UED
开发1个上门家政小程序APP系统,都有哪些功能?
在快节奏的现代生活中,家政服务已成为许多家庭的必需品。针对传统家政服务存在的问题,如服务质量不稳定、价格不透明等,我们历时两年开发了一套全新的上门家政系统。该系统通过完善信用体系、提供奖励机制、优化复购体验、多渠道推广和多样化盈利模式,解决了私单、复购、推广和盈利四大痛点,全面提升了服务质量和用户体验,旨在成为家政行业的领导者。
|
1月前
|
JavaScript 前端开发 小程序
uniapp一个人开发APP关键步骤和考虑因素
uniapp一个人开发APP关键步骤和考虑因素
123 1
uniapp一个人开发APP关键步骤和考虑因素
|
1月前
|
JavaScript 前端开发 UED
Vue与uni-app开发中通过@font-face巧妙引入自定义字体
Vue与uni-app开发中通过@font-face巧妙引入自定义字体
73 9
|
1月前
|
缓存 小程序 索引
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
193 1
|
16天前
|
机器人
布谷直播App系统源码开发之后台管理功能详解
直播系统开发搭建管理后台功能详解!
|
1月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
547 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
2月前
|
移动开发 Android开发 数据安全/隐私保护
移动应用与系统的技术演进:从开发到操作系统的全景解析随着智能手机和平板电脑的普及,移动应用(App)已成为人们日常生活中不可或缺的一部分。无论是社交、娱乐、购物还是办公,移动应用都扮演着重要的角色。而支撑这些应用运行的,正是功能强大且复杂的移动操作系统。本文将深入探讨移动应用的开发过程及其背后的操作系统机制,揭示这一领域的技术演进。
本文旨在提供关于移动应用与系统技术的全面概述,涵盖移动应用的开发生命周期、主要移动操作系统的特点以及它们之间的竞争关系。我们将探讨如何高效地开发移动应用,并分析iOS和Android两大主流操作系统的技术优势与局限。同时,本文还将讨论跨平台解决方案的兴起及其对移动开发领域的影响。通过这篇技术性文章,读者将获得对移动应用开发及操作系统深层理解的钥匙。
|
25天前
|
NoSQL PHP Redis
布谷语音app源码服务器环境配置及技术开发语言
布谷语音app源码服务器环境配置及技术语言研发。。

热门文章

最新文章