简称T2D,由Toou团队精心打造的Qt(quick) 2D框架,采用自身接口规范编写,它可以在开源和商业应用程序中免费使用,简洁的代码结构易于扩展与修改,完美地兼顾了应用的性能与动态性,解决了组件少、臃肿低效、无皮肤定制的问题。Toou2D使用门槛极低无需深入学习简单易用可拿来即用。从核心代码到组件Api的每一处细节都经过精心雕琢,非常适合App界面的快速开发。
以下功能毫无保留已全部开源!!!
使用Toou2D 开发的Demo 效果
需要Qt 5.6 或更高版本。
- 将项目clone到本地 使用Qt creator 打开 Toou-2D.pro
- 构建 (先构建后运行)
- 运行。即可看到demo预览效果。
支持 macOS ,Windows 构建,可发布到 macOS,Windows,iOS,Android等多平台。
| 组件名称 | 简短说明 |
|---|---|
| TAvatar | 用图标、图片或者字符的形式展示用户或事物信息 |
| TAwesomeIcon | 超级流行的 Font Awesome icon |
| TBadge | 出现在按钮、图标旁的数字或状态标记 |
| TBusyIndicator | 加载数据时显示动效 |
| TButton | 常用的操作按钮 |
| TCarousel | 在有限空间内,循环播放同一类型的图片、文字等内容 |
| TCheckBox | 一组备选项中进行多选 |
| TDialog | 在保留当前页面状态的情况下,告知用户并承载相关操作 |
| TDialogBasic | 可以自定义弹出效果的Dialog |
| TDialogButton | 嵌入在Dialog body 底部的操控按钮 |
| TDividerLine | 一条线段、分割线、底线 |
| TFlickable | 内容可拖拽,自带上下以及左右拖动进度条 |
| TFpsMonitor | FPS监控,监控软件性能相当重要 |
| TIcon | 提供了一套常用的图标集合,根据source不同自动加载 |
| TIconButton | 带有icon的按钮 |
| TImage | 显示一张图像,可以是Qt支持的所有格式 |
| TImageButton | 使用图像来制作一个按钮 |
| TInputField | 通过鼠标或键盘输入字符 |
| TLabel | 呈现文本给用户 |
| TMask | 遮罩功能,可以指定给用户显示某一特定区域 |
| TMouseArea | 接收并相应鼠标以及触控区域 |
| TNavigationBar | 为应用提供导航功能 |
| TObject | 在Qt基础上加了一丢丢小改善 |
| TPagination | 当数据量过多时,使用分页分解数据。 |
| TPopover | 模态任意位置弹出框 |
| TPopoverMenu | 模态任意位置弹出菜单框 |
| TPopup | 显示了一个弹出式窗口,需要自定义body |
| TProgressBar | 用于展示操作进度,告知用户当前状态和预期 |
| TRadioBox | 在一组备选项中进行单选 |
| TRadioBoxGroup | 管理一组RadioBox,组内只能选其一 |
| TRectangle | 矩形色块区域 |
| TSVGIcon | Svg 图标 |
| TScrollbarH | 横向滚动条,可操控ListView,GridView,Flickablet等等 |
| TScrollbarV | 竖向滚动条,可操控ListView,GridView,Flickablet等等 |
| TSwitch | 表示两种相互对立的状态间的切换,多用于触发「开/关」 |
| TTag | 用于标记和选择 |
| TToast | 轻量级的消息反馈,以小弹框的形式出现 |
| ... | 未完待续,请关注下一个版本的更新。 |
首先T2D的皮肤数据全部定义在 ini文件中,这些ini配置文件可以写在应用内也可以是应用的外部。通过修改ini节点属性及简单通用的规则即可实现完美的皮肤制作。
在Example中,我们为您配置了两款默认皮肤研究参考,没有皮肤的App是没有生命力的。
TThemeBinder组件与主题样式数据绑定在一起。废话不说看代码,如下:
//!当主题发展改变,Rectangle也会改变他的 color , width
//!同时不会打破 width 的原有绑定
Rectangle{
id:rect;
width : parent.width;
height: 100;
color : "red";
TThemeBinder{
id:theme
className: "MRect"
property alias color: rect.color;
property alias width: rect.width;
property alias height: rect.height;
}
}
我们提供了在线与离线两种文档方式。离线文档支持Qt create(F1) 与 Qt Assistant
| 平台 | 结果 | 平台 | 结果 | 平台 | 结果 |
|---|---|---|---|---|---|
| Windows 7 | OK | Windows 10 | OK | iOS iPad mini | OK |
| macOS 10.12 | OK | macOS 10.14 | OK | iOS iPhone XR | OK |
| Android 华为 4.4 | OK | Android 小米 7.0 | OK | iOS iPhone 8 plus | OK |
| Android Mi Pad 8.0 | OK | Android vivo 8.0 | OK | iOS iPhone 6 | OK |
以前 Ctrl + C 过你们的代码,今天Toou也给了你们一个Ctrl + V 的机会。
Toou 感谢关注,点个小星星呗!~