uiLitejhksdhkfj/README.md

130 lines
8.1 KiB
Markdown
Raw Normal View History

<p align="center">
2019-08-02 21:21:32 +08:00
<img src="doc/GuiLiteCube.gif" alt="Image" width="320" height="304"/>
</p>
2019-07-03 16:45:58 +08:00
# GuiLite - The smallest GUI library
2019-06-13 09:44:37 +08:00
![badge_build](https://img.shields.io/badge/build-passing-brightgreen.svg) ![badge_docker](https://img.shields.io/badge/docker%20build-passing-brightgreen.svg) ![badge_platform](https://img.shields.io/badge/platform-Windows%20%7C%20Linux%20%7C%20macOS%20%7C%20iOS%20%7C%20Android%20%7C%20MCU-brightgreen.svg) ![badge_lincense](https://img.shields.io/badge/license-Apache%202-blue.svg) ![badge_lincense](https://img.shields.io/badge/architecture-amd64%20%7C%20arm%20%7C%20arm64-blue.svg)
- [中文](README_zh.md)
2019-10-18 14:38:55 +08:00
- [✨Features](#features)
2019-10-18 16:50:41 +08:00
- [🚀Quick Launch](#quick-launch)
2019-10-18 14:38:55 +08:00
- [📚Documents](#documents)
2019-10-18 14:41:45 +08:00
- [📈How to Learn?](#how-to-learn)
2019-10-18 14:38:55 +08:00
- [📀Videos](#videos)
2019-10-18 14:41:45 +08:00
- [📞Community Channel](#community-channel)
2019-06-13 09:44:37 +08:00
***
## Introduction
2019-08-21 11:39:25 +08:00
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).
2019-08-22 12:36:31 +08:00
-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)
2019-08-21 11:39:25 +08:00
- ⚡Fast: Render GUI within one invoking, independent of any OS and any third party library - Make GUI run quickly and smoothly
2019-08-22 12:36:31 +08:00
- 💉Inject: Run inside Qt/MFC/Winform/Cocoa/Web - Keep Qt/MFC code reusable, and speed it up by local GuiLite-optimization
2019-08-19 18:00:37 +08:00
-Hardware Minimum Requirment:
| Processor | Disk/ROM space | Memory |
| --- | --- | --- |
| 24 MHZ | 29 KB | 9 KB |
2019-06-13 09:44:37 +08:00
2019-09-27 20:04:25 +08:00
## 🔥New feature3D engine - [Hello 3D](https://gitee.com/idea4good/GuiLiteSamples#hello-3d)
2019-09-20 17:12:45 +08:00
- ![Hello3D](doc/Hello3D.gif)
2019-09-27 20:04:25 +08:00
- Hardware requirment: 16K RAM, 36 MHZ
2019-09-27 20:21:17 +08:00
- Cross platform(e.g, Windows, Linux, MCU, Qt, MFC)
2019-09-27 20:04:25 +08:00
- Easy to build 3D object
2019-09-20 17:12:45 +08:00
- Could upgrade your UI experience
2019-06-13 09:44:37 +08:00
2019-10-18 14:21:41 +08:00
## ✨Features
2019-10-18 16:50:41 +08:00
### ⚔Cross platform
2019-06-13 09:44:37 +08:00
| ARM Linux | STM32 Without OS |
| --- | --- |
| ![ARM Linux](doc/Linux.gif) | ![MCU](doc/HelloParticle.gif) ![MCU](doc/HelloWave.gif) |
| Windows Mixed Reality | Android |
| --- | --- |
| ![Win MR](doc/WinMR.gif) | ![Android](doc/Android.gif) |
2019-11-06 10:41:05 +08:00
| macOS | iOS & Aplle Watch |
2019-06-13 09:44:37 +08:00
| --- | --- |
2019-11-06 10:41:05 +08:00
| ![macOS](doc/Mac.gif) | ![iOS.hostMonitor](doc/iOS.gif) ![iOS.particle](doc/iOS.particle.gif) ![iWatch.helloWave](doc/iWatch.helloWave.gif) |
2019-06-13 09:44:37 +08:00
***
2019-10-18 16:50:41 +08:00
### 🔍GuiLite previewer(WYSIWYG extension for GuiLite)
2019-07-06 14:08:12 +08:00
[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)
![GuiLitePreviewer](doc/Previewer.gif)
***
2019-10-18 16:50:41 +08:00
### 😎Gorgeous UI
2019-10-19 21:27:09 +08:00
![HostMonitor](doc/HostMonitor.gif)![HelloNets-pc](doc/HelloNets-pc.gif)
2019-06-13 09:44:37 +08:00
***
2019-10-18 14:21:41 +08:00
### 🔣Multi-language:
2019-06-13 09:44:37 +08:00
![unicode](doc/unicode.jpg)
***
2019-10-18 16:50:41 +08:00
### 🌐IoT Solution & 📊Code Telemetry
2019-06-13 09:44:37 +08:00
- Report build activities to cloud:<br>![BuildInfo](doc/BuildInfo.png)
- Sync running data to cloud:<br>![DataOnCloud](doc/data_on_cloud.png)
2019-10-16 10:30:02 +08:00
-To stop telemetry, remove script files(e,g: sync_build.bat .sync.sh .sync_build.sh)
2019-06-13 09:44:37 +08:00
***
2019-10-18 16:50:41 +08:00
### 🐋Support Docker
2019-07-30 16:39:49 +08:00
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`
***
2019-11-06 10:41:05 +08:00
## 📦3D
- ![GuiLiteGraphic](doc/GuiLite3D.gif) ![Hello3D](doc/Hello3D.gif)
- 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
2019-09-20 17:12:45 +08:00
***
2019-10-18 16:50:41 +08:00
## 🚀Quick Launch
2019-06-13 09:44:37 +08:00
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.
2019-11-06 10:41:05 +08:00
- Sample code [here](https://github.com/idea4good/GuiLiteSamples)
2019-06-13 09:44:37 +08:00
- 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) | ★ |
2019-09-20 17:25:34 +08:00
| 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) | ★★ |
2019-06-13 09:44:37 +08:00
| 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) | ★★★★ |
2019-10-18 14:21:41 +08:00
## 📚Documents
2019-06-13 09:44:37 +08:00
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)
2019-08-20 10:09:50 +08:00
- [How to build & port?](doc/HowToBuild.md)
2019-06-13 09:44:37 +08:00
- [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)
2019-08-09 19:48:04 +08:00
- How GuiLite multi-layers work?
- ![GuiLiteGraphic](doc/GuiLiteGraphic.gif)
- [Full video](https://www.youtube.com/watch?v=QzZJnU5KmDQ)
- [Tutorial Source code](https://github.com/idea4good/GuiLiteWeb/blob/master/Graphic/main.js)
2019-06-13 09:44:37 +08:00
2019-10-18 14:21:41 +08:00
## 📈How to learn?
2019-06-13 09:44:37 +08:00
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
2019-10-18 14:21:41 +08:00
## 📀Videos
2019-06-13 09:44:37 +08:00
- [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)
2019-10-18 14:21:41 +08:00
## 📞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="doc/qq.group.jpg">](https://jq.qq.com/?_wv=1027&k=5EO8D9i)