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

相关推荐

  • 大学生自然科学科研项目推荐

    大学生自然科学科研项目推荐 随着科技的不断进步,大学生在自然科学领域的研究兴趣也在不断增长。在这个时代,大学生可以通过参与自然科学科研项目,拓展自己的学术视野,提高实践能力,同时也…

    科研百科 2024年4月8日
    106
  • 工商潜伏屠宰窝点 获涉嫌注水牛肉652斤

      lls  ▲执法人员现场查处注水牛肉 攸县工商 供图lls   (原标题:凌晨潜伏屠宰窝点,抓到牛肉注水现场)lls   攸县工商查获涉嫌注水牛肉652斤,涉案老板称…

    2022年6月7日
    352
  • 优秀党建创新项目 – “四问于民”党建引领为民办实事(党建惠民工程)

    为深入学习贯彻党的十九届六中全会精神,全面落实新时代党的建设总要求,进一步总结推广西城法院加强党的建设的创新做法和特色经验,近期,西城法院组织开展了党建创新项目评选活动。 此次评选…

    科研百科 2023年1月20日
    623
  • 料斗侧翻致1死!光明铁道控股有限公司5·21叉车事故查明(光明叉车厂家)

    11月23日,本报从衢州市应急管理局获悉,龙游光明铁道控股有限公司5·21叉车事故已于近日查明。据悉,2023年5月21日13时30分许,位于龙游县小南海镇的光明铁道控股有限公司厂…

    科研百科 2024年5月12日
    73
  • 艺术类科研项目

    艺术类科研项目 随着现代社会的不断发展,艺术类科研项目已经成为了现代科学领域中不可或缺的一部分。这些项目涉及音乐、绘画、舞蹈、戏剧、电影等多个领域,旨在探索人类艺术的本质和规律,以…

    科研百科 2024年11月9日
    0
  • 工程管理的系统性

    系统性工程管理:确保项目成功的关键因素 在工程管理中,系统性是非常重要的因素。系统性意味着整个项目团队需要协调工作,以确保项目的成功。本文将探讨系统性工程管理的概念,以及如何确保项…

    科研百科 2025年1月3日
    0
  • 哈尔滨科研项目报价 哈尔滨科研项目报价查询

    哈尔滨科研项目报价查询 哈尔滨是中国东北地区的一个大城市,拥有着悠久的历史和文化,同时也是中国重要的能源和重工业基地之一。随着科技的不断发展,哈尔滨也吸引了越来越多的科研项目前来投…

    科研百科 2024年7月30日
    42
  • 项目管理分为几部分

    项目管理:从整体到局部 项目管理是指组织或个人为了实现特定目标,通过规划、执行和控制一系列活动的过程。在现代商业环境中,项目管理已经成为了一项重要的技能和知识,对于组织的高效运营和…

    科研百科 2024年7月16日
    68
  • 试验项目管理

    试验项目管理: 确保项目成功的关键因素 试验项目管理是一个非常重要的领域,涉及到从计划到交付的整个过程中。成功的试验项目管理不仅可以提高项目的效率和质量,还可以为公司的声誉和利润带…

    科研百科 2024年9月16日
    27
  • 盘安镇畜牧站力争做好冻配改良工作

    oZv    积极推广黄牛冻配改良技术是优化和提升盘安镇牛群品系结构的主要措施,更是提升肉牛生产性能、增加农民收入重要途径。盘安镇畜牧兽医站以“提高业务技能、…

    2022年5月20日
    472