Introduction to GTK 4
The GTK 4 package contains
libraries used for creating graphical user interfaces for
applications.
Note
Development versions of BLFS may not build or run some packages
properly if LFS or dependencies have been updated since the most
recent stable versions of the books.
Package Information
-
Download (HTTP):
https://download.gnome.org/sources/gtk/4.16/gtk-4.16.12.tar.xz
-
Download MD5 sum: 0f2b154a0b05e4ca94a05aaeb7e1f3fb
-
Download size: 18 MB
-
Estimated disk space required: 1.1 GB (with docs; add 157 MB
for tests)
-
Estimated build time: 1.7 SBU (using parallelism=4; with
docs; add 1.1 SBU for tests or 3.7 SBU for NVIDIA)
GTK 4 Dependencies
Required
FriBidi-1.0.16, gdk-pixbuf-2.42.12, graphene-1.10.8,
ISO Codes-4.17.0, libepoxy-1.5.10,
libxkbcommon-1.7.0, Pango-1.56.1, PyGObject-3.50.0, and wayland-protocols-1.39
Recommended
adwaita-icon-theme-47.0 (default for
some gtk4 settings keys), gst-plugins-bad-1.24.11, glslc from shaderc-2024.4,
gst-plugins-good-1.24.11 (runtime,
built with libvpx-1.15.0), hicolor-icon-theme-0.18 (needed for
tests and for defaults), and librsvg-2.59.2, and Vulkan-Loader-1.4.304
Recommended (Required if building GNOME)
GLib-2.82.4 (with GObject Introspection) and
Vulkan-Loader-1.4.304
Optional
Avahi-0.8 (for some tests), colord-1.4.7,
Cups-2.4.11, docutils-0.21.2, Gi-DocGen-2024.1, Highlight-4.15 (runtime, only used by
gtk4-demo for syntax
highlighting of demo source code), libcloudproviders-0.3.6, sassc-3.6.2, tinysparql-3.8.2, cpdb, pydbus (for
some tests), and sysprof
Installation of GTK 4
Install GTK 4 by running the
following commands:
mkdir build &&
cd build &&
meson setup --prefix=/usr \
--buildtype=release \
-D broadway-backend=true \
-D introspection=enabled \
-D vulkan=enabled \
.. &&
ninja
If you have Gi-DocGen-2024.1 installed and wish to build
the API documentation for this package, issue:
sed "s@'doc'@& / 'gtk-4.16.12'@" -i ../docs/reference/meson.build &&
meson configure -D documentation=true &&
ninja
To run the tests, issue:
env -u{GALLIUM_DRIVER,MESA_LOADER_DRIVER_OVERRIDE} \
LIBGL_ALWAYS_SOFTWARE=1 VK_LOADER_DRIVERS_SELECT='lvp*' \
dbus-run-session meson test --setup x11 \
--no-suite={headless,needs-udmabuf}
If you are in a Wayland session, replace the one occurrence of
x11
with wayland
. One test is known to fail if Cantrell fonts
are not installed. About a dozen of tests are known to fail with
minor (mostly invisible) differences between the render output and
the shipped reference image. Issue grep 'not ok' meson-logs/testlog-x11.txt
-B3 (use testlog-wayland.txt
if testing in a Wayland
session) to list them and the image files showing the render
output, the reference output, and the differences. You may take a
look at those images to ensure the differences are insignificant.
Many tests will fail if ~/.config/gtk-4.0/settings.ini
exists and the
gtk-modules line is not commented out. Several other tests may fail
for unknown reason. On systems with NVIDIA graphics cards, the
tests may take significantly longer.
Now, as the root
user:
ninja install
Command Explanations
--buildtype=release
:
Specify a buildtype suitable for stable releases of the package, as
the default may produce unoptimized binaries.
-D broadway-backend=true
:
This switch enables the HTML5 GDK backend.
-D introspection=enabled
:
This switch enables using GObject Introspection to generate GIR
bindings of this packages. These bindings are required by GNOME.
-D cloudproviders=enabled
: Use this
switch if you have libcloudproviders-0.3.6 installed and
wish to enable support for cloud providers in a file chooser
window.
-D tracker=enabled
: Use this switch if
you have tinysparql-3.8.2 installed and wish to use
search functionality when running a file chooser.
-D colord=enabled
: Use this switch if
you have colord-1.4.7 installed and wish to use colord
with the CUPS printing backend.
-D man-pages=true
: Use this switch if
you have docutils-0.21.2 installed and wish to
generate the man pages.
-D sysprof=enabled
: Use this switch if
you have sysprof installed and
wish to enable tracing support for GTK4-based applications.
-D vulkan=disabled
: Use this switch
instead of -D
vulkan=enabled
if you don't have Vulkan-Loader-1.4.304 or glslc from shaderc-2024.4
installed. It will disable the Vulkan backend that the upstream
prefers to use on Wayland-based graphical environments.
LIBGL_ALWAYS_SOFTWARE=1
and VK_LOADER_DRIVERS_SELECT='lvp*'
: Force the test
suite to use the softpipe or llvmpipe Gallium driver and the
lavapipe Vulkan driver from Mesa. The test suite is so sensitive
that the minor differences caused by a different Mesa driver can
trigger test failures.
env
-u{GALLIUM_DRIVER,MESA_LOADER_DRIVER_OVERRIDE}:
Unset variables which may conflict with LIBGL_ALWAYS_SOFTWARE=1
.
--no-suite={headless,needs-udmabuf}
:
Disable the tests requiring the external dependency pydbus, and the
tests requiring the device node /dev/udmabuf
. The device node does not exist if
the feature is not enabled in the kernel configuration.
Configuring GTK 4
Config Files
~/.config/gtk-4.0/settings.ini
and
/usr/share/gtk-4.0/settings.ini
Configuration Information
GTK 4 themes change the way a
GTK 4 application looks. An icon
theme can be used to change the icons that appear on the
application's toolbar. If you have installed a GTK 4 theme (e.g. the Adwaita theme built in
GTK 4), an icon theme (such as
oxygen-icons-6.0.0) and/or a font
(Dejavu fonts), you can set your
preferences in ~/.config/gtk-4.0/settings.ini
, or the default
system-wide configuration file (as the root
user), in /usr/share/gtk-4.0/settings.ini
. For the local
user, an example is:
mkdir -pv ~/.config/gtk-4.0
cat > ~/.config/gtk-4.0/settings.ini << "EOF"
[Settings]
gtk-theme-name = Adwaita
gtk-icon-theme-name = oxygen
gtk-font-name = DejaVu Sans 12
gtk-cursor-theme-size = 18
gtk-xft-antialias = 1
gtk-xft-hinting = 1
gtk-xft-hintstyle = hintslight
gtk-xft-rgba = rgb
gtk-cursor-theme-name = Adwaita
EOF
There are many settings keys, some with default values. You can
find them at Settings:
GTK 4 Reference Manual.
Contents
Installed Programs:
gtk4-broadwayd, gtk4-builder-tool,
gtk4-demo, gtk4-demo-application, gtk4-encode-symbolic-svg,
gtk4-icon-browser, gtk4-launch, gtk4-node-editor,
gtk4-print-editor, gtk4-query-settings, gtk4-update-icon-cache,
and gtk4-widget-factory
Installed Libraries:
libgtk-4.so
Installed Directories:
/usr/include/gtk-4.0, /usr/lib/gtk-4.0,
and /usr/share/gtk-4.0
Short Descriptions
gtk4-broadwayd
|
provides support for displaying GTK 4 applications in a
web browser using HTML5 and web sockets
|
gtk4-builder-tool
|
performs various operations on GtkBuilder .ui files
|
gtk4-demo
|
is a simple program that demonstrates some of the tasks
that can be done with GTK 4
|
gtk4-demo-application
|
is a simple GTK 4 application which is useful for testing
|
gtk4-encode-symbolic-svg
|
converts symbolic SVG icons into special PNG files. GTK 4
can load and recolor these PNGs, just like original SVGs,
but loading them is much faster
|
gtk4-icon-browser
|
is a utility to explore the icons in the current icon
theme. It shows icons in various sizes, their symbolic
variants when available, as well as a description of the
icon and its context
|
gtk4-launch
|
launches an application using the given name. The name
should match the application .desktop file name (as seen
in /usr/share/applications ), with or
without the '.desktop' extension
|
gtk4-node-editor
|
is a utility to show and edit render node files. Such
render node files can be obtained e.g. from the GTK
inspector
|
gtk4-print-editor
|
is a simple program to demonstrate printing using GTK 4
applications
|
gtk4-query-settings
|
provides a complete listing of all settings related to
GTK 4
|
gtk4-update-icon-cache
|
is an icon theme caching utility that creates mmap()able
cache files for icon themes
|
gtk4-widget-factory
|
is a program to view GTK 4 themes and widgets
|
libgtk-4.so
|
contains functions that provide an API to implement
graphical user interfaces
|