Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/neko-box-coder/ssgui

◀️ Super Simple GUI Library for C++ ▶️
https://github.com/neko-box-coder/ssgui

cpp cross-platform gui gui-framework gui-library sfml sfml-library ui widgets

Last synced: 4 days ago
JSON representation

◀️ Super Simple GUI Library for C++ ▶️

Awesome Lists containing this project

README

        

> [!IMPORTANT]
> Development for this project is currently **on hold**. There are no plans to resume development at the moment.

> ⚠️ This library is constantly changing & incomplete until v1.00 . However, feel free to star or bookmark this project.

### 🔗 Quick Links
- [🔌 Status of ssGUI](#-status-of-ssgui-v09402)
- [❓ What is ssGUI?](#-what-is-ssgui)
- [❓ Why Another GUI Framework?](#-why-another-gui-framework)
- [📌 Cool Features](#-cool-features)
- [🧮 Quick Start](#-quick-start)
- [🛣️ Roadmap](#️-roadmap)
- [❤️ Special Thanks](#️-special-thanks)
- [📜 Licenses](#-licenses)
---

### 🔌 Status of ssGUI (v0.94.03)
- #### 🔀 Branches
- ![](https://img.shields.io/badge/Last_Release-v0.94.02-brightgreen?style=for-the-badge&logo=GitHub)
- ![](https://img.shields.io/badge/Current_Development-v0.94.03-darkgray?style=for-the-badge&logo=GitHub)

- #### 🖥️ OS support
- ![](https://img.shields.io/badge/Linux-Working-brightgreen?style=for-the-badge&logo=linux&logoColor=white)
- ![](https://img.shields.io/badge/Windows-Working_(v0.94.01)-brightgreen?style=for-the-badge&logo=windows)
- ![](https://img.shields.io/badge/OSX-Coming_Soon_(Possible_with_SFML)_-red?style=for-the-badge&logo=apple)

- #### 📈 Current Progress
- ![](https://img.shields.io/badge/v0.93-|█████ 100% █████|-29D236?style=for-the-badge&logo=)
- ![](https://img.shields.io/badge/v0.94-|█████ 100% █████|-29D236?style=for-the-badge)
- ![](https://img.shields.io/badge/v0.95-|█████   70%  ██───|-E5FF3C?style=for-the-badge)
---

### ❓ What is ssGUI?

![](DocsGeneration/ND_Config/Images/Logo.png "Logo")

- ### 🌍 Universal GUI Framework:
ssGUI is aimed to be an universal framework that can be used for both **graphical intensive** applications 🔥 and **normal** GUI applications 🎹.

Only one GUI framework for games and normal GUI application with support to OpenGL window and (**WIP**) ~~native OS window~~.

- ### ✅ Cross Platform:
ssGUI supports multiple platforms: Windows, Linux and (**WIP**) ~~MacOS~~.

Nothing is restricted ⛔, you can get the underlying system handle easily if you want.

- ### 📖 Everything Is Documented
ssGUI functions are verbose and easy to understand.

HTML Documentation provides step by step tutorial for getting started, (**WIP**) ~~with a number of mock up GUI examples to reference from.~~

API is clearly documented with (**WIP**) ~~images to describe each properties.~~

#### [See Documentation Here](https://neko-box-coder.github.io/ssGUI_Doc/)

- ### 🦾 Easily Extensible
ssGUI uses the extensions and (Optional) event callbacks model. Only add the functionalities you need and you are good to go.

- ### 📦 Everything You Need One Repo
It by default uses native system libraries, no need to install any external packages or download binaries libraries.

You can just build ssGUI from source using CMake.

- ### 🧩 Projects compatible
ssGUI uses C++ 11 standard (With the exception for MSVC), which makes it compatible with many project within the last decade.

- ### 🔙 ~~Source Compatible~~ (WIP)
ssGUI aims to be forward compatible in terms of souce compatibility, meaning no code change when migrating to newer ssGUI version.

- ### 🏗️ ~~GUI Builder~~ (WIP)
Easy visualization on what the GUI, no longer need to recompile everytime you make a change.
---

### ❓ Why Another GUI Framework?

1. Wanted to create an application with the performance of C++

2. Realized there ain't any GUI framework I wanted at the time.

- They are either:
- Not fully open source license
- Convoluted framework
- Looks ugly
- Missing modern features like docking or automatic layout
- Terrible API
- Steep learning curve

3. Decided to reinvent the wheel just like any other programmers

4. 2 years later, I still haven't created the application I wanted in the first place

![](./7rsp5l.jpg)

Joke aside, I just wanted to have a GUI framework that can be:
- Spinned up within minutes with minimum / no configuration
- Uses C++ STL
- No restrictions on commercial use
- Simple, feature rich but not bloated

Which ssGUI has achieved most of them.

### 📌 Cool Features
#### Window Docking & Auto Layout:
![](DocsGeneration/ND_Config/Images/DockingAndLayout.gif)

#### Mask:
![](DocsGeneration/ND_Config/Images/Mask.gif)

#### Text Alignment:
![](DocsGeneration/ND_Config/Images/TextAlignment.gif)

#### Text Character Level Customization:
![](DocsGeneration/ND_Config/Images/CharAdjust.gif)

#### Extension To Provide Modularity:
![](DocsGeneration/ND_Config/Images/ExtensionExample.gif)

#### And more to come...

---

### GUI Objects List:
- ▶️ Button
- 🔲 Checkbox
- 📷 Image
- 🪟 MainWindow
- 📑 Menu
- 🈶 Text
- ✏️ TextField
- 📦 GUIObject, Widget & Window (Base GUI Objcet)
- 🗄️ Composite GUI Objects
- 📄 Dropdown
- 🩻 ImageCanvas
- 🗃️ MenuItem
- ↕️ Scrollbar
- 🛝 Slider
- ⏩ StandardButton
- 🖥 StandardWindow

---

### 🧮 Quick Start

#### 🔧 Using ssGUI in your project
1. Add ssGUI to your project as submodule
- `git submodule add -b v0.94.01.a_release https://github.com/Neko-Box-Coder/ssGUI.git `
2. Then initialize the submodules used by ssGUI
- `git submodule update --init --recursive`
3. Add ssGUI to your `CMakeLists.txt` by doing
- `add_subdirectory("${CMAKE_CURRENT_LIST_DIR}/directory/to/ssGUI")`
4. And link it by doing
- `target_link_libraries(example PUBLIC ssGUI)`

#### 🏗️ Creating an simple GUI example
![](DocsGeneration/ND_Config/Images/IntroductionExample.gif)

(You can find this at `ssGUI/Example/ReadmeExampleV7`)

```C++
#include "ssGUI/HeaderGroups/StandardGroup.hpp"
#include "ssGUI/Extensions/Layout.hpp"

//Readme example
using namespace ssGUI::Enums;
int main()
{
ssGUI::MainWindow mainWindow;
mainWindow.SetRenderSize(glm::vec2(450, 80));
mainWindow.AddExtension();

auto* text = mainWindow.AddChild();
text->SetText("Click on the button to show the message");

auto* button = mainWindow.AddChildWithWrapper(AlignmentHorizontal::CENTER, AlignmentVertical::CENTER);
button->SetSize(glm::vec2(50, 30));

ssGUI::ssGUIManager guiManager;
guiManager.AddRootGUIObject(&mainWindow);
guiManager.AddPostGUIUpdateEventListener
(
[&]()
{
if(button->GetButtonState() == ssGUI::Enums::ButtonState::CLICKED)
text->SetText(L"(`oωo´)");
}
);
guiManager.StartRunning();
return 0;
}
```

---

### 🛣️ Roadmap
#### [Kanban Board](https://ssGUI.nekoboxcoder.dev/b/ckQsLZToXDPFzsAzx/ssgui)

#### Main Features that are on Roadmap:
- #### Mock up GUI examples
- #### MacOS support
- #### Support systems without OpenGL
- #### GUI Builder
- #### Optional immediate mode support
- File Dialog support
- Tabs extension
- Color picker
- ~~Instance rendering~~
- etc...

---

### ❤️ Special Thanks

- #### SFML With Awesome Documentation:

![](DocsGeneration/ND_Config/Images/SFML.png)

- #### GLM With Great Math Structs And Math Functions:

![](DocsGeneration/ND_Config/Images/Glm.png)

- #### Natural Docs With Amazing And Intuative Documentation Generation::

![](DocsGeneration/ND_Config/Images/NaturalDocs.svg)

- #### stb_image for easy importing for different image formats
- #### freetype for easy font importing
- #### clip for cross-platfrom clipboard implementation

---

### 📜 Licenses
This project is under Apache-2.0 License.
Licenses for resources used by testing and examples are stored as "Credits.txt" under the same folder.

- GLM:
- The Happy Bunny License or MIT License

- SFML:
- zlib/png license
- Components used by ssGUI:
- freetype is under the FreeType license or the GPL license
- stb_image and stb_image_write are public domain
- If you want to use other components, please visit https://github.com/SFML/SFML/blob/master/license.md for their licenses

- stb_image:
- MIT License or Public Domain

- freetype:
- The FreeType License or GPLv2

- clip:
- The clip license (Copyright (c) 2015-2022 David Capello)