130 lines
8.3 KiB
Markdown
130 lines
8.3 KiB
Markdown
<p align="center">
|
||
<img src="documents/GuiLiteCube.gif" alt="Image" width="320" height="304"/>
|
||
</p>
|
||
|
||
# GuiLite - The smallest GUI library
|
||
data:image/s3,"s3://crabby-images/ac9ff/ac9ff0c947e15cf5c2b1b64a4e005ac180ba09b2" alt="badge_build" data:image/s3,"s3://crabby-images/99413/994137ab3d493e1e919d33b4bd6ecf121a98dc1e" alt="badge_docker" data:image/s3,"s3://crabby-images/2432c/2432c73e05ad1dc4ca4848042b977b6fdeabdcc3" alt="badge_platform" data:image/s3,"s3://crabby-images/8b0ed/8b0ed59243d4fdd66aa2e0f686d043c6a6ee752b" alt="badge_lincense" data:image/s3,"s3://crabby-images/e773e/e773eba98e39b12eef5c6ce587f6098397a4091a" alt="badge_lincense"
|
||
- [中文](README_zh.md)
|
||
- [✨Features](#features)
|
||
- [🚀Quick Launch](#quick-launch)
|
||
- [📚Documents](#documents)
|
||
- [📈How to Learn?](#how-to-learn)
|
||
- [📀Videos](#videos)
|
||
- [📞Community Channel](#community-channel)
|
||
***
|
||
## Introduction
|
||
GuiLite is the smallest GUI library with 5000 lines of code, could run on **all platforms**(e.g, iOS/macOS/WathOS, Android, Linux, Windows, Docker and MCU without OS), and work with **many languages**(e.g. Swift, Java, Javascript, C#, Golang).
|
||
- ✂️Small: 5,000 lines of C++ code, could be merged into 1 header & 1 source file(GuiLite.h/GuiLite.cpp) - Easy to [build & port](documents/HowToBuild.md)
|
||
- ⚡Fast: Render GUI within one invoking, independent of any OS and any third party library - Make GUI run quickly and smoothly
|
||
- 💉Inject: Run inside Qt/MFC/Winform/Cocoa/Web - Keep Qt/MFC code reusable, and speed it up by local GuiLite-optimization
|
||
- ⚙️️Hardware Minimum Requirment:
|
||
|
||
| Processor | Disk/ROM space | Memory |
|
||
| --- | --- | --- |
|
||
| 24 MHZ | 29 KB | 9 KB |
|
||
|
||
## 🔥New feature:Apple Watch
|
||
Run GuiLite both on MCU and Apple Watch:
|
||
| MCU | Apple Watch |
|
||
| --- | --- |
|
||
| data:image/s3,"s3://crabby-images/4cc41/4cc41825865961276ef6c223422eaea2559d8bce" alt="Hello3D" | data:image/s3,"s3://crabby-images/670b4/670b478820aed6a1d7f6cd13a611eed0ad310675" alt="iWatch.hello3D" |
|
||
| data:image/s3,"s3://crabby-images/c5319/c5319b89b132a21f9e8dc71953250e730dd0f63a" alt="MCU" | data:image/s3,"s3://crabby-images/61cdc/61cdc72d5470ade839d8fe8948177e99f2342ef6" alt="iWatch.helloWave" |
|
||
|
||
## ✨Features
|
||
### ⚔️Cross platform
|
||
| ARM Linux | STM32 Without OS |
|
||
| --- | --- |
|
||
| data:image/s3,"s3://crabby-images/30ffe/30ffe81df80f7a1c431adf519d7b2e440e6f2502" alt="ARM Linux" | data:image/s3,"s3://crabby-images/6f231/6f2319d8e31410ffbcf5ed387fc1a0b79b850311" alt="MCU" data:image/s3,"s3://crabby-images/c5319/c5319b89b132a21f9e8dc71953250e730dd0f63a" alt="MCU" |
|
||
|
||
| Windows Mixed Reality | Android |
|
||
| --- | --- |
|
||
| data:image/s3,"s3://crabby-images/2d9d8/2d9d868db99977ced3481414cb7a7d7cb1fa51c7" alt="Win MR" | data:image/s3,"s3://crabby-images/11ae4/11ae4aedd5be34a4cc89b79544a31be2f28db7bb" alt="Android" |
|
||
|
||
| macOS | iOS & Aplle Watch |
|
||
| --- | --- |
|
||
| data:image/s3,"s3://crabby-images/2d2be/2d2bee42acf216ead58752e54252ce48a139f1b6" alt="macOS" | data:image/s3,"s3://crabby-images/2ce21/2ce21d69ca863dc1b9dcca9b5a25387d2c01efc9" alt="iOS.hostMonitor" data:image/s3,"s3://crabby-images/a78f9/a78f9cf1b10e097cdae47a620121fcaf5b73317b" alt="iOS.particle" data:image/s3,"s3://crabby-images/61cdc/61cdc72d5470ade839d8fe8948177e99f2342ef6" alt="iWatch.helloWave" |
|
||
***
|
||
### 🔍GuiLite previewer(WYSIWYG extension for GuiLite)
|
||
[GuiLite Previewer](https://github.com/idea4good/GuiLitePreviewer) is a Visual Studio Code extension, could extract GUI information from C++ code and preview GUI at preview page(What you see is what you get)
|
||
data:image/s3,"s3://crabby-images/8add3/8add33686142d161957d36e074bc5ccf8e217ef1" alt="GuiLitePreviewer"
|
||
***
|
||
### 😎Gorgeous UI
|
||
data:image/s3,"s3://crabby-images/e48a0/e48a08b30bb2a4c89c918b02154ffb2bdbed1e20" alt="HostMonitor"data:image/s3,"s3://crabby-images/0b071/0b07196a24c8473e156f575d5af8ad99592f068f" alt="HelloNets-pc"
|
||
***
|
||
### 🔣Multi-language:
|
||
data:image/s3,"s3://crabby-images/e4973/e4973965c3c36fbbfe4906eafc5cd0e0113bbe3a" alt="unicode"
|
||
***
|
||
### 🌐IoT Solution & 📊Code Telemetry
|
||
- Report build activities to cloud:<br>data:image/s3,"s3://crabby-images/39361/393610449cf9f546c1c063c373af39931b04b8f4" alt="BuildInfo"
|
||
- Sync running data to cloud:<br>data:image/s3,"s3://crabby-images/7a7da/7a7da002910442474c557dbed22098ee0a8a1aff" alt="DataOnCloud"
|
||
- ⚠️To stop telemetry, remove script files(e,g: sync_build.bat .sync.sh .sync_build.sh)
|
||
***
|
||
### 🐋Support Docker
|
||
We build GuiLite demo as docker image, you can update/deploy/run the latest GuiLite demo on your device with single command below:
|
||
- `sudo docker run -it --privileged -v /dev:/dev-share idea4good/gui-lite:latest bash /run.sh`
|
||
***
|
||
## 📦3D
|
||
- data:image/s3,"s3://crabby-images/e6dfd/e6dfd8eddc1c69e0300dcf64d732df51c19affb9" alt="GuiLiteGraphic" data:image/s3,"s3://crabby-images/4cc41/4cc41825865961276ef6c223422eaea2559d8bce" alt="Hello3D"
|
||
- Run GuiLite Samples[(HelloParticle, HelloWave)](https://gitee.com/idea4good/GuiLiteSamples) on Web and 3D scenario, [source code here](https://github.com/idea4good/GuiLiteWeb/blob/master/CubeEx/main.js)
|
||
- Run GuiLite-Sample-Hello3D on MCU and Windows/Linux/Qt platform
|
||
***
|
||
## 🚀Quick Launch
|
||
GuiLite is only a framework, could not create UI by itself. In order to show how to build UI App with it, We provide some samples for you.
|
||
- Sample code [here](https://github.com/idea4good/GuiLiteSamples)
|
||
- Sample introduction:
|
||
|
||
| Sample name | Platform | Description | Build guidance | Diffculty level |
|
||
| --- | --- | --- | --- | --- |
|
||
| HelloParticle | Windows, Linux, STM32F103, STM32F429 | Show how to develop particle effect | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloParticle/README.md) | ★ |
|
||
| HelloStar | Windows, Linux, STM32F103, STM32F429 | Show how to develop star field effect | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloStar/README.md) | ★ |
|
||
| Hello3D | Windows, Linux, STM32F103 | Lightweight(MCU level) 3D engine base on GuiLite | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/Hello3D/README.md) | ★★ |
|
||
| HelloNets | Windows, Linux, STM32F103 | Show how to build physics App with GuiLite | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloNets/README.md) | ★★ |
|
||
| HelloGuiLite | Windows, Linux | Show how to Initialize UI, load resource, layout UI | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloGuiLite/README.md) | ★★ |
|
||
| HelloWidgets | Windows, Linux | Show how to use GuiLite widgets | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloWidgets/README.md) | ★★ |
|
||
| HelloMario | Windows, Linux, STM32F103, STM32F429 | Show how to develop multi-layer UI system | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloMario/README.md) | ★★ |
|
||
| HelloNavigation | Windows, Linux, STM32F103, STM32F429 | Show how to navigate/click widgets by hard button in non-touch GUI scenario | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloNavigation/README.md) | ★★|
|
||
| HelloFont | Windows, Linux | Show how to use multi-language feature(UTF-8) | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloFont/README.md) | ★★ |
|
||
| HelloAnimation | Windows, Linux | Show how to make animation | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloAnimation/README.md) | ★★ |
|
||
| HelloSlide | Windows, Linux | Show how to use sliding pages | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloSlide/README.md) | ★★★ |
|
||
| HelloWave | Windows, Linux, STM32F103, STM32F429 | Show how to use wave widget | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HelloWave/README.md) | ★★★ |
|
||
| HostMonitor | iOS, Mac, Android, Windows, Linux | Show how to build complex UI for all platforms | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/HostMonitor/README.md) | ★★★★ |
|
||
|
||
## 📚Documents
|
||
GuiLite is the smallest and simplest GUI library.
|
||
1. Just 5,000 line C++ code
|
||
2. Only use basic C++ feature(class, virtual function), no complex syntax
|
||
3. All rendering base on draw_pixel, no algorithm
|
||
4. Full documents and small live demos for reference
|
||
- [Design specification](documents/HowToWork.md)
|
||
- [How to build & port?](documents/HowToBuild.md)
|
||
- [How to Layout widgets?](documents/HowLayoutWork.md)
|
||
- [How to build unicode font/bitmap resource?](https://github.com/idea4good/GuiLiteToolkit)
|
||
- [How to switch theme?](https://github.com/idea4good/GuiLiteSamples/blob/master/HostMonitor/UIcode/source/resource/resource.cpp)
|
||
- [How to dispatch messages?](documents/HowMessageWork.md)
|
||
- [UML chart of GuiLite core](documents/UML.md)
|
||
- How GuiLite multi-layers work?
|
||
- data:image/s3,"s3://crabby-images/87cae/87cae16575e702fdf5c82a8ba9434fc08b9d635b" alt="GuiLiteGraphic"
|
||
- [Full video](https://www.youtube.com/watch?v=QzZJnU5KmDQ)
|
||
- [Tutorial Source code](https://github.com/idea4good/GuiLiteWeb/blob/master/Graphic/main.js)
|
||
|
||
## 📈How to learn?
|
||
1. Build/Run GuiLite library
|
||
2. Build/Run HelloXXX demos
|
||
3. Read/Modify `HelloXXX/UIcode/UIcode.cpp` code
|
||
4. Read/Modify `gui` code
|
||
5. Read/Modify `core` code
|
||
6. Build your UI framework
|
||
|
||
## 📀Videos
|
||
- [GuiLite introduction](https://www.youtube.com/watch?v=grqXEz3bdC0)
|
||
- [3D GuiLite](https://v.youku.com/v_show/id_XMzYxNTE3MTI0MA)
|
||
- [GuiLite + STM32](https://v.youku.com/v_show/id_XNDAwNzM5MTM3Ng)
|
||
|
||
## Mirror repository
|
||
[Gitee in China](https://gitee.com/idea4good/GuiLite)
|
||
|
||
## 📞Community Channel
|
||
Thanks for the help from community, you guys make GuiLite better! And welcome new friend to join us.
|
||
- [**@Twitter**](https://twitter.com/idea4good)
|
||
- QQ code: [<img src="documents/qq.group.jpg">](https://jq.qq.com/?_wv=1027&k=5EO8D9i)
|