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

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

(0)
上一篇 2023年4月28日 上午11:39
下一篇 2023年4月28日 上午11:49

相关推荐

  • 项目部管理细则:财务管理实施细则之资产管理(项目部资产管理制度)

    近日,我们公司成立了一个项目部,本人参与制定了全部的管理制度,现在分享给大家!后期还有别的各种制度也一并分享,敬请期待!如有不妥,请指正!本人长期负责制定各项管理制度、预案、计划等…

    科研百科 2023年8月7日
    204
  • 合肥 大学科学装置

    合肥大学科学装置:探索未知世界的关键 合肥大学是一所历史悠久的综合性大学,拥有丰富的学术资源和科研实力。其中,科学装置是合肥大学的重要科研平台之一,它为学生们提供了探索未知世界的机…

    科研百科 2024年11月14日
    1
  • 科研项目答辩可能遇到的问题

    科研项目答辩可能遇到的问题 在科研项目答辩中,研究人员可能会面临许多挑战和问题。以下是一些可能会在科研项目答辩中出现的问题: 1. 如何解释实验结果?研究人员需要清晰地解释他们的实…

    科研百科 2025年1月4日
    0
  • RWC集团

    RWC集团是一家总部位于中国的跨国企业,成立于1999年,致力于提供高品质的电子产品和解决方案。集团总部位于中国深圳,并在中国其他城市和海外市场设有分支机构。 RWC集团是一家领先…

    科研百科 2025年1月2日
    0
  • 充分运用新媒体,推动检察党建新发展(充分运用新媒体,推动检察党建新发展工作)

    随着信息化进程的快速发展和普及,以网站、微博、微信、头条、抖音等新媒体平台为阵地的新兴传播介质,在媒体格局中的地位日益凸显,其应用已深深浸润普通大众的生活,并以其传播速度快、便捷及…

    科研百科 2023年2月18日
    300
  • 字节跳动的项目经理,是什么神仙存在?(字节跳动 项目经理)

    揭秘字节跳动项目经理:职场中的多面手与策略大师 在竞争激烈的互联网行业中,字节跳动凭借其强大的技术实力和创新能力,成为了行业的佼佼者。而在这样一家高速发展的公司中,项目经理的角色显…

    科研百科 2024年6月19日
    50
  • 知识管理软件2734899868

    知识管理软件:助力知识管理现代化 随着数字化时代的到来,知识管理已经成为一个日益重要的领域。作为知识管理软件,它们可以帮助人们更好地组织、存储、共享和利用知识,提高知识利用效率,实…

    科研百科 2024年10月2日
    22
  • 永济中车集团郭湘云

    永济中车集团郭湘云永济中车集团郭湘云,经历了前不久举行的《西京杂记》。此书是一个东北地区的小教史。作者通过真实的故事来解释南宋时期的种种危机。永济西江是哪里的永济九华(富阳市繁华区…

    科研百科 2024年11月27日
    2
  • 盲盒系统定制开发小程序APP源码搭建(盲盒制作小程序)

    盲盒系统定制开发,盲盒小程序开发,盲盒商城开发,盲盒APP开发。 互联网时代,社会发展日新月异,似乎一切皆有可能。 用互联网大佬的一句话说就是,站在风口上先,猪都能飞起来。 当今社…

    科研百科 2023年5月12日
    220
  • 产品项目管理系统

    产品项目管理系统 随着企业规模的不断扩大,产品项目管理系统已经成为了现代项目管理中不可或缺的一部分。产品项目管理系统可以提高项目管理的效率和质量,帮助企业更好地应对日益复杂的市场竞…

    科研百科 2024年7月14日
    68