Qt 5.7 > Qt Applications
本文翻译自Qt官方文档:
http://doc.qt.io/qt-5/qmlapplications.html
QML 应用
QML是声明式语言,它使得用户界面以及交互行为可以被“描述”出来。这是一种可读性非常高、动态互联其中的构件的语言,并且它允许构件可以非常容易的被重用和界面自定义。使用QtQuick模块,设计者和开发者可以使用QML开发流畅的动画界面,也可以选择将用户界面与后端的C++库连接起来。
什么是QML?
QML是用户界面规范与编程语言。它使得开发者和设计者可以开发出高性能,流畅动画、美观的应用。QML提供高可读性,声明式的,语法类似 JSON 的、支持命令式的 JavaScript 表达式与动态属性绑定。
QML语言以及引擎架构由 Qt QML 模块提供。更多介绍参见 Qt QML 文档。
下面这些页面包含了更多QML说明:
- 使用QML第一步 —— 通过这些实例程序来开始了解QML
- 在 Qt Creator 中创建 Qt Quick 项目
- QML 帮助文档 —— QML的结构和特性说明
- QML 编码约定
- QML 术语表
什么是 Qt Quick?
Qt Quick 是QML的类型和功能标准库。 它包含了虚类型,交互类型,动画,模型和视图,材质特效和阴影特效。一个QML应用开发者使用一句简单的语句即可使用所有这些功能。
Qt Quick QML库由 QtQuick 模块提供,Qt Quick 模块文档包含了更多关于QML类型和别的功能的描述。
QML用户界面
为了创建一个自定义的图形用户界面,除了QML标准类型意外,QtQuick 还从Qt QML中添加了类型、动画类型,以及其他QML类型。 Qt Quick Designer 集成在了 Qt Creator 中,它支持 QtQuick 2、QtCreator 2.7 。
- QML中的虚类型
- QML中响应用户输入
- QML中的动画
- 在QML中显示文本
- QML中的布局处理器
- 风格和主题支持
- 在QML中集成 JavaScript
- 缩放
按钮、菜单、以及其他控件
基本 UI 控件中, Qt Quick 控件模块实现了许多诸如按钮、菜单、视图。 这些控件会模仿不同平台(windows,mac,Linux)的原生风格。
- Qt Quick 控件概览
- 风格
- 对话框
- 布局
- 其他
特效
一些Qt模块提供了创建特效的类型,详细信息参看:
- 材质效果
- 图形效果 —— 创建图片特效
在QML应用中浏览网页内容
QML类型:WebEngineView 和 WebView ,可以渲染并且显示动态网页内容。它俩之间唯一的不同就是:如果允许,那么WebView会使用原生的网页视效。这两种类型都可以加载URL和HTML字符串信息。更多示例程序和信息,参见 Qt WebEngine 和 Qt WebView。
传感器、收拾和触摸屏界面
Qt Sensors 模块允许程序读取来自传感器中的信息,比如加速器、倾斜测量仪。这些QML API 对于不同平台都提供了,并且可以使用C++来拓展。
- Qt Sensors QML类型
- Qt 传感器 示例程序
- 通用地图 —— 列出了不同手机平台支持的级别。
多媒体内容
Qt Multimedia 模块使程序可以通过使用一个方便的QML类型集合来处理各种多媒体内容。这些QML类型也可以使用C++进行拓展。
- 多媒体
- 声音
- 视屏
- 摄像头
- 广播
- Qt Audio Engine —— 3D环绕声和内容管理
移动设备
一些Qt模块为网络和移动设备提供了 QML API 支持。 QML类型提供对蓝牙、短距离通信(NFC),和GPS的设备的支持。
- Qt 定位
- Qt 方位
- Qt 蓝牙
- Qt 短距离通信
更多参见:网络和连接、移动API页面。
代码示例和程序示例
更多QML代码,演示如何使用QML类型,另外,还有很多程序示例演示如何在应用程序中使用QML代码。
- 从使用Qt Quick开始 —— 一个简单的QML编辑器教程
- Qt Quick 示例和教程
高级应用开发部分
- 发布QML程序
- 性能表现的思考与建议
- 国家化与区域
- 测试与调试:
- qmlscene 雏形
- 调试QML程序
- Qt Quick测试:QML单元测试框架
其他一些QML模块
Qt Quick 只提供了一些基本的虚类型,很多Qt的功能都通过别的模块暴露给了QML。如果你要用到这些功能,你需要参考他们的QML文档。
所有QML模块API 包含了Qt5中QML的模块列表。
相关话题
把QML应用移植到Qt5
Qt 5.7 > Qt Applications的更多相关文章
- Qt... configure: error: Qt (>= Qt 2.2.2) (headers…
转载:http://blog.chinaunix.net/uid-23733724-id-290980.html 昨天开始在自己的fedora12下装qt~ 但是按照教程在/opt/Embed ...
- Qt环境搭建(Qt Creator)+Visual Studio
1.http://www.cnblogs.com/ranjiewen/p/5318768.html 简述 经常有人问我编写Qt程序时使用什么IDE,其实这个真的很难回答(各有所长),只能说看个人爱好了 ...
- Qt Creator提示"Qt没有被正确安装,请运行make install"的解决办法
笔者最近使用Qt在开发一些小程序,觉得这个框架设计确实很好,使用了信号和槽解决了组件之间的通讯问题,可以说是基于C++语言上一个非常大的创新,大大提高了开发人员的编码效率,也使整个C++语言更加抽象. ...
- Qt学习记录--Qt::CaseSensitive
Qt::CaseSensitivity 为枚举类型, 可取值Qt::CaseSensitive 和 Qt::CaseInsensitive, 表示匹配的灵敏度. 比较字符串的时候 Qt::CaseSe ...
- qt widget设置Qt::FramelessWindowHint和Qt::WA_TranslucentBackground, 会出现一个bug: 在最小化后还原时界面停止刷新
qt widget设置Qt::FramelessWindowHint和Qt::WA_TranslucentBackground, 会出现一个bug: 在最小化后还原时界面停止刷新 Widget wit ...
- 【Qt】关于Qt【转】
什么是Qt Qt是一个针对桌面.嵌入式.移动设备的一个跨平台的应用程序开发框架,支持的平台包括Linux.OS X.Windows.VxWorks.QNX.Android.iOS.BlackBerry ...
- :: error: 无法打开文件“d:\Qt\2010.05\qt\lib\qtmaind.lib”
新建一个工程马上编译也会出现这个错误:: error: 无法打开文件“d:\Qt\2010.05\qt\lib\qtmaind.lib” vc的编译器, 而你安装的是mingw版本的qt. 工具-选项 ...
- Qt on Android:让 Qt Widgets 和 Qt Quick 应用全屏显示
Android 系统版本号非常多,较新的 4.4 ,较老的 2.3 ,都有人用. Qt on Android 开发的 Android 应用.默认在 Android 设备上是非全屏的. 而有些应用的需求 ...
- Qt入门学习——Qt 5 帮助文档的使用
Qt入门学习——Qt 5 帮助文档的使用 学习图形界面开发,肯定离不开帮助文档的使用,因为它不像 C 语言那样就那么几个函数接口,图形接口的接口可以用海量来形容,常用的我们可能能记住,其它的真的没有必 ...
随机推荐
- jvm回收方法区
很多人认为方法区(或者HotSpot虚拟机中的永久代)是没有垃圾收集的,Java虚拟机规范中确实说过可以不要求虚拟机在方法区实现垃圾收集,而且在方法区进行垃圾收集的“性价比”一般比较低:在堆中,尤其是 ...
- js 数组常用的操作函数整理
平时多做企业应用开发,抱着实用为主,对前端技术理解得比较肤浅,下面就是肤浅地对 js 数组的属性和方法及对它操作的 jquery 方法做些记录: js 数组是 js 内建的一个非常强大数据类型,由于 ...
- 结构-行为-样式-Bootstrap笔记
1.自上而下的内容布局,中间内容可变,应该用: <div class=" container-fluid"> <div class=" row" ...
- C语言之逻辑运算符
一 逻辑运算符: &&:逻辑与,读作并且 表达式左右两边都为真,那么结果才为真 口诀:一假则假 ||:逻辑或,读作或者 表达式左右两边,有一个为真,那么结果就为真 口诀:一真则真 !: ...
- 【Java每日一题】20170110
20170109问题解析请点击今日问题下方的"[Java每日一题]20170110"查看(问题解析在公众号首发,公众号ID:weknow619) package Jan2017; ...
- React一些必须要知道的基础
React 起源于 Facebook 的内部项目,因为该公司对市场上所有 JavaScript MVC 框架,都不满意,就决定自己写一套,用来架设 Instagram 的网站.做出来以后,发现这套东西 ...
- Docker集群实验环境布署--swarm【6 配置上层Nginx代理,让任意Docker client访问得到高可用的管理API】
10.40.42.10上,也就是对应的VRRP中的10.40.42.1和2上,配置nginx tcp代理 # cat 4000_manager.venic.com_10.40.100.141-14 ...
- Bootstrap UI层收藏介绍
Table组件使用的是bootstrap table,之所以用它是因为它的API比较全,并且博主觉得它的风格适用于各种类型的设备,无论是PC端还是手机端都都能很好的兼容各种浏览器.现将相关内容收藏如下 ...
- 【Python】32. Longest Valid Parentheses
Given a string containing just the characters '(' and ')', find the length of the longest valid (wel ...
- 如何将MongoDB数据库的数据迁移到MySQL数据库中
FAQ v2.0终于上线了,断断续续忙了有2个多月.这个项目是我实践的第一个全栈的项目,从需求(后期有产品经理介入)到架构,再到设计(有征询设计师的意见).构建(前端.后台.数据库.服务器部署),也是 ...