百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Qt使用教程:创建移动应用程序(二)

myzbx 2025-04-26 19:41 3 浏览

Qt Enterprise最新版下载>

创建Accelbubble主视图

当您倾斜设备时应用程序的主视图会显示一个SVG泡沫图像在屏幕上移动。为了在项目中使用Bluebubble.svg,您可以将其复制到项目目录中(QML文件相同的子目录中),该图像会出现在资源中。您也可以使用任何其他图像或QML类型来代替。

想要在Design模式下创建UI:

1. 在Projects视图中,双击MainForm.ui.qml文件来在Qt Quick Designer中打开它。

2. 在Navigator中选择RowLayout并点击Delete将其删除。

3. 在Library > QML Types中,选择Rectangle并将其拖动到导航器的Item中。

4. 在导航器中选择矩形框来编辑它们的属性:

  • 在ID字段中输入mainWindow,使其能够从其他地方引用矩形框。
  • 选择Layout标签,然后点击Fill to Parent按钮来锚定矩形框到项目中。

5. 在Library > Resources中,选择Bluebubble.svg并将其拖动到导航器的mainWindow中。

6. 在Properties面板的Id字段中输入bubble,使其能够从其他地方引用图片。

7. 在导航器中选择Export按钮来导出mainWindowbubble作为属性。

想要修改bubble的属性使其不支持Qt Quick Designer,因此,我们为它创建一个自定义的QML类型:

  • 选择Edit来在代码编辑器中打开MainForm.ui.qml。
  • 右键单击Image并选择Refactoring > Move Component into Separate File。
  • 在Component name字段中,输入Bubble并选择OK来创建Bubble.qml

在MainForm.ui.qml中Qt Creator创建一个引用到Bubble.qml。想要检查代码,您可以比较具有MainForm.ui.qml示例文件的MainForm.ui.qml和具有Bubble.qml示例文件的Bubble.qml。用户界面现在已经准备就绪,您可以切换到编辑模式编辑main.qml和Bubble.qml文件。

移动Bubble

新的项目向导添加样本代码到main.qml文件中来创建菜单项目和按钮。通过删除旧的代码并添加新的代码来修改样本代码。您已经从UI表单中删除了按钮,因此还需要从main.qml中删除相应的代码。

在代码编辑器中,编辑Bubble.qml来添加属性,我们将使用该属性来定位图片:

Image {
source: "Bluebubble.svg"
smooth: true
property real centerX
property real centerY
property real bubbleCenter
}

在代码编辑器中,编辑main.qml指定应用程序标题,通过以下的代码片段说明:

