C++界面开发框架Qt新手入门教程 – 如何创建移动应用程序(二)(qt 开源界面框架)

Qt是目前最先进、最完整的跨平台C 开发工具。它不仅完全实现了一次编写,所有平台无差别运行,更提供了几乎所有开发过程中需要用到的工具。如今,Qt已被运用于超过70个行业、数千家企业,支持数百万设备及应用。

点击获取Qt组件下载

本教程介绍了在使用Qt 6作为最低Qt版本并使用CMake作为构建系统时,如何使用Qt Creator开发适用于Android和iOS设备的Qt Quick应用程序。(点击这里回顾上文:C 界面开发框架Qt新手入门教程 – 如何创建移动应用程序(一))

添加图像作为资源

当您倾斜设备时,应用程序的主视图会显示一个 SVG 气泡图像,该图像会在屏幕上移动。

我们在本教程中使用 Bluebubble.svg,但您可以使用任何其他图像或组件来代替。

要在运行应用程序时显示图像,您必须在向导为您创建的 CMakeLists.txt 文件的 RESOURCES 部分中将其指定为资源:

qt_add_qml_module(appaccelbubbleURI accelbubbleVERSION 1.0QML_FILES main.qmlRESOURCES Bluebubble.svg)

创建 Accelbubble 主视图

我们通过添加一个以 Bluebubble.svg 作为源的 Image 组件在 main.qml 文件中创建主视图:

