提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|使用教程|编辑:龚雪|2016-01-06 09:18:18.000|阅读 1071 次
概述:本教程主要介绍了如何使用Qt Quick控件为Android和iOS设备开发Qt Quick应用程序。我们使用Qt Creator实现Qt Quick应用程序加速基于加速度值变化的SVG(可伸缩向量图形)图像。
#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>
相关链接:
当您倾斜设备时应用程序的主视图会显示一个SVG泡沫图像在屏幕上移动。为了在项目中使用,您可以将其复制到项目目录中(QML文件相同的子目录中),该图像会出现在资源中。您也可以使用任何其他图像或QML类型来代替。
想要在Design模式下创建UI:
1. 在Projects视图中,双击MainForm.ui.qml文件来在Qt Quick Designer中打开它。
2. 在Navigator中选择RowLayout并点击Delete将其删除。
3. 在Library > QML Types中,选择Rectangle并将其拖动到导航器的Item中。
4. 在导航器中选择矩形框来编辑它们的属性:
5. 在Library > Resources中,选择Bluebubble.svg并将其拖动到导航器的mainWindow中。
6. 在Properties面板的Id字段中输入bubble,使其能够从其他地方引用图片。
7. 在导航器中选择Export按钮来导出mainWindow和bubble作为属性。
想要修改bubble的属性使其不支持Qt Quick Designer,因此,我们为它创建一个自定义的QML类型:
在MainForm.ui.qml中Qt Creator创建一个引用到Bubble.qml。想要检查代码,您可以比较具有MainForm.ui.qml示例文件的MainForm.ui.qml和具有Bubble.qml示例文件的Bubble.qml。用户界面现在已经准备就绪,您可以切换到编辑模式编辑main.qml和Bubble.qml文件。
新的项目向导添加样本代码到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 {
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 < 0)
newX = 0
if (newX > mainWindow.width - bubble.width)
newX = mainWindow.width - bubble.width
if (newY < 18)
newY = 18
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属性中添加操作使其运动看起来更加平滑。
Behavior on y {
SmoothedAnimation {
easing.type: Easing.Linear
duration: 100
}
}
Behavior on x {
SmoothedAnimation {
easing.type: Easing.Linear
duration: 100
}
}
购买Qt Enterprise最新正版授权!详情请""
新年新禧新气象,送礼送福送优惠!优惠详情点击查看>>
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@hmdbvip.cn
文章转载自:慧都控件网



在现代软件开发过程中,自动化单元测试是确保代码质量与可靠性的关键环节。尤其对于特定框架(如MFC)的代码,测试复杂度显著增加,常因依赖外部资源或交互操作而难以在静默环境中顺利执行。Parasoft C/C++test作为专业的软件测试工具,致力于帮助开发团队高效实施自动化测试,通过其强大的桩函数功能,能够有效模拟依赖组件的行为,从而实现对复杂逻辑的隔离测试。
本文将为大家介绍如何在MyEclipse中使用XDoclet开发EJB 2 Session Bean,欢迎下载最新版体验!
如果能将 CSV 自动转换为 PDF ,就能快速生成清晰、美观的报表,既节省手动排版时间,又能保持数据的专业呈现。本文将介绍如何使用 Spire.XLS for Java 实现这一过程——从加载 CSV 到输出高质量 PDF,仅需数行代码即可完成。
Parasoft C/C++test是一款专为C/C++代码设计的自动化测试工具,通过静态代码分析、单元测试和运行时错误检测等功能,帮助开发团队在早期发现并修复缺陷,提升代码质量和开发效率 。在实际使用中,尤其是在VC6此类旧版开发环境中执行单元测试时,可能会因环境兼容性问题触发链接错误。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@hmdbvip.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
永利最大(官方)网站