2016-10-18 19:21:12 +00:00
|
|
|
<?xml version="1.0"?>
|
|
|
|
<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN"
|
|
|
|
"http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" [
|
|
|
|
<!ENTITY % local.common.attrib "xmlns:xi CDATA #FIXED 'http://www.w3.org/2003/XInclude'">
|
|
|
|
]>
|
|
|
|
<chapter id="gtk-migrating-3-to-4">
|
2019-02-05 09:14:31 +00:00
|
|
|
<title>Migrating from GTK 3.x to GTK 4</title>
|
2016-10-18 19:21:12 +00:00
|
|
|
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK 4 is a major new version of GTK that breaks both API and ABI
|
|
|
|
compared to GTK 3.x. Thankfully, most of the changes are not hard
|
2016-10-18 20:20:44 +00:00
|
|
|
to adapt to and there are a number of steps that you can take to
|
2019-02-05 09:14:31 +00:00
|
|
|
prepare your GTK 3.x application for the switch to GTK 4. After
|
2016-10-18 20:20:44 +00:00
|
|
|
that, there's a small number of adjustments that you may have to do
|
2019-02-05 09:14:31 +00:00
|
|
|
when you actually switch your application to build against GTK 4.
|
2016-10-18 19:21:12 +00:00
|
|
|
</para>
|
|
|
|
|
2016-10-18 20:20:44 +00:00
|
|
|
<section>
|
2019-02-05 09:14:31 +00:00
|
|
|
<title>Preparation in GTK 3.x</title>
|
2016-10-18 20:20:44 +00:00
|
|
|
|
|
|
|
<para>
|
|
|
|
The steps outlined in the following sections assume that your
|
2019-02-05 09:14:31 +00:00
|
|
|
application is working with GTK 3.24, which is the final stable
|
|
|
|
release of GTK 3.x. It includes all the necessary APIs and tools
|
|
|
|
to help you port your application to GTK 4. If you are still using
|
|
|
|
an older version of GTK 3.x, you should first get your application
|
2018-07-19 00:22:18 +00:00
|
|
|
to build and work with the latest minor release in the 3.24 series.
|
2016-10-18 20:20:44 +00:00
|
|
|
</para>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Do not use deprecated symbols</title>
|
|
|
|
<para>
|
|
|
|
Over the years, a number of functions, and in some cases, entire
|
|
|
|
widgets have been deprecated. These deprecations are clearly spelled
|
|
|
|
out in the API reference, with hints about the recommended replacements.
|
2019-02-05 09:14:31 +00:00
|
|
|
The API reference for GTK 3 also includes an
|
2018-07-19 00:22:18 +00:00
|
|
|
<ulink url="https://developer.gnome.org/gtk3/3.24/api-index-deprecated.html">index</ulink> of all deprecated symbols.
|
2016-10-18 20:20:44 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
To verify that your program does not use any deprecated symbols,
|
|
|
|
you can use defines to remove deprecated symbols from the header files,
|
|
|
|
as follows:
|
|
|
|
<programlisting>
|
|
|
|
make CFLAGS+="-DGDK_DISABLE_DEPRECATED -DGTK_DISABLE_DEPRECATED"
|
|
|
|
</programlisting>
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
Note that some parts of our API, such as enumeration values, are
|
|
|
|
not well covered by the deprecation warnings. In most cases, using
|
|
|
|
them will require you to also use deprecated functions, which will
|
|
|
|
trigger warnings.
|
|
|
|
</para>
|
|
|
|
</section>
|
2016-10-20 20:09:45 +00:00
|
|
|
|
2018-02-09 19:36:00 +00:00
|
|
|
<section>
|
|
|
|
<title>Enable diagnostic warnings</title>
|
|
|
|
<para>
|
|
|
|
Deprecations of properties and signals cannot be caught at compile
|
|
|
|
time, as both properties and signals are installed and used after
|
|
|
|
types have been instantiated. In order to catch deprecations and
|
|
|
|
changes in the run time components, you should use the
|
|
|
|
<envar>G_ENABLE_DIAGNOSTIC</envar> environment variable when
|
|
|
|
running your application, e.g.:
|
|
|
|
<programlisting>
|
|
|
|
G_ENABLE_DIAGNOSTIC=1 ./your-app
|
|
|
|
</programlisting>
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-11-20 12:46:47 +00:00
|
|
|
<section>
|
|
|
|
<title>Do not use widget style properties</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
Style properties do not exist in GTK 4. You should stop using them in
|
2017-12-01 15:29:14 +00:00
|
|
|
your custom CSS and in your code.
|
2016-11-20 12:46:47 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-10-20 20:09:45 +00:00
|
|
|
<section>
|
|
|
|
<title>Review your window creation flags</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK 4 removes the GDK_WA_CURSOR flag. Instead, just use
|
2018-07-19 00:22:18 +00:00
|
|
|
gdk_window_set_cursor() to set a cursor on the window after
|
2016-10-20 20:09:45 +00:00
|
|
|
creating it.
|
|
|
|
</para>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK 4 also removes the GDK_WA_VISUAL flag, and always uses
|
2016-10-20 20:09:45 +00:00
|
|
|
an RGBA visual for windows. To prepare your code for this,
|
2018-07-19 00:22:18 +00:00
|
|
|
use gdk_window_set_visual (gdk_screen_get_rgba_visual ()) after
|
2016-10-20 20:09:45 +00:00
|
|
|
creating your window.
|
|
|
|
</para>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK 4 also removes the GDK_WA_WMCLASS flag. If you need this
|
2016-10-20 20:09:45 +00:00
|
|
|
X11-specific functionality, use XSetClassHint() directly.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Stop using non-RGBA visuals</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK 4 always uses RGBA visuals for its windows; you should make
|
2016-10-20 20:09:45 +00:00
|
|
|
sure that your code works with that.
|
|
|
|
</para>
|
2017-12-01 15:29:14 +00:00
|
|
|
<para>
|
|
|
|
At the same time, you should stop using GdkVisual APIs, this object
|
2019-02-05 09:14:31 +00:00
|
|
|
not longer exist in GTK 4. Most of its APIs are deprecated already
|
2017-12-01 15:29:14 +00:00
|
|
|
and not useful when dealing with RGBA visuals.
|
|
|
|
</para>
|
2016-10-20 20:09:45 +00:00
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
2017-04-28 15:11:52 +00:00
|
|
|
<title>Stop using GtkBox:padding, GtkBox:fill and GtkBox:expand</title>
|
2016-10-20 20:09:45 +00:00
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK4 removes these #GtkBox child properties, so you should not use them.
|
2017-04-28 15:11:52 +00:00
|
|
|
You can replace GtkBox:padding using the #GtkWidget:margin properties
|
|
|
|
on your #GtkBox child widgets.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
The fill child property can be replaced by setting appropriate values
|
|
|
|
for the #GtkWidget:halign and #GtkWidget:valign properties of the child
|
|
|
|
widgets. If you previously set the fill child property to %TRUE, you can
|
|
|
|
achieve the same effect by setting the halign or valign properties to
|
|
|
|
%GTK_ALIGN_FILL, depending on the parent box -- halign for a horizontal
|
2017-12-01 15:29:14 +00:00
|
|
|
box, valign for a vertical one.
|
2017-04-28 15:11:52 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
#GtkBox also uses the expand child property. It can be replaced by setting
|
|
|
|
#GtkWidget:hexpand or #GtkWidget:vexpand on the child widgets. To match the
|
|
|
|
old behavior of the #GtkBox's expand child property, you need to set
|
|
|
|
#GtkWidget:hexpand on the child widgets of a horizontal #GtkBox and
|
|
|
|
#GtkWidget:vexpand on the child widgets of a vertical #GtkBox.
|
2017-12-01 15:29:14 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2017-04-28 15:11:52 +00:00
|
|
|
Note that there's a subtle but important difference between #GtkBox's
|
|
|
|
expand and fill child properties and the ones in #GtkWidget: setting
|
|
|
|
#GtkWidget:hexpand or #GtkWidget:vexpand to %TRUE will propagate up
|
2017-12-01 15:29:14 +00:00
|
|
|
the widget hierarchy, so a pixel-perfect port might require you to reset
|
|
|
|
the expansion flags to %FALSE in a parent widget higher up the hierarchy.
|
2016-10-20 20:09:45 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Stop using the state argument of GtkStyleContext getters</title>
|
|
|
|
<para>
|
|
|
|
The getters in the GtkStyleContext API, such as
|
|
|
|
gtk_style_context_get_property(), gtk_style_context_get(),
|
|
|
|
or gtk_style_context_get_color() only accept the context's current
|
2017-12-01 15:29:14 +00:00
|
|
|
state for their state argument. You should update all callers to pass
|
|
|
|
the current state.
|
2016-10-20 20:09:45 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-11-20 12:46:47 +00:00
|
|
|
<section>
|
2018-03-20 11:05:26 +00:00
|
|
|
<title>Stop using gdk_pixbuf_get_from_window() and gdk_cairo_set_source_surface()</title>
|
2016-11-20 12:46:47 +00:00
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
These functions are not supported in GTK 4. Instead, either use backend-specific
|
2016-11-20 12:46:47 +00:00
|
|
|
APIs, or render your widgets using gtk_widget_render().
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2018-02-13 12:57:18 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop using GtkButton's image-related API</title>
|
|
|
|
<para>
|
|
|
|
The functions and properties related to automatically add a GtkImage
|
|
|
|
to a GtkButton, and using a GtkSetting to control its visibility, are
|
2019-02-05 09:14:31 +00:00
|
|
|
not supported in GTK 4. Instead, you can just pack a GtkImage inside
|
2018-02-13 12:57:18 +00:00
|
|
|
a GtkButton, and control its visibility like you would for any other
|
|
|
|
widget. If you only want to add a named icon to a GtkButton, you can
|
|
|
|
use gtk_button_set_icon_name().
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2018-07-19 00:22:18 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop using GtkWidget event signals</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
Event controllers and #GtkGestures replace event signals in GTK 4. They
|
|
|
|
have been backported to GTK 3.x so you can prepare for this change.
|
2018-07-19 00:22:18 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2018-08-02 09:03:41 +00:00
|
|
|
<section>
|
|
|
|
<title>Set a proper app_id</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
In GTK4 we want the application's #GApplication
|
2018-08-02 09:03:41 +00:00
|
|
|
'application-id' (and therefore the D-Bus name), the desktop
|
|
|
|
file basename and Wayland's xdg-shell app_id to match. In
|
2019-02-05 09:14:31 +00:00
|
|
|
order to achieve this with GTK3 call g_set_prgname() with the same
|
2018-08-02 09:03:41 +00:00
|
|
|
application id you passed to #GtkApplication. Rename your
|
|
|
|
desktop files to match the application id if needed.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
The call to g_set_prgname() can be removed once you fully migrated
|
2019-02-05 09:14:31 +00:00
|
|
|
to GTK4.
|
2018-08-02 09:03:41 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2018-12-29 08:53:16 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop using GtkBox's pack-type child property</title>
|
|
|
|
<para>
|
|
|
|
In order to improve performance and simplify the widget, GtkBox lost its
|
2019-02-05 09:14:31 +00:00
|
|
|
'pack-type' child property. In GTK4, every GtkBox instance has a simple
|
2018-12-29 08:53:16 +00:00
|
|
|
list of child widgets that it allocates from start to end.
|
|
|
|
The old behavior of pack-type=END can be emulated by simply making the
|
|
|
|
box child in the center hexpand and right-align the ones at the end.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-10-20 20:09:45 +00:00
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Changes that need to be done at the time of the switch</title>
|
|
|
|
|
|
|
|
<para>
|
|
|
|
This section outlines porting tasks that you need to tackle when
|
|
|
|
you get to the point that you actually build your application against
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK 4. Making it possible to prepare for these in GTK 3 would
|
2016-10-20 20:09:45 +00:00
|
|
|
have been either impossible or impractical.
|
|
|
|
</para>
|
|
|
|
|
2017-12-01 15:29:14 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop using GdkScreen</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
The GdkScreen object has been removed in GTK 4. Most of its APIs already
|
|
|
|
had replacements in GTK 3 and were deprecated, a few remaining replacements
|
2017-12-01 15:29:14 +00:00
|
|
|
have been added to GdkDisplay.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Stop using the root window</title>
|
|
|
|
<para>
|
|
|
|
The root window is an X11-centric concept that is no longer exposed in the
|
2018-03-20 10:40:08 +00:00
|
|
|
backend-neutral GDK API. gdk_surface_get_parent() will return %NULL for toplevel
|
2017-12-01 15:29:14 +00:00
|
|
|
windows. If you need to interact with the X11 root window, you can use
|
|
|
|
gdk_x11_display_get_xrootwindow() to get its XID.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2017-12-26 14:30:07 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop using GdkVisual</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
This object is not useful with current GTK drawing APIs and has been removed
|
2017-12-26 14:30:07 +00:00
|
|
|
without replacement.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2017-12-01 15:29:14 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop using GdkDeviceManager</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
The GdkDeviceManager object has been removed in GTK 4. Most of its APIs already
|
|
|
|
had replacements in GTK 3 and were deprecated in favor of GdkSeat.
|
2017-12-01 15:29:14 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-11-20 12:46:47 +00:00
|
|
|
<section>
|
2018-05-05 01:09:57 +00:00
|
|
|
<title>Adapt to GdkWindow API changes</title>
|
2016-11-20 12:46:47 +00:00
|
|
|
<para>
|
2018-05-05 01:09:57 +00:00
|
|
|
GdkWindow has been renamed to GdkSurface.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
The gdk_window_new() function has been replaced by a number of more
|
2018-03-20 10:40:08 +00:00
|
|
|
specialized constructors: gdk_surface_new_toplevel(), gdk_surface_new_popup(),
|
|
|
|
gdk_surface_new_temp(), gdk_surface_new_child(), gdk_surface_new_input(),
|
|
|
|
gdk_wayland_surface_new_subsurface(). Use the appropriate ones to create
|
2016-11-20 12:46:47 +00:00
|
|
|
your windows.
|
|
|
|
</para>
|
2017-01-11 02:20:38 +00:00
|
|
|
<para>
|
|
|
|
Native and foreign subwindows are no longer supported. These concepts were
|
|
|
|
complicating the code and could not be supported across backends.
|
|
|
|
</para>
|
|
|
|
<para>
|
2018-05-05 01:09:57 +00:00
|
|
|
gdk_window_reparent() is no longer available.
|
2017-01-11 02:20:38 +00:00
|
|
|
</para>
|
2016-11-20 12:46:47 +00:00
|
|
|
</section>
|
|
|
|
|
2017-12-01 15:29:14 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop accessing GdkEvent fields</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
Direct access to GdkEvent structs is no longer possible in GTK 4. Some
|
|
|
|
frequently-used fields already had accessors in GTK 3, and the remaining
|
|
|
|
fields have gained accessors in GTK 4.
|
2017-12-01 15:29:14 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2017-12-26 14:30:07 +00:00
|
|
|
<section>
|
2018-03-20 10:40:08 +00:00
|
|
|
<title>Stop using gdk_surface_set_event_compression</title>
|
2017-12-26 14:30:07 +00:00
|
|
|
<para>
|
|
|
|
Event compression is now always enabled. If you need to see the uncoalesced
|
|
|
|
motion history, use gdk_event_get_motion_history().
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2017-12-15 12:48:36 +00:00
|
|
|
<section>
|
2019-03-27 06:18:36 +00:00
|
|
|
<title>Stop using gdk_pointer_warp()</title>
|
|
|
|
<para>
|
|
|
|
Warping the pointer is disorienting and unfriendly to users.
|
2019-03-27 18:21:26 +00:00
|
|
|
GTK 4 does not support it. In special circumstances (such as when
|
|
|
|
implementing remote connection UIs) it can be necessary to
|
|
|
|
warp the pointer; in this case, use platform APIs such as XWarpPointer
|
|
|
|
directly.
|
2019-03-27 06:18:36 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Adapt to coordinate api changes</title>
|
|
|
|
<para>
|
|
|
|
A number of coordinate apis in GTK 3 had _double variants:
|
|
|
|
gdk_device_get_position(), gdk_device_get_surface_at_position(),
|
|
|
|
gdk_surface_get_device_position(). These have been changed to use
|
|
|
|
doubles, and the _double variants have been removed. Update your
|
|
|
|
code accordingly.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
2017-12-15 12:48:36 +00:00
|
|
|
<title>Adapt to GdkKeymap API changes</title>
|
|
|
|
<para>
|
2017-12-26 14:30:07 +00:00
|
|
|
The way to get a keymap has changed slightly. gdk_keymap_get_for_display() has
|
|
|
|
been renamed to gdk_display_get_keymap().
|
2017-12-15 12:48:36 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2018-08-05 23:53:02 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop using GtkEventBox</title>
|
|
|
|
<para>
|
|
|
|
GtkEventBox is no longer needed and has been removed.
|
|
|
|
All widgets receive all events.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2019-02-07 18:04:57 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop using GtkButtonBox</title>
|
|
|
|
<para>
|
|
|
|
GtkButtonBox has been removed. Use a GtkBox instead.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Adapt to GtkButton API changes</title>
|
|
|
|
<para>
|
|
|
|
GtkBox no longer has pack-start and -end. Pack your widgets in the
|
|
|
|
correct order, or reorder them as necessary.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2017-12-08 03:36:29 +00:00
|
|
|
<section>
|
2019-03-27 17:52:47 +00:00
|
|
|
<title>Adapt to GtkHeaderBar and GtkActionBar API changes</title>
|
2017-12-08 03:36:29 +00:00
|
|
|
<para>
|
|
|
|
The gtk_header_bar_set_show_close_button() function has been renamed to
|
2017-12-26 14:30:07 +00:00
|
|
|
the more accurate name gtk_header_bar_set_show_title_buttons(). The corresponding
|
|
|
|
getter and the property itself have also been renamed.
|
2017-12-08 03:36:29 +00:00
|
|
|
</para>
|
2019-03-27 17:52:47 +00:00
|
|
|
<para>
|
|
|
|
The ::pack-type child properties of GtkHeaderBar and GtkActionBar have
|
|
|
|
been removed. If you need to programmatically place children, use the
|
|
|
|
pack_start() and pack_end() APIs. In ui files, use the type attribute
|
|
|
|
on the child element.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
gtk4-builder-tool can help with this conversion, with the --3to4 option
|
|
|
|
of the simplify command.
|
|
|
|
</para>
|
2017-12-08 03:36:29 +00:00
|
|
|
</section>
|
|
|
|
|
2019-02-07 18:12:07 +00:00
|
|
|
<section>
|
2019-02-21 06:09:09 +00:00
|
|
|
<title>Adapt to GtkStack, GtkAssistant and GtkNotebook API changes</title>
|
2019-02-07 18:12:07 +00:00
|
|
|
<para>
|
2019-02-21 06:09:09 +00:00
|
|
|
The child properties of GtkStack, GtkAssistant and GtkNotebook have been
|
|
|
|
converted into child meta objects.
|
2019-02-07 18:12:07 +00:00
|
|
|
Instead of gtk_container_child_set (stack, child, …), you can now use
|
|
|
|
g_object_set (gtk_stack_get_page (stack, child), …). In .ui files, the
|
|
|
|
GtkStackPage objects must be created explicitly, and take the child widget
|
2019-02-21 06:09:09 +00:00
|
|
|
as property. GtkNotebook and GtkAssistant are similar.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
gtk4-builder-tool can help with this conversion, with the --3to4 option
|
|
|
|
of the simplify command.
|
2019-02-07 18:12:07 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-10-20 20:09:45 +00:00
|
|
|
<section>
|
|
|
|
<title>Adapt to GtkStyleContext API changes</title>
|
|
|
|
<para>
|
|
|
|
The getters in the GtkStyleContext API, such as
|
|
|
|
gtk_style_context_get_property(), gtk_style_context_get(),
|
|
|
|
or gtk_style_context_get_color() have lost their state argument,
|
|
|
|
and always use the context's current state. Update all callers
|
|
|
|
to omit the state argument.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-11-20 12:46:47 +00:00
|
|
|
<section>
|
|
|
|
<title>Adapt to GtkCssProvider API changes</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
In GTK 4, the various #GtkCssProvider load functions have lost
|
2016-11-20 12:46:47 +00:00
|
|
|
their #GError argument. If you want to handle CSS loading errors,
|
|
|
|
use the #GtkCssProvider::parsing-error signal instead.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-10-21 13:58:36 +00:00
|
|
|
<section>
|
|
|
|
<title>Stop using GtkContainer::border-width</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK 4 has removed the #GtkContainer::border-width property.
|
2017-01-11 02:20:38 +00:00
|
|
|
Use other means to influence the spacing of your containers,
|
2017-01-21 22:43:35 +00:00
|
|
|
such as the CSS margin and padding properties on child widgets.
|
2016-10-21 13:58:36 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-10-22 19:40:04 +00:00
|
|
|
<section>
|
|
|
|
<title>Adapt to GtkWidget's size request changes</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK 3 used five different virtual functions in GtkWidget to
|
2016-10-22 19:40:04 +00:00
|
|
|
implement size requisition, namely the gtk_widget_get_preferred_width()
|
2019-02-05 09:14:31 +00:00
|
|
|
family of functions. To simplify widget implementations, GTK4 uses
|
2016-10-22 19:40:04 +00:00
|
|
|
only one virtual function, GtkWidgetClass::measure() that widgets
|
|
|
|
have to implement.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2018-07-29 13:10:44 +00:00
|
|
|
<section>
|
|
|
|
<title>Adapt to GtkWidget's size allocation changes</title>
|
|
|
|
<para>
|
|
|
|
The #GtkWidget::size-allocate signal now takes the baseline as an
|
|
|
|
argument, so you no longer need to call gtk_widget_get_allocated_baseline()
|
|
|
|
to get it.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2017-01-11 02:20:38 +00:00
|
|
|
<section>
|
|
|
|
<title>Switch to GtkWidget's children APIs</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
Instead of the GtkContainer subclass, in GTK 4, any widget can
|
2017-01-11 02:20:38 +00:00
|
|
|
have children, and there is new API to navigate the widget tree:
|
|
|
|
gtk_widget_get_first_child(), gtk_widget_get_last_child(),
|
|
|
|
gtk_widget_get_next_sibling(), gtk_widget_get_prev_sibling().
|
|
|
|
The GtkContainer API still works, but if you are implementing
|
|
|
|
your own widgets, you should consider using the new APIs.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-11-07 19:59:23 +00:00
|
|
|
<section>
|
|
|
|
<title>Don't use -gtk-gradient in your CSS</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK now supports standard CSS syntax for both linear and radial
|
2016-11-07 19:59:23 +00:00
|
|
|
gradients, just use those.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2017-01-11 02:20:38 +00:00
|
|
|
<section>
|
|
|
|
<title>Don't use -gtk-icon-effect in your CSS</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
GTK now supports a more versatile -gtk-icon-filter instead. Replace
|
2017-01-11 02:20:38 +00:00
|
|
|
-gtk-icon-effect: dim; with -gtk-icon-filter: opacity(0.5); and
|
|
|
|
-gtk-icon-effect: hilight; with -gtk-icon-filter: brightness(1.2);.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2016-11-18 12:42:49 +00:00
|
|
|
<section>
|
2016-11-20 12:46:47 +00:00
|
|
|
<title>Use gtk_widget_measure</title>
|
|
|
|
<para>
|
2017-12-26 14:30:07 +00:00
|
|
|
gtk_widget_measure() replaces the various gtk_widget_get_preferred_ functions
|
2016-11-20 12:46:47 +00:00
|
|
|
for querying sizes.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
2016-11-18 12:42:49 +00:00
|
|
|
<title>Adapt to drawing model changes</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
This area has seen the most radical changes in the transition from GTK 3
|
|
|
|
to GTK 4. Widgets no longer use a draw() function to render their contents
|
2016-11-18 12:42:49 +00:00
|
|
|
to a cairo surface. Instead, they have a snapshot() function that creates
|
|
|
|
one or more GskRenderNodes to represent their content. Third-party widgets
|
|
|
|
that use a draw() function or a #GtkWidget::draw signal handler for custom
|
2017-01-13 03:46:09 +00:00
|
|
|
drawing will need to be converted to use gtk_snapshot_append_cairo().
|
2016-11-18 12:42:49 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
The auxiliary #GtkSnapshot object has APIs to help with creating render
|
|
|
|
nodes.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
If you are using a #GtkDrawingArea for custom drawing, you need to switch
|
2017-12-26 14:30:07 +00:00
|
|
|
to using gtk_drawing_area_set_draw_func() to set a draw function instead
|
|
|
|
of connnecting a handler to the #GtkWidget::draw signal.
|
2016-11-18 12:42:49 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2017-01-11 02:20:38 +00:00
|
|
|
<section>
|
2018-03-20 10:40:08 +00:00
|
|
|
<title>Stop using APIs to query GdkSurfaces</title>
|
2017-01-11 02:20:38 +00:00
|
|
|
<para>
|
|
|
|
A number of APIs for querying special-purpose windows have been removed,
|
|
|
|
since these windows are no longer publically available:
|
2017-12-01 15:29:14 +00:00
|
|
|
gtk_tree_view_get_bin_window(), gtk_viewport_get_bin_window(),
|
2017-01-11 02:20:38 +00:00
|
|
|
gtk_viewport_get_view_window().
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
2017-12-26 14:30:07 +00:00
|
|
|
<section>
|
|
|
|
<title>Widgets are now visible by default</title>
|
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
The default value of #GtkWidget::visible in GTK 4 is %TRUE, so you no
|
2017-12-26 14:30:07 +00:00
|
|
|
longer need to explicitly show all your widgets. On the flip side, you
|
|
|
|
need to hide widgets that are not meant to be visible from the start.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
A convenient way to remove unnecessary property assignments like this
|
|
|
|
from ui files it run the command <command>gtk4-builder-tool simplify --replace</command>
|
|
|
|
on them.
|
|
|
|
</para>
|
2018-07-31 17:29:32 +00:00
|
|
|
<para>
|
|
|
|
The function gtk_widget_show_all(), the #GtkWidget::no-show-all property
|
2019-02-05 09:14:31 +00:00
|
|
|
and its getter and setter have been removed in GTK 4, so you should stop using them.
|
2018-07-31 17:29:32 +00:00
|
|
|
</para>
|
2017-12-26 14:30:07 +00:00
|
|
|
</section>
|
|
|
|
|
2017-01-11 02:20:38 +00:00
|
|
|
<section>
|
|
|
|
<title>Adapt to changes in animated hiding and showing of widgets</title>
|
|
|
|
<para>
|
|
|
|
Widgets that appear and disappear with an animation, such as GtkPopover,
|
|
|
|
GtkInfoBar, GtkRevealer no longer use gtk_widget_show() and gtk_widget_hide()
|
|
|
|
for this, but have gained dedicated APIs for this purpose that you should
|
|
|
|
use.
|
|
|
|
</para>
|
|
|
|
</section>
|
2017-01-19 18:52:52 +00:00
|
|
|
|
|
|
|
<section>
|
2017-12-26 14:30:07 +00:00
|
|
|
<title>Stop passing commandline arguments to gtk_init</title>
|
2017-01-19 18:52:52 +00:00
|
|
|
<para>
|
|
|
|
The gtk_init() and gtk_init_check() functions no longer accept commandline
|
|
|
|
arguments. Just call them without arguments. Other initialization functions
|
|
|
|
that were purely related to commandline argument handling, such as
|
|
|
|
gtk_parse_args() and gtk_get_option_group(), are gone. The APIs to
|
|
|
|
initialize GDK separately are also gone, but it is very unlikely
|
|
|
|
that you are affected by that.
|
|
|
|
</para>
|
|
|
|
</section>
|
2017-10-23 16:33:15 +00:00
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>GdkPixbuf is deemphasized</title>
|
|
|
|
<para>
|
2017-12-26 14:30:07 +00:00
|
|
|
A number of #GdkPixbuf-based APIs have been removed. The available replacements
|
2018-05-05 01:09:57 +00:00
|
|
|
are either using #GIcon, or the newly introduced #GdkTexture or #GdkPaintable
|
|
|
|
classes instead.
|
2017-12-01 15:29:14 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2017-12-26 14:30:07 +00:00
|
|
|
If you are dealing with pixbufs, you can use gdk_texture_new_for_pixbuf()
|
|
|
|
to convert them to texture objects where needed.
|
2017-12-01 15:29:14 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
2018-05-05 01:09:57 +00:00
|
|
|
<title>GtkWidget event signals are removed</title>
|
2017-12-01 15:29:14 +00:00
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
Event controllers and #GtkGestures have already been introduced in GTK 3 to handle
|
|
|
|
input for many cases. In GTK 4, the traditional widget signals for handling input,
|
2018-05-05 01:09:57 +00:00
|
|
|
such as #GtkWidget::motion-event or #GtkWidget::event have been removed.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Invalidation handling has changed</title>
|
|
|
|
<para>
|
|
|
|
Only gtk_widget_queue_draw() is left to mark a widget as needing redraw.
|
|
|
|
Variations like gtk_widget_queue_draw_rectangle() or gtk_widget_queue_draw_region()
|
|
|
|
are no longer available.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Stop using GtkWidget::draw</title>
|
|
|
|
<para>
|
|
|
|
The #GtkWidget::draw signal has been removed. Widgets need to implement the
|
|
|
|
#GtkWidget::snapshot function now. Connecting draw signal handlers is no longer possible.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Window content observation has changed</title>
|
|
|
|
<para>
|
|
|
|
Observing widget contents and widget size is now done by using the
|
|
|
|
#GtkWidgetPaintable object instead of connecting to widget signals.
|
2017-12-01 15:29:14 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
2017-12-26 14:30:07 +00:00
|
|
|
<title>The gtk_window_fullscreen_on_monitor API has changed</title>
|
2017-12-01 15:29:14 +00:00
|
|
|
<para>
|
2017-12-26 14:30:07 +00:00
|
|
|
Instead of a monitor number, gtk_window_fullscreen_on_monitor() now takes a
|
|
|
|
#GdkMonitor argument.
|
2017-12-01 15:29:14 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Adapt to cursor API changes</title>
|
|
|
|
<para>
|
|
|
|
Use the new gtk_widget_set_cursor() function to set cursors, instead of
|
|
|
|
setting the cursor on the underlying window directly. This is necessary
|
|
|
|
because most widgets don't have their own window anymore, turning any
|
|
|
|
such calls into global cursor changes.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
For creating standard cursors, gdk_cursor_new_for_display() has been removed,
|
|
|
|
you have to use cursor names instead of GdkCursorType. For creating custom cursors,
|
|
|
|
use gdk_cursor_new_from_texture(). The ability to get cursor images has been removed.
|
|
|
|
</para>
|
|
|
|
</section>
|
|
|
|
|
|
|
|
<section>
|
2017-12-26 14:30:07 +00:00
|
|
|
<title>Adapt to icon size API changes</title>
|
2017-12-01 15:29:14 +00:00
|
|
|
<para>
|
2019-02-05 09:14:31 +00:00
|
|
|
Instead of the existing extensible set of symbolic icon sizes, GTK now only
|
2017-12-26 14:30:07 +00:00
|
|
|
supports normal and large icons with the #GtkIconSize enumeration. The actual sizes
|
|
|
|
can be defined by themes via the CSS property -gtk-icon-size.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
GtkImage setters like gtk_image_set_from_icon_name() no longer take a #GtkIconSize
|
|
|
|
argument. You can use the separate gtk_image_set_icon_size() setter if you need
|
|
|
|
to override the icon size.
|
2017-12-01 15:29:14 +00:00
|
|
|
</para>
|
|
|
|
<para>
|
2017-12-26 14:30:07 +00:00
|
|
|
The ::stock-size property of GtkCellRendererPixbuf has been renamed to
|
|
|
|
#GtkCellRendererPixbuf:icon-size.
|
2017-10-23 16:33:15 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
2018-05-05 01:09:57 +00:00
|
|
|
|
2019-02-07 18:12:07 +00:00
|
|
|
<section>
|
|
|
|
<title>Convert .ui files</title>
|
|
|
|
<para>
|
|
|
|
The simplify command of gtk4-builder-tool has gained a --3to4 option, which
|
|
|
|
can help with some of the required changes in .ui files, such as converting
|
|
|
|
child properties to child meta objects.
|
|
|
|
</para>
|
|
|
|
</section>
|
2019-02-14 19:46:01 +00:00
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Adapt to changes in the GtkAssistant API</title>
|
|
|
|
<para>
|
|
|
|
The ::has-padding property is gone, and GtkAssistant no longer adds padding
|
|
|
|
to pages. You can easily do that yourself.
|
|
|
|
</para>
|
|
|
|
</section>
|
2019-02-19 05:10:24 +00:00
|
|
|
|
|
|
|
<section>
|
2019-02-28 19:31:36 +00:00
|
|
|
<title>Adapt to changes in the API of GtkEntry, GtkSearchEntry adn GtkSpinButton</title>
|
2019-02-19 05:10:24 +00:00
|
|
|
<para>
|
|
|
|
The GtkEditable has been made more useful, and the core functionality of
|
|
|
|
GtkEntry has been broken out as a GtkText widget. GtkEntry, GtkSearchEntry,
|
|
|
|
GtkSpinButton and the new GtkPasswordEntry now use a GtkText widget internally
|
|
|
|
and implement GtkEditable. In particular, this means that it is no longer
|
|
|
|
possible to use GtkEntry API such as gtk_entry_grab_focus_without_selecting()
|
|
|
|
on a search entry.
|
|
|
|
</para>
|
|
|
|
<para>
|
|
|
|
Use GtkEditable API for editable functionality, and widget-specific APIs for
|
|
|
|
things that go beyond the common interface. For password entries, use
|
2019-02-28 19:31:36 +00:00
|
|
|
GtkPasswordEntry. As an example, gtk_spin_button_set_max_width_chars()
|
|
|
|
has been removed in favor of gtk_editable_set_max_width_chars().
|
2019-02-19 05:10:24 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
2019-02-22 03:07:39 +00:00
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Adapt to changes in GtkOverlay API</title>
|
|
|
|
<para>
|
|
|
|
The GtkOverlay::pass-through child property has been replaced by the
|
|
|
|
GtkWidget::can-pick property. Note that they have the oppositve sense:
|
|
|
|
pass-through == !can-pick.
|
|
|
|
</para>
|
|
|
|
</section>
|
2019-04-02 15:00:05 +00:00
|
|
|
|
|
|
|
<section>
|
|
|
|
<title>Use GtkFixed instead of GtkLayout</title>
|
|
|
|
<para>
|
|
|
|
Since GtkScrolledWindow can deal with widgets that do not implement
|
|
|
|
the GtkScrollable interface by automatically wrapping them into a
|
|
|
|
GtkViewport, GtkLayout is redundant, and has been removed in favor
|
2019-04-03 10:27:18 +00:00
|
|
|
of the existing GtkFixed container widget.
|
2019-04-02 15:00:05 +00:00
|
|
|
</para>
|
|
|
|
</section>
|
2016-10-18 20:20:44 +00:00
|
|
|
</section>
|
|
|
|
|
2016-10-18 19:21:12 +00:00
|
|
|
</chapter>
|
2016-10-20 20:09:45 +00:00
|
|
|
|