vgtk VS libui

Compare vgtk vs libui and see what are their differences.

vgtk

A declarative desktop UI framework for Rust built on GTK and Gtk-rs (by bodil)

libui

Simple and portable (but not inflexible) GUI library in C that uses the native GUI technologies of each platform it supports. (by andlabs)
GUI
Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
vgtk libui
14 22
1,038 10,590
- -
0.0 0.0
about 2 years ago over 1 year ago
Rust C
GNU General Public License v3.0 or later GNU General Public License v3.0 or later
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

vgtk

Posts with mentions or reviews of vgtk. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-12-14.
  • Rust: State of GUI, December 2022 – KAS blog
    15 projects | news.ycombinator.com | 14 Dec 2022
    A pretty fun Rust GUI experienc is vgtk[0], which is doing a bunch of macro magic to give a "we're coding in React" vibe to GTK+. I don't really have a specific thing I want to code in a native GUI at the moment but if I did I think this would be the most tempting for me.

    [0]: https://github.com/bodil/vgtk/

  • Code bloat has become astronomical
    2 projects | /r/programming | 26 Sep 2022
    a stateful GUI markup language is react. it is not yet the case that react-like code works for desktop, though there are cool examples like vgtk https://github.com/bodil/vgtk
  • Vgtk - A declarative desktop ui framework for rust built on gtk and gtk-rs
    1 project | /r/github_trends | 19 Jun 2022
  • A declarative desktop UI framework for Rust built on GTK and GTK-rs
    2 projects | /r/programming | 6 Jun 2022
    from what i gather from https://github.com/bodil/vgtk/issues/78, you're better off using realm
    1 project | /r/patient_hackernews | 28 May 2022
    1 project | /r/hackernews | 28 May 2022
    1 project | /r/Boiling_Steam | 28 May 2022
    5 projects | news.ycombinator.com | 28 May 2022
    I'm always curious to see these projects, because I've been experimenting with a React renderer for the GJS bindings for a while. It's frustrating because GTK "feels like" it's so close to being able to support a vdom/declarative paradigm, but the devil is in the details.

    The simple use-cases like "Window > Box > Label" are easy to get going. The more complex widgets like Stack/Grid/TreeView ... aren't.

    This project seems to have the same issue: https://github.com/bodil/vgtk/issues/40

    This is made more difficult now GTK4 has removed the Container base class, so there's no longer a unified interface for adding children (although it had caveats in the first place).

    I totally get the GTK view that (presumably) specific widgets are more intuitive with specific add/remove APIs (like the grid - one doesn't really "appendChild" to a grid).

    It just feels like: if there was a consistent container API comparable to the web's appendChild approach, a vdom/declarative approach would require only a very light wrapper. Without it, I keep coming back to the idea of implementing wrapper widgets that expose that consistent API instead. And that's just not something I want to maintain - effectively duplicating each GTK widget for the purpose of making it fit into a tree model.

    It's also a problem of trying to wrap richer functionality (pack_start and pack_end) into a simpler set (append only) of course.

    So I don't know exactly what my point is :) Perhaps cautioning the reader that the simplicity of the approach comes with a catch.

  • Hacker News top posts: May 28, 2022
    5 projects | /r/hackerdigest | 28 May 2022
    A declarative desktop UI framework for Rust built on GTK and GTK-rs\ (23 comments)
  • Newbie here. Just finished reading the book. What now?
    5 projects | /r/rust | 12 Jan 2022
    Build your own To-do List Application in Rust: https://bodil.lol/vgtk/

libui

Posts with mentions or reviews of libui. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-11-04.
  • Short history of all Windows UI frameworks and libraries
    1 project | news.ycombinator.com | 10 Feb 2024
    You can kind of see the desktop UI train wreck in real time here.

    We started with simple stable APIs for a common look and feel. For a while these were evolved and made available in other languages. This was back when native apps were consistent and intuitive and you could… uhh… actually write and ship them without bundling giant runtimes or checking a huge compatibility matrix.

    Then around 2012 the train rounds the bend and screeeeech it hits some bad track and starts to derail. UI starts trying to emulate the web, a terrible UI platform, and sane compositional UI libraries and APIs are abandoned in favor of XML soup.

    Since this stuff is a trash fire, this is followed by multiple incompatible attempts to replace or fix this. Most of these are abandoned dead ends.

    Meanwhile the dev community just said fuck it and went to Electron, creating today’s world where a “hello world” app with an OK button is hundreds of megabytes and has to load an entire private copy of a language runtime and rendering engine.

    Versions of this comedy of errors have occurred on every other platform, and of course there has been little effort to create a cross platform UI API that’s sane beyond Qt (with its own problems) and dozens of half completed OSS projects.

    So enjoy Electron I guess.

    There was one sane human being who tried to do this a while ago:

    https://github.com/andlabs/libui

    It’s the only sane desktop UI project I’ve seen in almost 20 years, an attempt to create an actual cross platform common API. But it’s abandoned of course, likely too difficult for one dev and nobody is going to provide financial support for anything that sane.

    Maybe AI will get good enough some day that we can use it to do a thing like that.

  • BeeWare Toga v0.4.0 – A Python native, OS native GUI toolkit
    3 projects | news.ycombinator.com | 4 Nov 2023
  • Is there no simple GUI library for pure C?
    4 projects | /r/C_Programming | 15 May 2023
    What about https://github.com/andlabs/libui
  • Capy – Cross-platform library for making true native GUIs in Zig
    4 projects | news.ycombinator.com | 1 Aug 2022
    Fantastic! This is similar to the C library `libui` since it also acts as a wrapper of native libraries of each platform.

    If only there was a way to interface to these using some declarative minimal and highly opinionated programming language and paradigm...

    https://github.com/andlabs/libui

  • Mathematical Patterns
    2 projects | /r/cprogramming | 27 Jun 2022
    For the GUI you will need a library or framework that interacts with your specifiv operating system and allows you to create windows and a canvas to which you can draw. You could give libui a chance.
  • libui-ng-sys: external FFI bindings for libui-ng
    2 projects | /r/rust | 20 Apr 2022
    libui-ng is a cross-platform GUI library with native widgets written in C. It is based on an earlier, (currently) inactive project known as libui. While Rust bindings for libui have existed for years (see ui-sys and iui), there is no solution for the new libui-ng; libui-ng-sys aims to fill this role.
  • What GUI library should I start with after learning C?
    3 projects | /r/C_Programming | 17 Feb 2022
    libui
  • Not-gtk GUI Libs/frameworks for plain C
    6 projects | /r/C_Programming | 22 Jan 2022
    https://github.com/andlabs/libui is very nice, but unfortunately dead, if it serves your purpose consider using it, this is a fork under development https://github.com/libui-ng/libui-ng
  • Ask HN: Is there any cross platform non native GUI written in C that looks good?
    2 projects | news.ycombinator.com | 7 Dec 2021
    https://github.com/andlabs/libui

    Better yet, it has excellent DSLs that make it possible to build desktop apps in a way similar to HTML, but much better due to keeping all code dynamic in one language (no static/dynamic multi-language separation/mixing dissonance):

  • Usable cross-platform GUI?
    2 projects | /r/vlang | 4 Nov 2021
    Maybe a module that uses https://github.com/andlabs/libui or a light HTML renderer?

What are some alternatives?

When comparing vgtk and libui you can also consider the following projects:

neon - Neon: Serverless Postgres. We separated storage and compute to offer autoscaling, branching, and bottomless storage.

imgui - Dear ImGui: Bloat-free Graphical User interface for C++ with minimal dependencies

headway - Self-hostable maps stack, powered by OpenStreetMap.

nuklear - A single-header ANSI C immediate mode cross-platform GUI library

orbtk - The Rust UI-Toolkit.

wxWidgets - Cross-Platform C++ GUI Library

areweguiyet - A website built for the Rust community

nana - a modern C++ GUI library

piet - An abstraction for 2D graphics.

ncurses - snapshots of ncurses - see http://invisible-island.net/ncurses/ncurses.faq.html (no pull requests are accepted)

Relm4 - Build truly native applications with ease!

GTK+ - Read-only mirror of https://gitlab.gnome.org/GNOME/gtk