113 lines
7.0 KiB
Markdown
113 lines
7.0 KiB
Markdown
# 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 C++ code, it runs on **all platforms**(e.g, iOS, Android, Linux, Windows, macOS, Docker and **MCU with or without OS**).
|
||
- GuiLite is embeddable, it runs inside other UI frameworks(e.g, Qt, MFC, Winform, Cocoa). You could use GuiLite features and host UI features simultaneously.
|
||
- GuiLite render UI by itself, independent of OS & Graphic library.
|
||
- GuiLite could work with many languages(e.g. Swift, Java, C#, Golang).
|
||
- 🔧We want people to customize GuiLite.
|
||
- ⚙️We hope GuiLite is small enough to help you understand how UI works.
|
||
- 👑You should be the master of your UI and not be tied to a specific framework.
|
||
|
||
## 🔥New feature:3D
|
||
data:image/s3,"s3://crabby-images/05c39/05c39b69af5e2b48a1fdee8d78cecf24ab28e1b0" alt="Hello3D-pc"data:image/s3,"s3://crabby-images/c48b5/c48b52907e814275d5a1307f23bf64afaea0e89b" alt="Hello3D-mcu"
|
||
|
||
Hello 3D has only [100+ lines code](https://github.com/idea4good/GuiLiteSamples/blob/master/Hello3D/UIcode/UIcode.cpp) for beginner, showing you how to build pseudo 3D App with GuiLite. You can run it on Windows, Linux and MCU.
|
||
|
||
## Features
|
||
### Cross platform
|
||
| ARM Linux | STM32 Without OS |
|
||
| --- | --- |
|
||
| data:image/s3,"s3://crabby-images/b76bb/b76bbff698d3459ddee77f6409a58a78c538ce06" alt="ARM Linux" | data:image/s3,"s3://crabby-images/14dac/14dac731b81f99679cc48e63dd5538809939e98b" alt="MCU" data:image/s3,"s3://crabby-images/1ab6a/1ab6a93677916d6bbc0aa1ee7bea3ad119c6cd76" alt="MCU" |
|
||
|
||
| Windows Mixed Reality | Android |
|
||
| --- | --- |
|
||
| data:image/s3,"s3://crabby-images/5554b/5554b79a957c938218e26374b9f1c57a3561016b" alt="Win MR" | data:image/s3,"s3://crabby-images/cf54a/cf54ad15864af04bf9aa9ff520c2c71dcd60b89c" alt="Android" |
|
||
|
||
| macOS | iOS |
|
||
| --- | --- |
|
||
| data:image/s3,"s3://crabby-images/68336/68336afd456f843a5fe574736c9bd202672f6742" alt="macOS" | data:image/s3,"s3://crabby-images/9f893/9f893f705a9f5a61ab2371e21c265afd448bb003" 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/c4fdb/c4fdbe634cd758e1a7fdf563c946081ce70b44b3" alt="GuiLitePreviewer"
|
||
***
|
||
### Support Docker Container
|
||
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`
|
||
***
|
||
### Easy customization
|
||
data:image/s3,"s3://crabby-images/95876/95876403bdeb5468ef38fbd65798ac869b359c77" alt="wallpaper"
|
||
***
|
||
### Multi-language:
|
||
data:image/s3,"s3://crabby-images/70793/707931877631545be7103f9ec08276afff48d23a" alt="unicode"
|
||
***
|
||
### Multi-theme
|
||
data:image/s3,"s3://crabby-images/43d94/43d9465eca7a9aa791ba2d5b7a39c4d6fcb66f19" alt="multi-theme"
|
||
***
|
||
### IoT Solution & Code Telemetry
|
||
- Report build activities to cloud:<br>data:image/s3,"s3://crabby-images/8ec7a/8ec7aa65b95b444a68a8af3d4082fbb1447b04ea" alt="BuildInfo"
|
||
- Sync running data to cloud:<br>data:image/s3,"s3://crabby-images/ff1ff/ff1ff537a64a861a89e58b44d04dfded331c83ca" alt="DataOnCloud"
|
||
***
|
||
## 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?](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 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.<br>[<img src="doc/qq.group.jpg">](https://jq.qq.com/?_wv=1027&k=5EO8D9i)
|
||
- [Sponsor & Help sick kids](https://idea4good.github.io)
|