Gtk4DotNet 7.0.3-beta-3
See the version list below for details.
dotnet add package Gtk4DotNet --version 7.0.3-beta-3
NuGet\Install-Package Gtk4DotNet -Version 7.0.3-beta-3
<PackageReference Include="Gtk4DotNet" Version="7.0.3-beta-3" />
<PackageVersion Include="Gtk4DotNet" Version="7.0.3-beta-3" />
<PackageReference Include="Gtk4DotNet" />
paket add Gtk4DotNet --version 7.0.3-beta-3
#r "nuget: Gtk4DotNet, 7.0.3-beta-3"
#:package Gtk4DotNet@7.0.3-beta-3
#addin nuget:?package=Gtk4DotNet&version=7.0.3-beta-3&prerelease
#tool nuget:?package=Gtk4DotNet&version=7.0.3-beta-3&prerelease
Gtk4DotNet
A C# wrapper for GTK4 (.NET 8). You can create programs using the GTK4 UI system as a .NET 8.
Gtk4DotNet uses a functional declarative approach to GTK4 similar to REACT or Kotlin Compose:
return Application
.New("org.gtk.example")
.OnActivate(app =>
app
.NewWindow()
.Title("Hello Gtk👍")
.SideEffect(win => win
.Child(
Grid
.New()
.Attach(
Button
.NewWithLabel("Button 1")
.OnClicked(() => WriteLine("Button1 clicked")),
0, 0, 1, 1)
.Attach(
Button
.NewWithLabel("Button 2")
.OnClicked(() => WriteLine("Button2 clicked")),
1, 0, 1, 1)
.Attach(
Button
.NewWithLabel("Quit")
.OnClicked(() => win.CloseWindow()),
0, 1, 2, 1)))
.Show())
.Run(0, 0);
}
Table of contents
Prerequisites <a name="prerequisites"></a>
Necessary prerequisites only depending on the version of Linux
On modern Linux like Ubuntu 24.04 or Fedora 40 Gtk4DotNet apps will run out of the box (if you create a full contained single file exe), otherwise you have to install the necessary dotnet runtime.
libadwaita is only necessary if you want to create Adwaita apps, and webkitgtk6 you only need when integrating a webview.
On older/other Linux systems perhaps you have to install one of the following packages in order to make the app runnable.
sudo apt install libgtk-4-dev
sudo apt install libadwaita-1-dev
sudo apt install libwebkitgtk-6.0-dev
For example on Linux Mint 22 you only have to install
sudo apt install libwebkitgtk-6.0-dev
if you want to use webkit webview whereas for KDE neon 6.0 you have to install
sudo apt install libadwaita-1-dev
sudo apt install libwebkitgtk-6.0-dev
The necessary Gtk4DotNet Nuget package <a name="nuget"></a>
To use these features there is a nuget package Gtk4DotNet, which you have to include.
Hello World (a minimal GTK4 app) <a name="helloworld"></a>
In a newly created folder create a new console program with .NET (dotnet new console
). Now add the necessary package: dotnet add package Gtk4DotNet
.
In the created file Program.cs
replace all code with:
using GtkDotNet;
static class First
{
public static int Run()
{
var app = Application.New("de.uriegel.first");
return app.Run(0, 0);
}
}
It creates a GTK45 Application object and then runs the message loop. Compile the program and start it. It starts and ends immediately with the warning:
GLib-GIO-WARNING **: 08:27:42.149: Your application does not implement g_application_activate() and has no handlers connected to the 'activate' signal. It should do one of these.
When the app is being activated, you have to implement the activate method. You can do this with a injected C# callback with the help of Application.OnActivate
. Let's do this:
var app = Application.New("de.uriegel.first");
app.OnActivate(app => Console.WriteLine("App is being activated"));
return app.Run(0, 0);
When you debug the program, OnActivate is being called and returns immediately. When app.Run() is being executed, the injected callback is being called and the text is being displayed in the terminal. However, the app also stops immediately. Of cource some kind of UI has to be created.
Let's create a window, this has to be done in the Application.OnActivate callback:
app.OnActivate(app =>
{
var windows = app.NewWindow();
windows.Show();
});
Now an empty default window is being shown and the function call Applicatio.Run()
will only return when the window is being closed.
Fluent syntax <a name="fluentsyntax"></a>
To avoid creating many variables only to set them as parameters in a function, Gtk4DotNet uses a functional builder approach to create a complicated ui with fluent syntax. Many setter function returns the same instance, so that builder functions can be assigned in a row.
The above sample can be written using this approach as:
static class First
{
public static int Run()
=> Application
.New("de.uriegel.first")
.OnActivate(app =>
app
.NewWindow()
.Show())
.Run(0, IntPtr.Zero);
}
With this approach the hierarchy of the GTK4 application is being reflected in code.
The Window is very empty. Let's add a title and change the default size:
.NewWindow()
.Title("Hello Gtk👍")
.DefaultSize(600, 200)
.Show())
// TODO refer to GTK exmples in GTK tutorial and GTK4 Rust
// TODO show image
// TODO Now complete Hello World
// TODO Adwaita e.g. color schemes.. // TODO Pipe SideEffect // TODO Lambdas in callbacks
// TODO explain static classes Object and ObjectHandle
DEPRECATED Part
Contained in this Repo are samples how to use Gtk4DotNet. All examples of the official GTK4 are transformed to C# with Gtk4DotNet.
If you want to use GTK resources
- sudo apt install libglib2.0-dev-bin
Installation of GTK Schema
sudo install -D ./Test/org.gtk.example.gschema.xml /usr/share/glib-2.0/schemas/
sudo glib-compile-schemas /usr/share/glib-2.0/schemas/
Usage
Look at the sample programs (https://github.com/uriegel/Gtk4DotNet/tree/Main/Test)
Checking if memory is being freed
To check if GObjects are being freed, just run
Widget.AddWeakRef(() => Console.WriteLine("... is being freed));
If this object is finalized, then the callback will be called.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net8.0
- CsTools (>= 7.23.0)
NuGet packages (3)
Showing the top 3 NuGet packages that depend on Gtk4DotNet:
Package | Downloads |
---|---|
WebWindowNetCore
A C# Webview Application for Windows and Linux similar to Electron based on WebView2 (Windows) and GTK WebKit (Linux) |
|
WebWindowNetCore.Linux
A C# Webview Application for Linux similar to Electron based on GTK WebKit |
|
Gtk4DotNet.FSharp
.NET 8 F# Bindings for GTK 4, functional declarative similar to REACT or Kotlin Compose |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last Updated |
---|---|---|
7.0.65-beta-65 | 181 | 5/17/2025 |
7.0.64-beta-64 | 138 | 5/17/2025 |
7.0.63-beta-63 | 169 | 5/16/2025 |
7.0.62-beta-62 | 225 | 5/16/2025 |
7.0.61-beta-61 | 245 | 5/14/2025 |
7.0.60-beta-60 | 275 | 5/12/2025 |
7.0.59-beta-59 | 244 | 5/12/2025 |
7.0.58-beta-58 | 182 | 4/18/2025 |
7.0.57-beta-57 | 237 | 4/14/2025 |
7.0.56-beta-56 | 186 | 4/13/2025 |
7.0.55-beta-55 | 186 | 4/13/2025 |
7.0.54-beta-54 | 185 | 4/12/2025 |
7.0.53-beta-53 | 193 | 4/12/2025 |
7.0.52-beta-52 | 132 | 4/12/2025 |
7.0.51-beta-51 | 174 | 4/11/2025 |
7.0.50-beta-50 | 197 | 4/10/2025 |
7.0.49-beta-49 | 185 | 4/10/2025 |
7.0.48-beta-48 | 190 | 4/10/2025 |
7.0.47-beta-47 | 197 | 4/10/2025 |
7.0.46-beta-46 | 190 | 4/10/2025 |
7.0.45-beta-45 | 194 | 4/9/2025 |
7.0.44-beta-44 | 216 | 4/8/2025 |
7.0.43-beta-43 | 176 | 4/8/2025 |
7.0.42-beta-42 | 182 | 4/7/2025 |
7.0.41-beta-41 | 183 | 4/6/2025 |
7.0.40-beta-40 | 161 | 4/6/2025 |
7.0.39-beta-39 | 139 | 4/5/2025 |
7.0.38-beta-38 | 148 | 4/5/2025 |
7.0.37-beta-37 | 110 | 4/5/2025 |
7.0.36-beta-36 | 213 | 4/3/2025 |
7.0.35-beta-35 | 194 | 4/3/2025 |
7.0.34-beta-34 | 162 | 4/3/2025 |
7.0.33-beta-33 | 192 | 4/2/2025 |
7.0.32-beta-32 | 171 | 4/1/2025 |
7.0.31-beta-31 | 210 | 4/1/2025 |
7.0.30-beta-30 | 199 | 3/31/2025 |
7.0.29-beta-29 | 188 | 3/31/2025 |
7.0.28-beta-28 | 179 | 3/30/2025 |
7.0.27-beta-27 | 491 | 3/24/2025 |
7.0.26-beta-26 | 492 | 3/24/2025 |
7.0.25-beta-25 | 443 | 3/24/2025 |
7.0.24-beta-24 | 455 | 3/24/2025 |
7.0.23-beta-23 | 284 | 3/23/2025 |
7.0.22-beta-22 | 107 | 3/22/2025 |
7.0.21-beta-21 | 93 | 3/22/2025 |
7.0.20-beta-20 | 103 | 3/21/2025 |
7.0.19-beta-19 | 160 | 3/21/2025 |
7.0.18-beta-18 | 193 | 3/20/2025 |
7.0.17-beta-17 | 165 | 3/20/2025 |
7.0.16-beta-16 | 198 | 3/19/2025 |
7.0.15-beta-15 | 153 | 3/18/2025 |
7.0.14-beta-14 | 189 | 3/18/2025 |
7.0.13-beta-13 | 172 | 3/18/2025 |
7.0.12-beta-12 | 188 | 3/17/2025 |
7.0.11-beta-11 | 181 | 3/16/2025 |
7.0.10-beta-10 | 116 | 3/14/2025 |
7.0.9-beta-9 | 135 | 3/14/2025 |
7.0.8-beta-8 | 138 | 3/14/2025 |
7.0.7-beta-7 | 141 | 3/2/2025 |
7.0.6-beta-6 | 186 | 2/26/2025 |
7.0.5-beta-5 | 146 | 2/25/2025 |
7.0.4-beta-4 | 165 | 2/24/2025 |
7.0.3-beta-3 | 134 | 2/24/2025 |
7.0.2-beta-2 | 131 | 2/24/2025 |
7.0.1-beta-1 | 123 | 2/24/2025 |
7.0.0-beta-0 | 160 | 2/23/2025 |
6.8.1 | 377 | 2/15/2025 |
6.8.0 | 153 | 2/15/2025 |
6.7.1 | 286 | 2/8/2025 |
6.7.0 | 178 | 2/8/2025 |
6.6.1 | 153 | 2/8/2025 |
6.6.0 | 291 | 2/3/2025 |
6.5.6 | 167 | 2/2/2025 |
6.5.5 | 238 | 9/7/2024 |
6.5.4 | 348 | 8/31/2024 |
6.5.4-beta6 | 163 | 8/31/2024 |
6.5.4-beta5 | 150 | 8/31/2024 |
6.5.4-beta4 | 130 | 8/31/2024 |
6.5.4-beta3 | 140 | 8/31/2024 |
6.5.3 | 440 | 8/23/2024 |
6.5.3-beta3 | 139 | 8/31/2024 |
6.5.3-beta2 | 158 | 8/31/2024 |
6.5.3-beta1 | 125 | 8/31/2024 |
6.5.2 | 205 | 8/19/2024 |
6.5.1 | 202 | 8/19/2024 |
6.5.0 | 188 | 8/18/2024 |
6.4.0 | 221 | 8/13/2024 |
6.3.0 | 192 | 8/12/2024 |
6.2.1 | 232 | 8/11/2024 |
6.2.0 | 167 | 8/11/2024 |
6.1.3 | 200 | 8/10/2024 |
6.1.2 | 189 | 8/9/2024 |
6.1.1 | 183 | 8/9/2024 |
6.1.0 | 438 | 4/29/2024 |
6.0.0 | 184 | 4/27/2024 |
5.4.0 | 261 | 4/20/2024 |
5.3.11 | 194 | 4/20/2024 |
5.3.10 | 183 | 4/20/2024 |
5.3.9 | 220 | 4/19/2024 |
5.3.8 | 223 | 3/26/2024 |
5.3.7 | 202 | 3/13/2024 |
5.3.6 | 314 | 1/20/2024 |
5.3.5 | 212 | 1/20/2024 |
5.3.4 | 274 | 1/7/2024 |
5.3.3 | 237 | 1/3/2024 |
5.3.2 | 224 | 1/2/2024 |
5.3.1 | 210 | 1/2/2024 |
5.3.0 | 205 | 1/2/2024 |
5.2.0 | 266 | 12/22/2023 |
5.1.0 | 210 | 12/22/2023 |
5.0.0 | 331 | 12/14/2023 |
4.0.0 | 189 | 12/13/2023 |
3.4.0 | 202 | 12/10/2023 |
3.3.1 | 209 | 12/10/2023 |
3.3.0 | 192 | 12/10/2023 |
3.2.0 | 191 | 12/9/2023 |
3.1.1 | 189 | 12/9/2023 |
3.1.0 | 203 | 12/9/2023 |
3.0.0 | 235 | 12/9/2023 |
2.0.0 | 184 | 11/28/2023 |
1.4.0 | 300 | 11/17/2023 |
1.3.3 | 143 | 11/16/2023 |
1.3.2 | 176 | 11/16/2023 |
1.3.1 | 186 | 11/16/2023 |
1.3.0 | 186 | 11/16/2023 |
1.2.1 | 217 | 10/29/2023 |
1.2.0 | 191 | 10/22/2023 |
1.1.0 | 304 | 4/24/2023 |
1.0.0 | 282 | 4/23/2023 |
Subclassing for GTK4 objects