Image {id: bubblesource: "Bluebubble.svg"smooth: true

接下来,我们添加自定义属性以根据主窗口的宽度和高度定位图像:

property real centerX: mainWindow.width / 2property real centerY: mainWindow.height / 2property real bubbleCenter: bubble.width / 2x: centerX - bubbleCentery: centerY - bubbleCenter

我们现在要添加代码以根据加速度计传感器值移动气泡。 首先,我们添加以下导入语句:

import QtSensors

接下来,我们添加具有必要属性的 Accelerometer 组件:

Accelerometer {id: acceldataRate: 100active:true

然后,我们添加以下 JavaScript 函数,这些函数根据当前的 Accelerometer 值计算气泡的 x 和 y 位置:

function calcPitch(x,y,z) {return -Math.atan2(y, Math.hypot(x, z)) * mainWindow.radians_to_degrees;}function calcRoll(x,y,z) {return -Math.atan2(x, Math.hypot(y, z)) * mainWindow.radians_to_degrees;}

我们为 Accelerometer 组件的 onReadingChanged 信号添加以下 JavaScript 代码,以使气泡在 Accelerometer 值发生变化时移动:

onReadingChanged: {var newX = (bubble.x calcRoll(accel.reading.x, accel.reading.y, accel.reading.z) * .1)var newY = (bubble.y - calcPitch(accel.reading.x, accel.reading.y, accel.reading.z) * .1)if (isNaN(newX) || isNaN(newY))return;if (newX < 0)newX = 0if (newX > mainWindow.width - bubble.width)newX = mainWindow.width - bubble.widthif (newY < 18)newY = 18if (newY > mainWindow.height - bubble.height)newY = mainWindow.height - bubble.heightbubble.x = newXbubble.y = newY}

我们要确保气泡的位置始终在屏幕范围内,如果加速度计返回的不是数字 (NaN),则忽略该值并且不更新气泡位置。

我们在气泡的 x 和 y 属性上添加 SmoothedAnimation 操作,使其运动看起来更平滑。

Behavior on y {SmoothedAnimation {easing.type: Easing.Linearduration: 100}}Behavior on x {SmoothedAnimation {easing.type: Easing.Linearduration: 100}}

Qt组件推荐

  • QtitanRibbon – Ribbon UI组件:是一款遵循Microsoft Ribbon UI Paradigm for Qt技术的Ribbon UI组件,QtitanRibbon致力于为Windows、Linux和Mac OS X提供功能完整的Ribbon组件。
  • QtitanChart – Qt类图表组件:是一个C 库,代表一组控件,这些控件使您可以快速地为应用程序提供漂亮而丰富的图表。
  • QtitanDataGrid – Qt网格组件:提供了一套完整的标准 QTableView 函数和传统组件无法实现的独特功能。使您能够将不同来源的各类数据加载到一个快速、灵活且功能强大的可编辑网格中,支持排序、分组、报告、创建带状列、拖放按钮和许多其他方便的功能。
  • QtitanDocking:允许您像 Visual Studio 一样为您的伟大应用程序配备可停靠面板和可停靠工具栏。黑色、白色、蓝色调色板完全支持 Visual Studio 2019 主题!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2023年3月14日 上午11:24
下一篇 2023年3月14日 上午11:34

相关推荐

  • 东方雨虹全项目管理系统

    东方雨虹全项目管理系统:提升企业项目管理效率的利器 随着现代企业竞争的加剧,项目管理的重要性越来越受到企业界的关注。东方雨虹作为一家拥有多年行业经验和实力的企业,其项目管理的效率对…

    科研百科 2025年7月10日
    1
  • 关注产业振兴行动、联合反馈审计结果……关注本期审计动态

    推动用好用活产业政策 2023年以来,黑龙江省审计厅组织9个市级审计机关,对省发改委等5个省直部门和哈尔滨等10个市及所辖部分县(市),促进数字经济及战略性新兴产业发展情况开展专项…

    科研百科 2024年1月28日
    102
  • 科研项目怎么申报

    科研项目申报是一项非常重要的工作,它关系到项目的成功与否和研究人员的薪资福利。以下是一些科研项目申报的基本步骤和注意事项。 一、明确申报项目的类型和范围 在申报科研项目之前,首先要…

    科研百科 2025年3月5日
    0
  • 公司内部公文规范实施细则(公司内部公文规范实施细则最新)

      公司内部公文规范实施细则   目的:统一发文标准,明确职责,确保内部发文的规范性、准确性、权威性。细则:   1、所有内部公文使用统一模板,有表格式页眉;   2、字体字号:页…

    科研百科 2024年2月5日
    138
  • 国内科研项目收费吗知乎

    国内科研项目是否收费 在国内,许多科研项目是收费的,但也存在一些项目是不收费的。收费的科研项目通常是指项目资金由政府机构或私人机构提供,并且项目的成果或服务需要一定的经济代价来支付…

    科研百科 2025年4月26日
    0
  • 党联办工作职责(党联办工作职责是什么)

    党委组织部是学校党委的重要职能部门,协助党委负责领导班子和干部队伍建设,承担基层党组织建设、党员教育管理任务,参与党校 干部、党员和入觉积极分子培训等工作。具体职责如下: 一、坚持…

    科研百科 2023年6月25日
    420
  • 5 款主流的密码管理软件,你在用哪款?(5 款主流的密码管理软件,你在用哪款软件)

    现在大家上网注册的各种账号密码非常多,有些小伙伴为了方便好记,可能会采用弱口令(123456/aaaabbbb/生日……),或者统一密码,这样很容易导致账户密码泄露。密码被泄露情况…

    科研百科 2024年7月18日
    57
  • 移动协同办公(移动 协同办公)

    移动协同办公:让工作更加高效便捷 随着科技的不断发展,移动协同办公已经成为了现代工作方式的重要组成部分。无论是企业内部的协作,还是与客户的沟通,移动协同办公都能够有效地提高我们的工…

    科研百科 2024年6月8日
    56
  • 开源项目管理工具

    开源项目管理工具:一个项目成功的关键因素 开源项目管理工具是现代项目管理中不可或缺的一部分。这些工具可以帮助项目经理有效地组织、跟踪和管理项目进度、资源、风险等信息。本文将介绍开源…

    科研百科 2024年9月23日
    24
  • 食堂卫生管理制度(食堂卫生管理制度六条)

    食堂卫生管理制度 一、目的 为员工提供一个良好的就餐环境和可口的饭菜,严格对食堂进行标准化管理,最大限度地减少对环境的污染及避免因食物引起的意外发生,特制定本制度。 二、适用范围 …

    科研百科 2024年1月24日
    122