Slint is an open-source declarative GUI toolkit to build native user interfaces for Rust, C++, JavaScript, or Python apps.
Find a file
Simon Hausmann 114b51f32b Add include paths to CompilerConfiguration
We'll try to load .60 files from those paths.
2020-07-17 12:15:03 +02:00
.cargo Fix rebuild issues, part 10523 2020-06-09 13:08:59 +02:00
.github/workflows Fix wasm build, part 2 2020-06-08 17:48:34 +02:00
api Further encapsulate Diagnostics 2020-07-17 11:52:29 +02:00
docs Implement % as a unit 2020-07-16 11:24:46 +02:00
examples Set the DPI property according to the window's screen 2020-07-15 18:46:55 +02:00
helper_crates Fix linter warning 2020-07-07 14:14:17 +02:00
sixtyfps_compiler Add include paths to CompilerConfiguration 2020-07-17 12:15:03 +02:00
sixtyfps_runtime Add aggregating BuildDiagnostics 2020-07-17 12:10:25 +02:00
tests Further encapsulate Diagnostics 2020-07-17 11:52:29 +02:00
tools Simplify compilation call sites further 2020-07-16 18:53:59 +02:00
xtask C++ Only link against the backend library 2020-06-17 18:38:47 +02:00
.clang-format Reformat public header with Qt's clang-format 2020-05-11 15:20:17 +02:00
.gitignore Ignore generated files 2020-06-10 10:10:00 +02:00
Cargo.toml Add a weak-pin crate that can be used to create Weak pointr from Pin<Rc> 2020-06-26 17:30:40 +02:00
CONTRIBUTING.md Some documentation 2020-06-18 17:16:34 +02:00
README.md Some documentation 2020-06-18 17:16:34 +02:00
rustfmt.toml Initial commit laying out the structure 2020-05-04 10:49:58 +02:00

SixtyFPS

This is the monolithic repository of the SixtyFPS project.

What is SixtyFPS

It is a GUI engine, with libraries for different languages. The aim of the project is to be

  • Lightweight: We aim to provide a runtime that fits in a few MB. Minimize the RAM usage, and also be blazing fast.
  • Straightforward: We want to optimize as well for programmer and designer productivity. Making it an enjoyable experience to work with. We claim to use well thought idiomatic API for each target language. Provide well written documentation. And use of modern tools.
  • Native: We support many platforms. From embedded devices, to desktop, including mobile and web. One should feel at home on each platform. Both the user and the developer. The appearance and look and feel should match was is expected of an application build for this platform.

<insert a few screenshots here>

Documentation

SixtyFPS can be used from different frontend languages. Refer to the README of these direcory for actual user documentation.

The docs folder contains build instructions and internal developer docs.

SixtyFps.cpp

Modern C++ Library for GUI

SixtyFps-rs

Rust GUI library

SixtyFps-js

NodeJS bindings

The .60 DSL

HelloWorld = Window {
 TextLabel { text: "Hello, world" }
}

Check out the language reference

Examples / Demo

Todo

Contributions

Contributions are welcome. To contribute, please see CONTRIBUTING.md. Contributions are done under a CLA.

License

The software is provided under a double license scheme

  • GNU GPLv3: Open source license ideal for free software.
  • Commercial SixtyFps license: more details to come.