提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:鲍佳佳|2021-03-16 11:29:44.070|阅读 471 次
概述:本教程将逐步介绍如何使用QML创建完整的应用程序。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
QML高级教程1-创建游戏画布和块
Qt是一个跨平台框架,通常用作图形工具包,它不仅创建CLI应用程序中非常有用。而且它也可以在三种主要的台式机操作系统以及移动操作系统(如Symbian,Nokia Belle,Meego Harmattan,MeeGo或BB10)以及嵌入式设备,Android(Necessitas)和iOS的端口上运行。现在我们为你提供了免费的试用版。
Qt组件推荐:
创建应用程序屏幕
第一步是在您的应用程序中创建基本的QML项。
首先,我们使用以下主屏幕创建我们的Same Game应用程序:
这是由主应用程序文件定义的samegame.qml,如下所示:
import QtQuick 2.0 Rectangle { id: screen width: 490; height: 720 SystemPalette { id: activePalette } Item { width: parent.width anchors { top: parent.top; bottom: toolBar.top } Image { id: background anchors.fill: parent source: "../shared/pics/background.jpg" fillMode: Image.PreserveAspectCrop } } Rectangle { id: toolBar width: parent.width; height: 30 color: activePalette.window anchors.bottom: screen.bottom Button { anchors { left: parent.left; verticalCenter: parent.verticalCenter } text: "New Game" onClicked: console.log("This doesn't do anything yet...") } Text { id: score anchors { right: parent.right; verticalCenter: parent.verticalCenter } text: "Score: Who knows?" } } }
这为您提供了一个基本的游戏窗口,其中包括块的主画布,“新游戏”按钮和得分显示。
您在这里可能不认识的一项是SystemPalette项。这提供了对Qt系统选项板的访问,并用于使按钮具有更原始的外观。
请注意为锚Item,Button和Text类型是使用组(点)表示法为可读性设置。
添加Button和Block组件
上面代码中的Button项定义在一个单独的组件文件中,名为Button.qml。为了创建一个功能按钮,我们在一个矩形内使用QML类型Text和MouseArea。下面是Button.qml的代码。
import QtQuick 2.0 Rectangle { id: container property string text: "Button" signal clicked width: buttonLabel.width + 20; height: buttonLabel.height + 5 border { width: 1; color: Qt.darker(activePalette.button) } antialiasing: true radius: 8 // color the button with a gradient gradient: Gradient { GradientStop { position: 0.0 color: { if (mouseArea.pressed) return activePalette.dark else return activePalette.light } } GradientStop { position: 1.0; color: activePalette.button } } MouseArea { id: mouseArea anchors.fill: parent onClicked: container.clicked(); } Text { id: buttonLabel anchors.centerIn: container color: activePalette.buttonText text: container.text } }
这本质上是定义了一个包含文本并可以被点击的矩形。MouseArea有一个onClicked()处理程序,实现了当该区域被点击时发出容器的clicked()信号。
在同一游戏中,当游戏开始时,屏幕上充满了小块。每个块只是一个包含图像的项目。区块代码在单独的Block.qml文件中定义。
import QtQuick 2.0 Item { id: block Image { id: img anchors.fill: parent source: "../shared/pics/redStone.png" } }
目前,块并没有做任何事情,它只是一个图像。随着本教程的进展,我们将为图块添加动画和行为。我们还没有添加任何代码来创建块,我们将在下一章中进行。
我们已经使用anchors.fill: parent将图像设置为其父项的大小。这意味着,当我们在教程的后面动态创建和调整块项的大小时,图像将自动调整为正确的大小。
注意Image类型的源属性的相对路径。这个路径是相对于包含Image类型的文件的位置而言的。另外,您也可以将Image源设置为绝对文件路径或包含图像的URL。
到目前为止,你应该已经熟悉了这些代码。我们刚刚创建了一些基本类型来开始。接下来,我们将在游戏画布中填充一些块。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn
文章转载自:本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
一个跨平台的C++图形用户界面应用程序开发框架。
QtitanDataGrid一个独特的Qt开发框架产品,吸收了Delphi、C++以及其他语言的优点
QtitanRibbon专业全面 & 实现Qt技术的跨平台Ribbon UI组件
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@cahobeh.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