Skip to content

RibirX/Ribir

Folders and files

NameName
Last commit message
Last commit date
May 16, 2024
Mar 28, 2025
Mar 29, 2024
Apr 7, 2025
Apr 23, 2025
Apr 23, 2025
Apr 23, 2025
Mar 28, 2025
Apr 11, 2025
Nov 18, 2024
Apr 11, 2025
Apr 23, 2025
Apr 23, 2025
Apr 23, 2025
Apr 23, 2025
Dec 22, 2024
Apr 6, 2025
Apr 7, 2025
Apr 23, 2025
Apr 23, 2025
May 10, 2024
Apr 23, 2025
Feb 14, 2023
Apr 23, 2025
Feb 14, 2023
Mar 28, 2025
Sep 10, 2024
Sep 10, 2024
Oct 3, 2024
Oct 13, 2024

Repository files navigation

Ribir - Non-intrusive GUI Framework for Rust

Ribir-logo

Use Rust to build multi-platform applications from a single codebase.

What's Ribir?

Ribir is a Rust GUI framework that helps you build beautiful and native multi-platform applications from a single codebase.

Experience a novel approach to UI development that's directly based on your data structure APIs. Any data mutation will trigger a precise UI update. Your focus should be on designing your data structure and its APIs. Then, you can describe your data's UI without intruding on its logic.

At First Glance

A simple example of a counter:

use ribir::prelude::*;
fn main() {
  let cnt = Stateful::new(0);
  App::run(button! {
    h_align: HAlign::Center,
    v_align: VAlign::Center,
    on_tap: move |_| *$cnt.write() += 1,
    @pipe!($cnt.to_string())
  });
}

To use Ribir without DSL:

use ribir::prelude::*;

fn main() {
  let cnt = Stateful::new(0);

  App::run(move || {
    let c_cnt = cnt.clone_writer();
    let mut btn = Button::declarer();
    btn.on_tap(move |_| *c_cnt.write() += 1)
      .h_align(HAlign::Center)
      .v_align(VAlign::Center);
    btn.finish()
      .with_child(pipe!($cnt.to_string()))
      .into_widget()
  });
}

More Examples

Features

  • Declarative language It doesn't introduce a completely new language. Instead, it provides a set of Rust macros for easier interaction. You can choose to use it or not.
  • Widgets compose system has four kinds of widgets to support you can implement your widget in different ways:
    • function widget and Compose, from other widgets composition.
    • Render, implement your layout and paint anything you want.
    • ComposeChild, control the compose logic between parent and child widgets and specify the template of child widgets.
  • Non-intrusive state converts your data to a listenable state and updates the view according to the change of the state.
  • Layout system learning and inspired by Flutter Sublinear layout, but not the same.
  • Event system is a composition event system, that supports event bubbling and capture. Allow to compose with any widget, and exists only if you use it.
  • Theme System: Supports using different themes for various parts of the sub-tree and enables theme modifications at runtime.
  • Painter converts the view to 2D paths.
  • GPU render is a backend of the Painter, do path tessellation so that you can easily render the triangles in any GPU render engine. A wgpu implementation is provided as the default GPU render engine. Tessellation base on [lyon].
  • Text support basic text typography and IME input, in a usable but rough stage.
  • Widgets library provides 20+ basic widgets, but all are in a rough stage, and the API is not stable yet.

Architecture overview

Support Platform

Platform Support situation
Linux βœ…
Windows βœ…
macOS βœ…
iOS 🚧 Not yet
Android 🚧 Not yet
Web βœ…

Ribir is actively being developed and tested on desktop platforms, with both desktop and web platforms integrated into our CI/CD pipeline.

While the framework can compile and run on mobile platforms, we haven't fully tested or adapted the user interface for them yet. We plan to focus on mobile support once the core framework is stable and a production-ready widget library is released.

Love Ribir?

If you like Ribir, give our repo a ⭐ STAR ⬆️ and WATCH πŸ‘€ our repository to stay updated with the latest developments!

Every encouragement and feedback can support us to go further.

Contributing

We are grateful to the community for contributing bug fixes and improvements.

😎 New to Ribir?

Start learning about the framework by helping us improve our documentation. Feel free to open a new "Documentation" issue. We are also very welcome:

  • Point out to us where our document has misunderstandings
  • Pull requests which improve test coverage
  • Add undocumented code (e.g. built-in widget)
  • Report typo

For more information please read:

πŸ€” Confused about something?

Feel free to go to Discussions and open a new "Q&A" to get help from contributors. Often questions lead to improvements to the ergonomics of the framework, better documentation, and even new features!

😱 Found a bug?

Please report all bugs! We are happy to help support developers fix the bugs they find if they are interested and have the time.

Thanks

This project exists thanks to all the people who contributed:


We also found inspiration from the following frameworks:

License

Ribir is MIT-licensed