提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:鲍佳佳|2020-12-28 14:18:52.313|阅读 424 次
概述:这是一个针对Qt Quick的触摸设备游戏,该游戏使用SpriteSequence,ParticleSystem,Emitter和Wander类型对对象进行动画处理,并使用SoundEffect类型来播放声音效果。
#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>
相关链接:
用Qt编写GUI的另一种方法是使用QtQuick模块。使用QtQuick的GUI是用QML编写的。QML是一种声明性的对象描述语言,它集成了Javascript进行程序化编程。QtQuick为使用QML开发GUI提供了必要的模块。可以只用QML编写整个应用程序,但通常只有GUI是用QML编写的,应用程序的后台是用C++实现的(参见整合QML和C++)。
一个针对Qt Quick的触摸设备游戏,该游戏使用SpriteSequence,ParticleSystem,Emitter和Wander类型对对象进行动画处理,并使用SoundEffect类型来播放声音效果。
《麻烦的马龙》展示了QML功能,这些功能在开发游戏时非常有用:
运行示例
要从Qt Creator运行示例,请打开“欢迎”模式,然后从“示例”中选择示例。有关更多信息,请访问构建和运行示例。
添加画面
在Maroon in Trouble应用程序中,我们使用以下自定义类型(分别在单独的.qml文件中定义)创建游戏屏幕:
要使用自定义类型,我们在主QML文件maroon.qml中添加了一个import语句,该语句将导入名为content类型所在位置的文件夹:
import "content"
我们在游戏的不同阶段使用屏幕类型。NewGameScreen类型用于创建玩家启动应用程序时出现的屏幕。在NewGameScreen.qml中,我们使用“图像”类型创建“新游戏”按钮,玩家可以按此按钮来开始新游戏。
轻击该按钮将启动一个倒数计时器,该倒计时计时器将通过使用GameCanvas类型触发游戏画布的创建。另一种“计时器”类型会在气泡内生成小鱼,玩家必须先将其释放才能到达水面。玩家可以点击屏幕来打开菜单,在这里他们可以购买不同类型的武器(近战,远程和炸弹)以破灭泡泡。
游戏结束时,出现使用GameOverScreen类型创建的屏幕。在此屏幕上,玩家可以查看他们的分数并开始新的游戏。
这些屏幕都是在相同的背景上创建的,并使用某些相同的图像和动画。
构造背景
在maroon.qml文件中,我们使用带有ID以及固定宽度和高度的Item类型root来创建游戏的主窗口:
Item{
id: root
width: 320
height: 480
property var gameState
property bool passedSplash: false
我们宣布了根项目两个自定义属性,gameState并且passedSplash我们将在后面使用管理的游戏状态。
我们使用一个Image项来显示游戏背景图像:
Image { source:"content/gfx/background.png" anchors.bottom: view.bottom
我们希望能够在应用启动时仅加载一次背景图片,并且仍将不同的场景用于游戏屏幕。因此,background.png是根项目长度的三倍,并显示一个场景,该场景从海底延伸到地平线上方的天空。
我们使用该anchors.bottom属性将背景图像锚定到我们用来放置屏幕的Column布局的底部:
Column {
id: view
y: -(height - 480)
width: 320
GameOverScreen
{
gameCanvas: canvas
}
我们为该y属性设置一个负值,以将第一个场景设置在海底。我们通过从height属性中减去屏幕的高度来计算位置。
在列布局中,我们使用Item类型将对象添加到背景。在该项目内,我们使用行布局对象定位图像对象,这些对象在游戏画布和游戏屏幕上方显示波浪:
Item {
id: canvasArea
width: 320
height: 480
Row { height: childrenRect.height
Image {
id: wave
y: 30
source:"content/gfx/wave.png"
}
Image {
y: 30
source:"content/gfx/wave.png"
} ... Row {
opacity: 0.5
Image {
id: wave2
y: 25
source: "content/gfx/wave.png"
}
Image
{
y: 25
source: "content/gfx/wave.png"
}
第二行波位于y轴上,与第一行略有偏移。我们还使用该opacity属性使波浪的颜色看起来比前两个波浪更浅,从而使背景更深。
我们使用Image对象还在新游戏屏幕和游戏画布上显示阳光:
Image {
source: "content/gfx/sunlight.png"
opacity: 0.02
y: 0
anchors.horizontalCenter: parent.horizontalCenter
...
Image {
source: "content/gfx/sunlight.png"
opacity: 0.04
y: 20
anchors.horizontalCenter: parent.horizontalCenter
我们将opacity图像的属性设置为,0.02并0.04赋予阳光一定的深度。我们使用y属性将图像定位在y轴上的固定位置,并使用属性将图像anchors.horizontalCenter相对于其父对象水平居中。
我们使用一个图像类型来显示一个在背景上加深阴影的图像:
Image {
source: "content/gfx/grid.png"
opacity: 0.5
}
}
我们将opacity图像的属性设置0.5为使背景在阴影后可见。
为了使背景更有趣,我们为添加到其中的一些对象设置了动画。下面我将详细讲解如何构建动画背景对象 。
Qt常用组件:
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@hmdbvip.cn
文章转载自:



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