2019-07-03 16:45:58 +08:00
# GuiLite( 超轻量UI框架) - 最小的GUI库
2019-06-13 09:44:37 +08:00
data:image/s3,"s3://crabby-images/cde5c/cde5c15bc7110c9f0a48c3838f2cbd9b30e25e35" alt="badge_build " data:image/s3,"s3://crabby-images/5eca4/5eca4c94579126a77fdbe9470a154d071cf0b3e8" alt="badge_docker " data:image/s3,"s3://crabby-images/68e8d/68e8d3eb9071e7a2542d42311142bd5469393590" alt="badge_platform " data:image/s3,"s3://crabby-images/97baf/97bafb7a49a2ce5c4a0896a3b7d9ab47f68aa210" alt="badge_lincense " data:image/s3,"s3://crabby-images/d1be0/d1be0dedf4d1968524efc82a94f2dd5d28fecd4d" alt="badge_lincense "
- [功能介绍 ](#功能介绍 )
- [快速上手 ](#快速上手 )
- [开发文档 ](#开发文档 )
- [学习方法 ](#学习方法 )
- [视频链接 ](#视频链接 )
2019-06-25 13:51:03 +08:00
- [🙏致谢和❤️慈善 ](#致谢和慈善 )
2019-06-13 09:44:37 +08:00
***
## GuiLite是什么鬼?
- GuiLite是5千行代码的**全平台UI框架**,可以完美运行在: iOS, Android, Linux( ARM/x86-64) , Windows( 包含VR) , Mac, Docker和**有(无)操作系统的MCU**上。
- GuiLite可以嵌入在iOS、Android、MFC、QT等其他UI系统中, 让你的界面集百家之长, 又不失个性。
- GuiLite与操作系统及第三方图形库无关, 甚至也可以运行在无OS的单片机环境。
- GuiLite鼓励混合编程, 开发者可以用GuiLite接管UI部分, 用Swift, Java, Golang, C#, Python开发业务部分。
- 🔧不鼓励大家全盘接受GuiLite, 更愿意大家自主定制GuiLite
- ⚙️ 希望GuiLite小到足够帮助大家掌握UI工作原理, 从而摆脱UI框架的束缚, 构建自己独一无二的UI
- 👑任何UI框架都不为你我而生, 你才是自己真正的主人
2019-07-06 14:08:12 +08:00
## 🔥新功能: 3D
2019-07-08 18:10:58 +08:00
data:image/s3,"s3://crabby-images/71177/7117794c38e34b356ecd3b87b817f13753c6ecf5" alt="Hello3D-pc "data:image/s3,"s3://crabby-images/6da98/6da986d30da0330a7c2f29166f63c9b2101725ca" alt="Hello3D-mcu "
2019-07-06 14:08:12 +08:00
2019-07-06 15:44:28 +08:00
Hello 3D 仅有[100多行代码](https://gitee.com/idea4good/GuiLiteSamples/blob/master/Hello3D/UIcode/UIcode.cpp), 用于向初学者展示: 如何使用GuiLite模拟3D物理过程。该实例可支持Windows, Linux及单片机平台。
2019-06-13 09:44:37 +08:00
## 功能介绍
### 卓越的跨平台能力
| ARM Linux | STM32 Without OS |
| --- | --- |
| data:image/s3,"s3://crabby-images/95d5f/95d5fe542bba3b8258868f00afb89d57056589fd" alt="ARM Linux " | data:image/s3,"s3://crabby-images/2f51d/2f51d3cbe6cea9c6606d71bbde74cd5c7ac91444" alt="MCU " data:image/s3,"s3://crabby-images/89d69/89d69ab347d052164d79baa138c31cd5e5b1f021" alt="MCU " |
| Windows Mixed Reality | Android |
| --- | --- |
| data:image/s3,"s3://crabby-images/bdd91/bdd9169a0591c125a3350c1cc382f50e0b57d10b" alt="Win MR " | data:image/s3,"s3://crabby-images/98b54/98b54fc5633f0d281d87aaf95155348aab6efa3a" alt="Android " |
| macOS | iOS |
| --- | --- |
| data:image/s3,"s3://crabby-images/c9386/c93868714c171289600478209771cc72d1dc0997" alt="macOS " | data:image/s3,"s3://crabby-images/d4129/d41295faffd56da5c97979bfdb8b61d403e73894" alt="iOS " |
***
2019-07-06 14:08:12 +08:00
### GuiLite Previewer(所见即所得的GuiLite开发插件)
[GuiLite Previewer ](https://github.com/idea4good/GuiLitePreviewer )是一个Visual Studio Code插件, 它可以自动提取源代码的GUI布局信息, 并实时显示在“预览”页面上(所见即所得)
data:image/s3,"s3://crabby-images/6fe2b/6fe2ba5cc9caf4880b7c9cc54b47673c94c901d5" alt="GuiLitePreviewer "
***
2019-06-13 09:44:37 +08:00
### 支持Docker容器
我们把GuiLite demo做成了Docker映像, 只需一行命令, 就可以将最新的GuiLite demo升级/部署/运行在你的设备上了。
- `sudo docker run -it --privileged -v /dev:/dev-share idea4good/gui-lite:latest bash /run.sh`
***
### 易于定制界面
data:image/s3,"s3://crabby-images/719a6/719a67a3d27f101dbad6341bebb57ed24429fa21" alt="wallpaper "
***
### 万国语(unicode):
data:image/s3,"s3://crabby-images/902a0/902a0a1299c65bf77460a62ff3acbb526a4ca9ba" alt="unicode "
***
### “换肤”功能
data:image/s3,"s3://crabby-images/cfd63/cfd63b7b8d5a4144aca68263c66dbe344b69c87b" alt="multi-theme "
***
### IoT( 物联网) 功能
- 上报“编译/运行”情况至“云端”:< br > data:image/s3,"s3://crabby-images/a0214/a0214e24e849b57cd69de9175ec816b3601e8ea5" alt="BuildInfo"
- 同步“运行数据”至“云端”:< br > data:image/s3,"s3://crabby-images/47a05/47a05de1bf05e961a7dd196a1611728f42ed4658" alt="DataOnCloud"
***
## 快速上手
GuiLite只是一个框架, 本身并不能生成UI。为了能够展示如何用GuiLite开发App, 我们提供了一些实例程序给大家参考。
- 实例程序的代码在[这里](https://gitee.com/idea4good/GuiLiteSamples)。
- 实例程序的功能说明:
| 实例名称 | 支持的平台 | 功能简介 | 编译方法 | 难度 |
| --- | --- | --- | --- | --- |
| HelloParticle | Windows, Linux, STM32F103, STM32F429 | 粒子效果的应用 | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloParticle/README.md ) | ★|
| HelloStar | Windows, Linux, STM32F103, STM32F429 | 星空效果的应用 | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloStar/README.md ) | ★|
2019-07-06 15:44:28 +08:00
| Hello3D | Windows, Linux, STM32F103 | 3D物理过程的应用 | [Build ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/Hello3D/README.md ) | ★★ |
2019-06-13 09:44:37 +08:00
| HelloGuiLite | Windows, Linux | 初始化GuiLite, 加载资源, 布局界面元素, 按钮响应 | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloGuiLite/README.md ) | ★★|
| HelloWidgets | Windows, Linux | 用于演示基本控件的使用方法 | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloWidgets/README.md ) | ★★|
| HelloMario | Windows, Linux, STM32F103, STM32F429 | 多图层的UI系统 | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloMario/README.md ) | ★★|
| HelloNoTouch | Windows, Linux, STM32F103, STM32F429 | 用于非触摸屏场景, 通过硬按键进行UI“导航” | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloNoTouch/README.md ) | ★★|
| HelloFont | Windows, Linux | 显示多种语言(不限:中、英文) | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloFont/README.md ) | ★★|
| HelloAnimation | Windows, Linux | 动画的应用 | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloAnimation/README.md ) | ★★|
| HelloSlide | Windows, Linux | 滑屏界面的应用 | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloSlide/README.md ) | ★★★|
| HelloWave | Windows, Linux, STM32F103, STM32F429 | 波形控件的应用,及单片机移植办法 | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HelloWave/README.md ) | ★★★|
| HostMonitor | iOS, Mac, Android, Windows, Linux | 创建复杂界面,扩展自定义控件,适配全平台 | [编译/运行 ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HostMonitor/README.md ) | ★★★★|
## 开发文档
GuiLite是最简单, 易学的GUI库。
1. 只有5千行C++代码
2. 只使用C++的基本特性(类和虚函数),不涉及复杂语法
3. 图形绘制以描点为基础,不使用任何算法
4. 设计简单, 配有丰富的文档和实例程序; 遇到问题, 可以在QQ群获得帮助
- [软件设计说明 ](doc/HowToWork-cn.md )
- [如何编译? ](doc/HowToBuild.md )
- [如何布局UI? ](doc/HowLayoutWork.md )
- [如何制作多种文字/位图资源? ](https://github.com/idea4good/GuiLiteToolkit )
- [如何“换肤”? ](https://gitee.com/idea4good/GuiLiteSamples/blob/master/HostMonitor/UIcode/source/resource/resource.cpp )
- [如何传递消息? ](doc/HowMessageWork.md )
- [核心UML示意图 ](doc/UML.md )
## 学习方法
1. **外围** - 成功编译GuiLite库
2. **前戏** - 成功运行HelloXXX实例程序
3. **交流** - 研读/修改100+行的`HelloXXX/UIcode/UIcode.cpp`源代码
4. **深交** - 研读`gui`目录下的代码
5. **攻核** - 研读`core`目录下的代码
6. **分家** - 丰富, 扩展自己的UI功能
## 视频链接:
- [GuiLite简介 ](https://v.youku.com/v_show/id_XMzA5NTMzMTYyOA )
- [3D GuiLite ](https://v.youku.com/v_show/id_XMzYxNTE3MTI0MA )
- [GuiLite + 单片机 ](https://v.youku.com/v_show/id_XNDAwNzM5MTM3Ng )
## 镜像代码仓库
[GitHub链接 ](https://github.com/idea4good/GuiLite )
2019-06-25 13:51:03 +08:00
## 致谢和慈善
2019-06-13 09:44:37 +08:00
- 感谢开发者群的所有同学, 是你们塑造了今天的GuiLite! 也欢迎新的大神/小白加入我们。< br > [< img src = "doc/qq.group.jpg" > ](https://jq.qq.com/?_wv=1027& k=5EO8D9i)
2019-07-03 16:45:58 +08:00
- [赞助 & 救助大病儿童 ](https://idea4good.github.io )