# 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)
- [Start with Demo](#Start-with-Demo)
- [Documents](#Documents)
- [How to Learn?](#How-to-Learn)
- [Videos](#Videos)
- [🙏Thanks & ❤️Charity](#Thanks-and-Charity)
***
## Introduction
GuiLite is the smallest GUI library with 5000 lines of code, could run on **all platforms**(e.g, iOS, Android, Linux, Windows, macOS, 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](doc/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:Inject GuiLite Samples into 3D Web
- data:image/s3,"s3://crabby-images/8c1e5/8c1e5b4b893e2748d6e7200004da979b40a12ea9" alt="GuiLiteGraphic"
- Run GuiLite Samples[(HelloParticle, HelloWave)](https://gitee.com/idea4good/GuiLiteSamples#mcu-demos-hello-star--hello-particle--hello-wave--hello-notouch--hello-mario--hello-3d) on Web and 3D scenario
- [Source code](https://github.com/idea4good/GuiLiteWeb/blob/master/CubeEx/main.js)
## Features
### Cross platform
| ARM Linux | STM32 Without OS |
| --- | --- |
| data:image/s3,"s3://crabby-images/ebfce/ebfced209ab1a0fdd96b961a36bb62874e8e362f" alt="ARM Linux" | data:image/s3,"s3://crabby-images/40cf9/40cf9690358a0dbb1a4d33442773b969b481695f" alt="MCU" data:image/s3,"s3://crabby-images/d01f2/d01f2a53f21da0b53667f05dbad69261ecd6a14b" alt="MCU" |
| Windows Mixed Reality | Android |
| --- | --- |
| data:image/s3,"s3://crabby-images/5ecef/5ecef3344d6ed69428a5a0ef765adb27e64ddfe3" alt="Win MR" | data:image/s3,"s3://crabby-images/12023/120234a0a4a8137146f06f11613cfa4fb58237b1" alt="Android" |
| macOS | iOS |
| --- | --- |
| data:image/s3,"s3://crabby-images/a326e/a326ed7b15598cdb161f70d549f656df17dee548" alt="macOS" | data:image/s3,"s3://crabby-images/11b08/11b085626e95f2f28186e0bd23dd5494db68911b" alt="iOS" |
***
### 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/8a4e3/8a4e3341591db63a825bfb4bfc8e023c507cb0be" alt="GuiLitePreviewer"
***
### Gorgeous UI
data:image/s3,"s3://crabby-images/afe7d/afe7d8a613da5f163f97a05db6f381c6c6547391" alt="wallpaper"data:image/s3,"s3://crabby-images/9e7f3/9e7f3b210a99c408c1ac66413c24ea597f560334" alt="Hello3D-pc"
***
### Multi-language:
data:image/s3,"s3://crabby-images/5a251/5a251a07371a713472936a9735de5c6bd5068d8b" alt="unicode"
***
### IoT Solution & Code Telemetry
- Report build activities to cloud:
data:image/s3,"s3://crabby-images/b947b/b947b6be14189c8d97f9d77bca0f5bd98d90016a" alt="BuildInfo"
- Sync running data to cloud:
data:image/s3,"s3://crabby-images/41d38/41d389bea4ed1a1163f97c1bf06371844cfb510d" alt="DataOnCloud"
***
### 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`
***
## Start with Demo
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 | Show how to build physics App with GuiLite | [Build](https://github.com/idea4good/GuiLiteSamples/blob/master/Hello3D/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](doc/HowToWork.md)
- [How to build & port?](doc/HowToBuild.md)
- [How to Layout widgets?](doc/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?](doc/HowMessageWork.md)
- [UML chart of GuiLite core](doc/UML.md)
- How GuiLite multi-layers work?
- data:image/s3,"s3://crabby-images/92cb6/92cb69a5977adb7fc6982ea216e5c9d593fc7de6" 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)
## Thanks and Charity
- Thanks for the help from QQ group, you guys make GuiLite better! And welcome new friend to join us.
[
](https://jq.qq.com/?_wv=1027&k=5EO8D9i)
- [Sponsor & Help sick kids](https://idea4good.github.io)