ApplicationWindow {
id: mainWindow
visible: true
width: 640
height: 480
title: qsTr("Accelerate Bubble")

使用bubble属性来定位图像:

MainForm {
anchors.fill: parent
bubble {
id: bubble
centerX: mainWindow.width / 2
centerY: mainWindow.height / 2
bubbleCenter: bubble.width / 2

然后基于新属性设置图像的X和Y位置:

x: bubble.centerX - bubble.bubbleCenter
y: bubble.centerY - bubble.bubbleCenter

}

然后基于加速度传感器值添加代码移动bubble:

1. 添加以下的import语句到main.qml中:

import QtSensors 5.5

2. 添加具有必要属性的Accelerometer类型:

Accelerometer {
id: accel
dataRate: 100
active: true

}

3. 添加以下JavaScript函数来计算基于当前加速度值的bubble的x和y的位置:

function calcPitch(x, y, z) {
return -(Math.atan(y / Math.sqrt(x * x + z * z)) * 57.2957795);
}
function calcRoll(x, y, z) {
return -(Math.atan(x / Math.sqrt(y * y + z * z)) * 57.2957795);
}

当加速度值变化时为Accelerometer类型的onReadingChanged信号添加以下的JavaScript代码:

onReadingChanged: {
var newX = (bubble.x + calcRoll(accel.reading.x, accel.reading.y, accel.reading.z) * 0.1)
var newY = (bubble.y - calcPitch(accel.reading.x, accel.reading.y, accel.reading.z) * 0.1)

if (isNaN(newX) || isNaN(newY))
return;

if (newX  mainWindow.width - bubble.width)
newX = mainWindow.width - bubble.width

if (newY  mainWindow.height - bubble.height)
newY = mainWindow.height - bubble.height

bubble.x = newX
bubble.y = newY
}

我们希望确保bubble的位置始终在屏幕的边界内。如果Accelerometer返回的不是数字(NaN),那么该值将会被忽略并且bubble位置不更新。

5. 在bubble的x和y属性中添加SmoothedAnimation操作使其运动看起来更加平滑。

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

购买Qt Enterprise最新正版授权!详情请"咨询在线客服"

新年新禧新气象,送礼送福送优惠!

本站文章除注明转载外,均为本站原创或翻译

相关推荐

让小球做圆周运动,你有几种办法?

最近在阅读外国技术文章中无意中发现了一个神奇的CSS属性motion-path,它可以让Dom元素可以按照自定义的路径移动。又想起了很久之前参加校招面试的时候,面试官问了我一个问题“能不能不借助库实现...

【聚焦全国两会】SVG漫画 | 诚可“桂” 事能“圆”

<animateattributeName="width"begin="click+0.1s"dur="0"fill="freeze"from="0"to="0"/><...

还能用 AI 生成 SVG(可缩放矢量图像)?我们来聊聊 SVG

文章链接:https://mp.weixin.qq.com/s/uWu4_yM5wb-eFkBlMBD-TA什么是SVGSVG(ScalableVectorGraphics,可缩放矢量图形)基于...

刚刚开源!SVG 向量图形生成模型

StarVector这个开源项目有点意思,3天前开源的:可以把图像和文本生成高质量的可缩放编辑SVG图形。由ServiceNowResearch、Mila等机构联合开发,并已被CVPR...

全能图片处理工具:GIMP 2.8.14正式版下载

IT之家(www.ithome.com):全能图片处理工具:GIMP2.8.14正式版下载GIMP是一款跨平台的图像处理工具,是GNU图像处理程序(GNUImageManipulationPr...

从零开始学Qt(22):QSS详解(3)- 盒子模型

使用样式表时,每个widget都被视为具有四个同心矩形的盒子:边距(margin)矩形、边框(border)矩形、填充(padding)矩形和内容(content)矩形。盒子模型(boxmodel)...

流程图用什么软件做?分享4款流程图绘制工具

在生活中,我们经常会使用流程图来绘制出一些事项的工作流程或过程,让整个过程看上去更直观清晰,并且能更好的了解到操作步骤或过程中各步骤的逻辑顺序,那么流程图用什么软件做呢?这里分享4款好用的流程图绘制工...

整理开源资源:零代码开发灵魂——逻辑引擎,收藏吧

逻辑配置是零代码开发的业务核心功能,本质上是实现服务的编排,把原子的服务通过可视化编排,形成最终的业务逻辑。经过小编的精心整理,把相关的资源全部汇总起来,收藏吧!Drawflow拖动节点多路输入/输出...

Qt中绘图框架介绍

绘图框架类父窗口继承1继承2QGraphicsSceneQGraphicsViewQGraphicsItemQAbstractGraphicsShapeItemQGraphicsEllipseItem...

矢量图都是什么格式的文件?

矢量图,也称为面向对象的图像或绘图图像,在数学上定义为一系列由点连接的线,矢量文件中的图形元素称为对象,它拥有颜色、形状、轮廓、大小和位置的等属性最大的优点是无论放大、缩小或者旋转等都不会失真,深受设...

免费PPT插件:PPT神器导航,亲测好用的120+辅助神器

插件开发:幻云PPT设计-大雄董军图文设计:大雄董军插件名称:PPT神器导航1.0当然了可能大家都有属于自己的神器收藏夹或者导航不过一直以来我听说并记录过很多故事关于PPT为了在一定程度上止痛主要功能...

超实用的一款国产工具!

往往在我们工作、生活、生产、研发等各领域经常会遇到需要绘制各类泳道流程图、思维导图、项目进度管理图、原型线框图、时序图、工艺流程图、关系图、拓扑图、组织结构、BPMN/UML、逻辑线框图、电路电气、示...

Qt使用教程:创建移动应用程序(二)

QtEnterprise最新版下载>创建Accelbubble主视图当您倾斜设备时应用程序的主视图会显示一个SVG泡沫图像在屏幕上移动。为了在项目中使用Bluebubble.svg,您可以将其...

图标(LOGO)绘制教程(一):今日头条

前言本次教程使用软件为:InkscapeInkscape是一款功能强大的免费设计工具。无论您是插画家、设计师、网页设计师,还是只是需要创建一些矢量图像的人,Inkscape都适合您!它具有以下功能...

鸿蒙开发:使用Ellipse绘制椭圆

前言本文基于Api13前边两篇文章,我们概述了几何图形矩形和圆形,分别使用Rect和Circle两个组件来实现,本篇文章,我们介绍另一个几何图形组件Ellipse,来实现一个椭圆图形。Ellipse是...