diff options
author | Georges Basile Stavracas Neto <georges.stavracas@gmail.com> | 2018-03-16 01:59:16 -0300 |
---|---|---|
committer | Georges Basile Stavracas Neto <georges.stavracas@gmail.com> | 2018-03-16 02:01:38 -0300 |
commit | 6cd94618078e4a23c796e7182fe8c9196f614e7b (patch) | |
tree | e4e793d8d8a5f043806bde38eee337c9152760c5 | |
parent | ca9228bb59aa29d80cb2ff8f62b8690b78abb136 (diff) | |
download | gnome-control-center-6cd94618078e4a23c796e7182fe8c9196f614e7b.tar.gz |
universal-access: Turn ZoomOptions into a template class
This commit turns the ZoomOptions into a template class that
subclasses GtkDialog.
This is also a follow-up from commit c82deede1 where we started
using the non-deprecated GdkMonitor API.
-rw-r--r-- | panels/universal-access/cc-ua-panel.c | 9 | ||||
-rw-r--r-- | panels/universal-access/zoom-options.c | 369 | ||||
-rw-r--r-- | panels/universal-access/zoom-options.h | 50 | ||||
-rw-r--r-- | panels/universal-access/zoom-options.ui | 69 |
4 files changed, 201 insertions, 296 deletions
diff --git a/panels/universal-access/cc-ua-panel.c b/panels/universal-access/cc-ua-panel.c index a364ed0a3..23e7d8a56 100644 --- a/panels/universal-access/cc-ua-panel.c +++ b/panels/universal-access/cc-ua-panel.c @@ -174,11 +174,12 @@ static void zoom_options_launch (CcUaPanel *self) { if (self->priv->zoom_options == NULL) - self->priv->zoom_options = zoom_options_new (); + { + GtkWindow *window = GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (self))); + self->priv->zoom_options = zoom_options_new (window); + } - if (self->priv->zoom_options != NULL) - zoom_options_set_parent (self->priv->zoom_options, - GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (self)))); + gtk_window_present_with_time (GTK_WINDOW (self->priv->zoom_options), GDK_CURRENT_TIME); } /* cursor size dialog */ diff --git a/panels/universal-access/zoom-options.c b/panels/universal-access/zoom-options.c index c759271a6..4bd1cc7d1 100644 --- a/panels/universal-access/zoom-options.c +++ b/panels/universal-access/zoom-options.c @@ -23,18 +23,17 @@ #include <glib/gi18n.h> #include <string.h> -#define WID(w) (GtkWidget *) gtk_builder_get_object (priv->builder, w) - #define POSITION_MODEL_VALUE_COLUMN 2 #define FONT_SCALE 1.25 -struct _ZoomOptionsPrivate +struct _ZoomOptions { - GtkBuilder *builder; + GtkDialog parent; + GSettings *settings; GSettings *application_settings; - GtkWidget *position_combobox; + GtkWidget *screen_position_combobox; GtkWidget *follow_mouse_radio; GtkWidget *screen_part_radio; GtkWidget *centered_radio; @@ -43,11 +42,18 @@ struct _ZoomOptionsPrivate GtkWidget *extend_beyond_checkbox; GtkWidget *brightness_slider; GtkWidget *contrast_slider; - - GtkWidget *dialog; + GtkWidget *crosshair_picker_color_button; + GtkWidget *magnifier_factor_spin; + GtkWidget *seeing_zoom_switch; + GtkWidget *crosshair_thickness_scale; + GtkWidget *grayscale_slider; + GtkWidget *crosshair_clip_checkbox; + GtkWidget *crosshair_length_slider; + GtkWidget *crosshair_enabled_switcher; + GtkWidget *inverse_enabled_switch; }; -G_DEFINE_TYPE (ZoomOptions, zoom_options, G_TYPE_OBJECT); +G_DEFINE_TYPE (ZoomOptions, zoom_options, GTK_TYPE_DIALOG); static gchar *brightness_keys[] = { "brightness-red", @@ -63,33 +69,33 @@ static gchar *contrast_keys[] = { NULL }; -static void set_enable_screen_part_ui (GtkWidget *widget, ZoomOptionsPrivate *priv); -static void mouse_tracking_notify_cb (GSettings *settings, const gchar *key, ZoomOptionsPrivate *priv); +static void set_enable_screen_part_ui (GtkWidget *widget, ZoomOptions *self); +static void mouse_tracking_notify_cb (GSettings *settings, const gchar *key, ZoomOptions *self); static void scale_label (GtkBin *toggle, PangoAttrList *attrs); -static void xhairs_color_opacity_changed (GtkColorButton *button, ZoomOptionsPrivate *priv); -static void xhairs_length_add_marks (GtkScale *scale); +static void xhairs_color_opacity_changed (GtkColorButton *button, ZoomOptions *self); +static void xhairs_length_add_marks (ZoomOptions *self, GtkScale *scale); static void effects_slider_set_value (GtkRange *slider, GSettings *settings); -static void brightness_slider_notify_cb (GSettings *settings, const gchar *key, ZoomOptionsPrivate *priv); -static void contrast_slider_notify_cb (GSettings *settings, const gchar *key, ZoomOptionsPrivate *priv); -static void effects_slider_changed (GtkRange *slider, ZoomOptionsPrivate *priv); +static void brightness_slider_notify_cb (GSettings *settings, const gchar *key, ZoomOptions *self); +static void contrast_slider_notify_cb (GSettings *settings, const gchar *key, ZoomOptions *self); +static void effects_slider_changed (GtkRange *slider, ZoomOptions *self); static void -mouse_tracking_radio_toggled_cb (GtkWidget *widget, ZoomOptionsPrivate *priv) +mouse_tracking_radio_toggled_cb (GtkWidget *widget, ZoomOptions *self) { if (gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (widget)) == TRUE) { - g_settings_set_string (priv->settings, "mouse-tracking", + g_settings_set_string (self->settings, "mouse-tracking", gtk_buildable_get_name (GTK_BUILDABLE (widget))); } } static void -init_mouse_mode_radio_group (GSList *mode_group, ZoomOptionsPrivate *priv) +init_mouse_mode_radio_group (GSList *mode_group, ZoomOptions *self) { gchar *mode; gchar *name; - mode = g_settings_get_string (priv->settings, "mouse-tracking"); + mode = g_settings_get_string (self->settings, "mouse-tracking"); for (; mode_group != NULL; mode_group = mode_group->next) { name = (gchar *) gtk_buildable_get_name (GTK_BUILDABLE (mode_group->data)); @@ -100,94 +106,87 @@ init_mouse_mode_radio_group (GSList *mode_group, ZoomOptionsPrivate *priv) g_signal_connect (G_OBJECT (mode_group->data), "toggled", G_CALLBACK(mouse_tracking_radio_toggled_cb), - priv); + self); } } static void -init_screen_part_section (ZoomOptionsPrivate *priv, PangoAttrList *pango_attrs) +init_screen_part_section (ZoomOptions *self, PangoAttrList *pango_attrs) { gboolean lens_mode; GSList *mouse_mode_group; - priv->follow_mouse_radio = WID ("moveableLens"); - priv->screen_part_radio = WID ("screenPart"); - priv->centered_radio = WID ("centered"); - priv->push_radio = WID ("push"); - priv->proportional_radio = WID ("proportional"); - priv->extend_beyond_checkbox = WID ("scrollAtEdges"); - /* Scale the labels of the toggles */ - scale_label (GTK_BIN(priv->follow_mouse_radio), pango_attrs); - scale_label (GTK_BIN(priv->screen_part_radio), pango_attrs); - scale_label (GTK_BIN(priv->centered_radio), pango_attrs); - scale_label (GTK_BIN(priv->push_radio), pango_attrs); - scale_label (GTK_BIN(priv->proportional_radio), pango_attrs); - scale_label (GTK_BIN(priv->extend_beyond_checkbox), pango_attrs); - - lens_mode = g_settings_get_boolean (priv->settings, "lens-mode"); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (priv->follow_mouse_radio), lens_mode); - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (priv->screen_part_radio), !lens_mode); - - mouse_mode_group = gtk_radio_button_get_group (GTK_RADIO_BUTTON (priv->centered_radio)); - init_mouse_mode_radio_group (mouse_mode_group, priv); - set_enable_screen_part_ui (priv->screen_part_radio, priv); - - g_settings_bind (priv->settings, "lens-mode", - priv->follow_mouse_radio, "active", + scale_label (GTK_BIN (self->follow_mouse_radio), pango_attrs); + scale_label (GTK_BIN (self->screen_part_radio), pango_attrs); + scale_label (GTK_BIN (self->centered_radio), pango_attrs); + scale_label (GTK_BIN (self->push_radio), pango_attrs); + scale_label (GTK_BIN (self->proportional_radio), pango_attrs); + scale_label (GTK_BIN (self->extend_beyond_checkbox), pango_attrs); + + lens_mode = g_settings_get_boolean (self->settings, "lens-mode"); + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (self->follow_mouse_radio), lens_mode); + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (self->screen_part_radio), !lens_mode); + + mouse_mode_group = gtk_radio_button_get_group (GTK_RADIO_BUTTON (self->centered_radio)); + init_mouse_mode_radio_group (mouse_mode_group, self); + set_enable_screen_part_ui (self->screen_part_radio, self); + + g_settings_bind (self->settings, "lens-mode", + self->follow_mouse_radio, "active", G_SETTINGS_BIND_DEFAULT); - g_settings_bind (priv->settings, "scroll-at-edges", - priv->extend_beyond_checkbox, "active", + g_settings_bind (self->settings, "scroll-at-edges", + self->extend_beyond_checkbox, "active", G_SETTINGS_BIND_DEFAULT); - g_signal_connect (G_OBJECT (priv->screen_part_radio), "toggled", - G_CALLBACK (set_enable_screen_part_ui), priv); + g_signal_connect (G_OBJECT (self->screen_part_radio), "toggled", + G_CALLBACK (set_enable_screen_part_ui), self); - g_signal_connect (G_OBJECT (priv->settings), "changed::mouse-tracking", - G_CALLBACK (mouse_tracking_notify_cb), priv); + g_signal_connect (G_OBJECT (self->settings), "changed::mouse-tracking", + G_CALLBACK (mouse_tracking_notify_cb), self); } static void -set_enable_screen_part_ui (GtkWidget *widget, ZoomOptionsPrivate *priv) +set_enable_screen_part_ui (GtkWidget *widget, ZoomOptions *self) { gboolean screen_part; /* If the "screen part" radio is not checked, then the "follow mouse" radio * is checked (== lens mode). Set mouse tracking back to the default. */ - screen_part = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (priv->screen_part_radio)); + screen_part = gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (self->screen_part_radio)); if (!screen_part) { - g_settings_set_string (priv->settings, + g_settings_set_string (self->settings, "mouse-tracking", "proportional"); } - gtk_widget_set_sensitive (priv->centered_radio, screen_part); - gtk_widget_set_sensitive (priv->push_radio, screen_part); - gtk_widget_set_sensitive (priv->proportional_radio, screen_part); - gtk_widget_set_sensitive (priv->extend_beyond_checkbox, screen_part); + gtk_widget_set_sensitive (self->centered_radio, screen_part); + gtk_widget_set_sensitive (self->push_radio, screen_part); + gtk_widget_set_sensitive (self->proportional_radio, screen_part); + gtk_widget_set_sensitive (self->extend_beyond_checkbox, screen_part); } static void -mouse_tracking_notify_cb (GSettings *settings, - const gchar *key, - ZoomOptionsPrivate *priv) +mouse_tracking_notify_cb (GSettings *settings, + const gchar *key, + ZoomOptions *self) { gchar *tracking; tracking = g_settings_get_string (settings, key); if (g_strcmp0 (tracking, "proportional") == 0) { - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (priv->proportional_radio), TRUE); + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (self->proportional_radio), TRUE); } else if (g_strcmp0 (tracking, "centered") == 0) { - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (priv->centered_radio), TRUE); + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (self->centered_radio), TRUE); } else { - gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (priv->push_radio), TRUE); + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (self->push_radio), TRUE); } } @@ -201,9 +200,8 @@ scale_label (GtkBin *toggle, PangoAttrList *attrs) } static void -screen_position_combo_changed_cb (GtkWidget *combobox, ZoomOptions *options) +screen_position_combo_changed_cb (GtkWidget *combobox, ZoomOptions *self) { - ZoomOptionsPrivate *priv = options->priv; gchar *combo_value = NULL; GtkTreeIter iter; @@ -215,7 +213,7 @@ screen_position_combo_changed_cb (GtkWidget *combobox, ZoomOptions *options) if (g_strcmp0 (combo_value, "")) { - g_settings_set_string (priv->settings, "screen-position", combo_value); + g_settings_set_string (self->settings, "screen-position", combo_value); } g_free (combo_value); @@ -224,9 +222,8 @@ screen_position_combo_changed_cb (GtkWidget *combobox, ZoomOptions *options) static void screen_position_notify_cb (GSettings *settings, const gchar *key, - ZoomOptions *options) + ZoomOptions *self) { - ZoomOptionsPrivate *priv = options->priv; gchar *position; GtkTreeIter iter; GtkTreeModel *model; @@ -235,8 +232,8 @@ screen_position_notify_cb (GSettings *settings, gchar *combo_value; position = g_settings_get_string (settings, key); - position = g_settings_get_string (priv->settings, key); - combobox = GTK_COMBO_BOX (WID ("screen_position_combo_box")); + position = g_settings_get_string (self->settings, key); + combobox = GTK_COMBO_BOX (self->screen_position_combobox); model = gtk_combo_box_get_model (combobox); /* Find the matching screen position value in the combobox model. If nothing @@ -250,9 +247,9 @@ screen_position_notify_cb (GSettings *settings, -1); if (!g_strcmp0 (combo_value, position)) { - g_signal_handlers_block_by_func (combobox, screen_position_combo_changed_cb, priv); + g_signal_handlers_block_by_func (combobox, screen_position_combo_changed_cb, self); gtk_combo_box_set_active_iter (combobox, &iter); - g_signal_handlers_unblock_by_func (combobox, screen_position_combo_changed_cb, priv); + g_signal_handlers_unblock_by_func (combobox, screen_position_combo_changed_cb, self); g_free (combo_value); break; } @@ -295,7 +292,7 @@ xhairs_opacity_notify_cb (GSettings *settings, gchar *key, GtkColorButton *butto #define TO_HEX(x) (int) ((gdouble) x * 255.0) static void -xhairs_color_opacity_changed (GtkColorButton *button, ZoomOptionsPrivate *priv) +xhairs_color_opacity_changed (GtkColorButton *button, ZoomOptions *self) { GdkRGBA rgba; gchar *color_string; @@ -306,13 +303,13 @@ xhairs_color_opacity_changed (GtkColorButton *button, ZoomOptionsPrivate *priv) TO_HEX(rgba.green), TO_HEX(rgba.blue)); - g_settings_set_string (priv->settings, "cross-hairs-color", color_string); + g_settings_set_string (self->settings, "cross-hairs-color", color_string); g_free (color_string); - g_settings_set_double (priv->settings, "cross-hairs-opacity", rgba.alpha); + g_settings_set_double (self->settings, "cross-hairs-opacity", rgba.alpha); } -static void xhairs_length_add_marks (GtkScale *scale) +static void xhairs_length_add_marks (ZoomOptions *self, GtkScale *scale) { GtkAdjustment *scale_model; GdkRectangle rect; @@ -345,7 +342,7 @@ static void xhairs_length_add_marks (GtkScale *scale) static void init_effects_slider (GtkRange *slider, - ZoomOptionsPrivate *priv, + ZoomOptions *self, gchar **keys, GCallback notify_cb) { @@ -353,17 +350,17 @@ init_effects_slider (GtkRange *slider, gchar *signal; g_object_set_data (G_OBJECT (slider), "settings-keys", keys); - effects_slider_set_value (slider, priv->settings); + effects_slider_set_value (slider, self->settings); for (key = keys; *key; key++) { signal = g_strdup_printf ("changed::%s", *key); - g_signal_connect (G_OBJECT (priv->settings), signal, notify_cb, priv); + g_signal_connect (G_OBJECT (self->settings), signal, notify_cb, self); g_free (signal); } g_signal_connect (G_OBJECT (slider), "value-changed", G_CALLBACK (effects_slider_changed), - priv); + self); gtk_scale_add_mark (GTK_SCALE (slider), 0, GTK_POS_BOTTOM, NULL); } @@ -392,29 +389,29 @@ effects_slider_set_value (GtkRange *slider, GSettings *settings) static void brightness_slider_notify_cb (GSettings *settings, const gchar *key, - ZoomOptionsPrivate *priv) + ZoomOptions *self) { - GtkRange *slider = GTK_RANGE (priv->brightness_slider); + GtkRange *slider = GTK_RANGE (self->brightness_slider); - g_signal_handlers_block_by_func (slider, effects_slider_changed, priv); + g_signal_handlers_block_by_func (slider, effects_slider_changed, self); effects_slider_set_value (slider, settings); - g_signal_handlers_unblock_by_func (slider, effects_slider_changed, priv); + g_signal_handlers_unblock_by_func (slider, effects_slider_changed, self); } static void contrast_slider_notify_cb (GSettings *settings, const gchar *key, - ZoomOptionsPrivate *priv) + ZoomOptions *self) { - GtkRange *slider = GTK_RANGE (priv->contrast_slider); + GtkRange *slider = GTK_RANGE (self->contrast_slider); - g_signal_handlers_block_by_func (slider, effects_slider_changed, priv); + g_signal_handlers_block_by_func (slider, effects_slider_changed, self); effects_slider_set_value (slider, settings); - g_signal_handlers_unblock_by_func (slider, effects_slider_changed, priv); + g_signal_handlers_unblock_by_func (slider, effects_slider_changed, self); } static void -effects_slider_changed (GtkRange *slider, ZoomOptionsPrivate *priv) +effects_slider_changed (GtkRange *slider, ZoomOptions *self) { gchar **keys, **key; gdouble value; @@ -424,197 +421,145 @@ effects_slider_changed (GtkRange *slider, ZoomOptionsPrivate *priv) for (key = keys; *key; key++) { - g_settings_set_double (priv->settings, *key, value); + g_settings_set_double (self->settings, *key, value); } } static void -zoom_options_dispose (GObject *object) +zoom_options_finalize (GObject *object) { - g_return_if_fail (object != NULL); - g_return_if_fail (ZOOM_IS_OPTIONS (object)); - ZoomOptionsPrivate *priv = ZOOM_OPTIONS (object)->priv; - - if (priv->builder) - { - g_object_unref (priv->builder); - priv->builder = NULL; - } + ZoomOptions *self = ZOOM_OPTIONS (object); - if (priv->settings) - { - g_object_unref (priv->settings); - priv->settings = NULL; - } - - g_clear_object (&priv->application_settings); - - if (priv->dialog) - { - gtk_widget_destroy (priv->dialog); - priv->dialog = NULL; - } - - G_OBJECT_CLASS (zoom_options_parent_class)->dispose (object); -} + g_clear_object (&self->settings); + g_clear_object (&self->application_settings); -static void -zoom_options_finalize (GObject *object) -{ G_OBJECT_CLASS (zoom_options_parent_class)->finalize (object); } static void zoom_options_class_init (ZoomOptionsClass *klass) { - GObjectClass *object_class = G_OBJECT_CLASS (klass); + GObjectClass *object_class = G_OBJECT_CLASS (klass); + GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass); - object_class->dispose = zoom_options_dispose; object_class->finalize = zoom_options_finalize; - g_type_class_add_private (klass, sizeof (ZoomOptionsPrivate)); + gtk_widget_class_set_template_from_resource (widget_class, "/org/gnome/control-center/universal-access/zoom-options.ui"); + + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, brightness_slider); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, centered_radio); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, contrast_slider); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, crosshair_clip_checkbox); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, crosshair_enabled_switcher); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, crosshair_length_slider); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, crosshair_picker_color_button); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, crosshair_thickness_scale); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, extend_beyond_checkbox); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, follow_mouse_radio); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, grayscale_slider); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, inverse_enabled_switch); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, magnifier_factor_spin); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, proportional_radio); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, push_radio); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, screen_part_radio); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, screen_position_combobox); + gtk_widget_class_bind_template_child (widget_class, ZoomOptions, seeing_zoom_switch); } static void zoom_options_init (ZoomOptions *self) { - ZoomOptionsPrivate *priv; - GtkWidget *w; PangoAttrList *pango_attrs; PangoAttribute *attr; - GError *err = NULL; - - priv = self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, ZOOM_TYPE_OPTIONS, ZoomOptionsPrivate); - priv->builder = gtk_builder_new (); - gtk_builder_add_from_resource (priv->builder, - "/org/gnome/control-center/universal-access/zoom-options.ui", - &err); - if (err) - { - g_warning ("Could not load interface file: %s", err->message); - g_error_free (err); - - g_object_unref (priv->builder); - priv->builder = NULL; - - return; - } + gtk_widget_init_template (GTK_WIDGET (self)); - priv->settings = g_settings_new ("org.gnome.desktop.a11y.magnifier"); - priv->application_settings = g_settings_new ("org.gnome.desktop.a11y.applications"); + self->settings = g_settings_new ("org.gnome.desktop.a11y.magnifier"); + self->application_settings = g_settings_new ("org.gnome.desktop.a11y.applications"); pango_attrs = pango_attr_list_new (); attr = pango_attr_scale_new (FONT_SCALE); pango_attr_list_insert (pango_attrs, attr); /* Zoom switch */ - g_settings_bind (priv->application_settings, "screen-magnifier-enabled", - WID ("seeing_zoom_switch"), "active", + g_settings_bind (self->application_settings, "screen-magnifier-enabled", + self->seeing_zoom_switch, "active", G_SETTINGS_BIND_DEFAULT); /* Magnification factor */ - w = WID ("magFactorSpinButton"); - g_settings_bind (priv->settings, "mag-factor", - gtk_spin_button_get_adjustment (GTK_SPIN_BUTTON (w)), + g_settings_bind (self->settings, "mag-factor", + gtk_spin_button_get_adjustment (GTK_SPIN_BUTTON (self->magnifier_factor_spin)), "value", G_SETTINGS_BIND_DEFAULT); /* Screen position combo */ - w = WID ("screen_position_combo_box"); - screen_position_notify_cb (priv->settings, "screen-position", self); - g_signal_connect (G_OBJECT (priv->settings), "changed::screen-position", + screen_position_notify_cb (self->settings, "screen-position", self); + g_signal_connect (self->settings, "changed::screen-position", G_CALLBACK (screen_position_notify_cb), self); - g_signal_connect (G_OBJECT (w), "changed", + g_signal_connect (self->screen_position_combobox, "changed", G_CALLBACK (screen_position_combo_changed_cb), self); /* Screen part section */ - init_screen_part_section (priv, pango_attrs); + init_screen_part_section (self, pango_attrs); /* Cross hairs: show/hide ... */ - w = WID ("xhairsEnabledSwitch"); - g_settings_bind (priv->settings, "show-cross-hairs", w, "active", + g_settings_bind (self->settings, "show-cross-hairs", + self->crosshair_enabled_switcher, "active", G_SETTINGS_BIND_DEFAULT); /* ... Cross hairs: color and opacity */ - w = WID ("xHairsPicker"); - init_xhairs_color_opacity (GTK_COLOR_BUTTON (w), priv->settings); - g_signal_connect (G_OBJECT (priv->settings), "changed::cross-hairs-color", - G_CALLBACK (xhairs_color_notify_cb), w); - g_signal_connect (G_OBJECT (priv->settings), "changed::cross-hairs-opacity", - G_CALLBACK (xhairs_opacity_notify_cb), w); - g_signal_connect (G_OBJECT (w), "color-set", + init_xhairs_color_opacity (GTK_COLOR_BUTTON (self->crosshair_picker_color_button), self->settings); + g_signal_connect (self->settings, "changed::cross-hairs-color", + G_CALLBACK (xhairs_color_notify_cb), self->crosshair_picker_color_button); + g_signal_connect (self->settings, "changed::cross-hairs-opacity", + G_CALLBACK (xhairs_opacity_notify_cb), self->crosshair_picker_color_button); + g_signal_connect (self->crosshair_picker_color_button, "color-set", G_CALLBACK (xhairs_color_opacity_changed), - priv); + self); /* ... Cross hairs: thickness ... */ - w = WID ("xHairsThicknessSlider"); - g_settings_bind (priv->settings, "cross-hairs-thickness", - gtk_range_get_adjustment (GTK_RANGE (w)), "value", + g_settings_bind (self->settings, "cross-hairs-thickness", + gtk_range_get_adjustment (GTK_RANGE (self->crosshair_thickness_scale)), "value", G_SETTINGS_BIND_DEFAULT); /* ... Cross hairs: clip ... */ - w = WID ("xHairsClipCheckbox"); - scale_label (GTK_BIN(w), pango_attrs); - g_settings_bind (priv->settings, "cross-hairs-clip", w, "active", + scale_label (GTK_BIN (self->crosshair_clip_checkbox), pango_attrs); + g_settings_bind (self->settings, "cross-hairs-clip", + self->crosshair_clip_checkbox, "active", G_SETTINGS_BIND_INVERT_BOOLEAN); /* ... Cross hairs: length ... */ - w = WID ("xHairsLengthSlider"); - xhairs_length_add_marks (GTK_SCALE (w)); - g_settings_bind (priv->settings, "cross-hairs-length", - gtk_range_get_adjustment (GTK_RANGE (w)), "value", + xhairs_length_add_marks (self, GTK_SCALE (self->crosshair_length_slider)); + g_settings_bind (self->settings, "cross-hairs-length", + gtk_range_get_adjustment (GTK_RANGE (self->crosshair_length_slider)), "value", G_SETTINGS_BIND_DEFAULT); /* ... Color effects ... */ - w = WID ("inverseEnabledSwitch"); - g_settings_bind (priv->settings, "invert-lightness", w, "active", + g_settings_bind (self->settings, "invert-lightness", self->inverse_enabled_switch, "active", G_SETTINGS_BIND_DEFAULT); - w = WID ("brightnessSlider"); - priv->brightness_slider = w; - init_effects_slider (GTK_RANGE(w), priv, brightness_keys, + init_effects_slider (GTK_RANGE (self->brightness_slider), + self, + brightness_keys, G_CALLBACK (brightness_slider_notify_cb)); - w = WID ("contrastSlider"); - priv->contrast_slider = w; - init_effects_slider (GTK_RANGE(w), priv, contrast_keys, + init_effects_slider (GTK_RANGE (self->contrast_slider), + self, + contrast_keys, G_CALLBACK (contrast_slider_notify_cb)); - w = WID ("grayscale_slider"); - g_settings_bind (priv->settings, "color-saturation", - gtk_range_get_adjustment (GTK_RANGE (w)), "value", + g_settings_bind (self->settings, "color-saturation", + gtk_range_get_adjustment (GTK_RANGE (self->grayscale_slider)), "value", G_SETTINGS_BIND_DEFAULT); - gtk_scale_add_mark (GTK_SCALE(w), 1.0, GTK_POS_BOTTOM, NULL); - /* ... Window itself ... */ - priv->dialog = WID ("magPrefsDialog"); - - g_signal_connect (G_OBJECT (priv->dialog), "delete-event", - G_CALLBACK (gtk_widget_hide_on_delete), - NULL); + gtk_scale_add_mark (GTK_SCALE(self->grayscale_slider), 1.0, GTK_POS_BOTTOM, NULL); pango_attr_list_unref (pango_attrs); } -/** - * zoom_options_set_parent: - * @self: the #ZoomOptions object - * @parent: the parent #GtkWindow - * - * Activate the dialog associated with this ZoomOptions. - */ -void -zoom_options_set_parent (ZoomOptions *self, - GtkWindow *parent) -{ - g_return_if_fail (ZOOM_IS_OPTIONS (self)); - - gtk_window_set_transient_for (GTK_WINDOW (self->priv->dialog), parent); - gtk_window_set_modal (GTK_WINDOW (self->priv->dialog), TRUE); - gtk_widget_show (self->priv->dialog); -} - ZoomOptions * -zoom_options_new (void) +zoom_options_new (GtkWindow *parent) { - return g_object_new (ZOOM_TYPE_OPTIONS, NULL); + return g_object_new (ZOOM_TYPE_OPTIONS, + "transient-for", parent, + "use-header-bar", TRUE, + NULL); } diff --git a/panels/universal-access/zoom-options.h b/panels/universal-access/zoom-options.h index 0dd54858d..ea82b22bb 100644 --- a/panels/universal-access/zoom-options.h +++ b/panels/universal-access/zoom-options.h @@ -18,58 +18,16 @@ * Author: Joseph Scheuhammer <clown@alum.mit.edu> */ -#ifndef _ZOOM_OPTIONS_H -#define _ZOOM_OPTIONS_H +#pragma once -#include <glib-object.h> #include <gtk/gtk.h> G_BEGIN_DECLS -typedef struct _ZoomOptions ZoomOptions; -typedef struct _ZoomOptionsClass ZoomOptionsClass; -typedef struct _ZoomOptionsPrivate ZoomOptionsPrivate; +#define ZOOM_TYPE_OPTIONS (zoom_options_get_type()) -#define ZOOM_TYPE_OPTIONS (zoom_options_get_type ()) +G_DECLARE_FINAL_TYPE (ZoomOptions, zoom_options, ZOOM, OPTIONS, GtkDialog) -#define ZOOM_OPTIONS(obj) \ - (G_TYPE_CHECK_INSTANCE_CAST ((obj), \ - ZOOM_TYPE_OPTIONS, ZoomOptions)) - -#define ZOOM_OPTIONS_CLASS(klass) \ - (G_TYPE_CHECK_CLASS_CAST ((klass), \ - ZOOM_TYPE_OPTIONS, ZoomOptionsClass)) - -#define ZOOM_IS_OPTIONS(obj) \ - (G_TYPE_CHECK_INSTANCE_TYPE ((obj), \ - ZOOM_TYPE_OPTIONS)) - -#define ZOOM_IS_OPTIONS_CLASS(klass) \ - (G_TYPE_CHECK_CLASS_TYPE ((klass), \ - ZOOM_TYPE_OPTIONS)) - -#define ZOOM_OPTIONS_GET_CLASS(obj) \ - (G_TYPE_INSTANCE_GET_CLASS ((obj), \ - ZOOM_TYPE_OPTIONS, ZoomOptionsClass)) - -struct _ZoomOptionsClass -{ - GObjectClass parent_class; -}; - -struct _ZoomOptions -{ - GObject parent; - - ZoomOptionsPrivate *priv; -}; - -GType zoom_options_get_type (void) G_GNUC_CONST; - -ZoomOptions *zoom_options_new (void); -void zoom_options_set_parent (ZoomOptions *self, - GtkWindow *parent); +ZoomOptions *zoom_options_new (GtkWindow *parent); G_END_DECLS - -#endif /* _ZOOM_OPTIONS_H */ diff --git a/panels/universal-access/zoom-options.ui b/panels/universal-access/zoom-options.ui index fcde06e68..37db88216 100644 --- a/panels/universal-access/zoom-options.ui +++ b/panels/universal-access/zoom-options.ui @@ -71,13 +71,14 @@ </row> </data> </object> - <object class="GtkDialog" id="magPrefsDialog"> + <template class="ZoomOptions" parent="GtkDialog"> + <property name="modal">True</property> <property name="can_focus">False</property> <property name="border_width">5</property> <property name="title" translatable="yes">Zoom Options</property> <property name="resizable">False</property> <property name="type_hint">dialog</property> - <property name="use_header_bar">1</property> + <signal name="delete-event" handler="gtk_widget_hide_on_delete" object="ZoomOptions" swapped="no" /> <child internal-child="vbox"> <object class="GtkBox" id="dialog-vbox1"> <property name="visible">True</property> @@ -186,7 +187,7 @@ <property name="ypad">2</property> <property name="label" translatable="yes">_Magnification:</property> <property name="use_underline">True</property> - <property name="mnemonic_widget">magFactorSpinButton</property> + <property name="mnemonic_widget">magnifier_factor_spin</property> <attributes> <attribute name="weight" value="bold"/> <attribute name="scale" value="1.25"/> @@ -199,7 +200,7 @@ </packing> </child> <child> - <object class="GtkSpinButton" id="magFactorSpinButton"> + <object class="GtkSpinButton" id="magnifier_factor_spin"> <property name="visible">True</property> <property name="can_focus">True</property> <property name="halign">start</property> @@ -247,7 +248,7 @@ <property name="visible">True</property> <property name="can_focus">False</property> <child> - <object class="GtkRadioButton" id="moveableLens"> + <object class="GtkRadioButton" id="follow_mouse_radio"> <property name="label" translatable="yes">_Follow mouse cursor</property> <property name="use_action_appearance">False</property> <property name="visible">True</property> @@ -267,7 +268,7 @@ </packing> </child> <child> - <object class="GtkRadioButton" id="screenPart"> + <object class="GtkRadioButton" id="screen_part_radio"> <property name="label" translatable="yes">_Screen part:</property> <property name="use_action_appearance">False</property> <property name="visible">True</property> @@ -277,7 +278,7 @@ <property name="xalign">0</property> <property name="yalign">0</property> <property name="draw_indicator">True</property> - <property name="group">moveableLens</property> + <property name="group">follow_mouse_radio</property> <property name="use_underline">True</property> </object> <packing> @@ -288,7 +289,7 @@ </packing> </child> <child> - <object class="GtkComboBox" id="screen_position_combo_box"> + <object class="GtkComboBox" id="screen_position_combobox"> <property name="visible">True</property> <property name="can_focus">False</property> <property name="model">screen_position_model</property> @@ -329,7 +330,7 @@ <property name="can_focus">False</property> <property name="orientation">vertical</property> <child> - <object class="GtkCheckButton" id="scrollAtEdges"> + <object class="GtkCheckButton" id="extend_beyond_checkbox"> <property name="label" translatable="yes">Magnifier _extends outside of screen</property> <property name="use_action_appearance">False</property> <property name="visible">True</property> @@ -348,7 +349,7 @@ </packing> </child> <child> - <object class="GtkRadioButton" id="centered"> + <object class="GtkRadioButton" id="centered_radio"> <property name="label" translatable="yes">_Keep magnifier cursor centered</property> <property name="use_action_appearance">False</property> <property name="visible">True</property> @@ -367,7 +368,7 @@ </packing> </child> <child> - <object class="GtkRadioButton" id="push"> + <object class="GtkRadioButton" id="push_radio"> <property name="label" translatable="yes">Magnifier cursor _pushes contents around</property> <property name="use_action_appearance">False</property> <property name="visible">True</property> @@ -376,7 +377,7 @@ <property name="use_action_appearance">False</property> <property name="xalign">0</property> <property name="draw_indicator">True</property> - <property name="group">centered</property> + <property name="group">centered_radio</property> <property name="use_underline">True</property> </object> <packing> @@ -386,7 +387,7 @@ </packing> </child> <child> - <object class="GtkRadioButton" id="proportional"> + <object class="GtkRadioButton" id="proportional_radio"> <property name="label" translatable="yes">Magnifier cursor moves with _contents</property> <property name="use_action_appearance">False</property> <property name="visible">True</property> @@ -395,7 +396,7 @@ <property name="use_action_appearance">False</property> <property name="xalign">0</property> <property name="draw_indicator">True</property> - <property name="group">centered</property> + <property name="group">centered_radio</property> <property name="use_underline">True</property> </object> <packing> @@ -492,7 +493,7 @@ <property name="label" translatable="yes">_Thickness:</property> <property name="justify">center</property> <property name="use_underline">True</property> - <property name="mnemonic_widget">xHairsThicknessSlider</property> + <property name="mnemonic_widget">crosshair_thickness_scale</property> <property name="width_chars">12</property> <attributes> <attribute name="scale" value="1.25"/> @@ -528,7 +529,7 @@ </packing> </child> <child> - <object class="GtkScale" id="xHairsThicknessSlider"> + <object class="GtkScale" id="crosshair_thickness_scale"> <property name="visible">True</property> <property name="can_focus">True</property> <property name="adjustment">xHairsThickness</property> @@ -576,10 +577,10 @@ <property name="label" translatable="yes">_Length:</property> <property name="justify">center</property> <property name="use_underline">True</property> - <property name="mnemonic_widget">xHairsLengthSlider</property> + <property name="mnemonic_widget">crosshair_length_slider</property> <property name="width_chars">12</property> <accessibility> - <relation type="label-for" target="xHairsLengthSlider"/> + <relation type="label-for" target="crosshair_length_slider"/> </accessibility> <attributes> <attribute name="scale" value="1.25"/> @@ -598,7 +599,7 @@ <property name="can_focus">False</property> <property name="spacing">3</property> <child> - <object class="GtkScale" id="xHairsLengthSlider"> + <object class="GtkScale" id="crosshair_length_slider"> <property name="visible">True</property> <property name="can_focus">True</property> <property name="adjustment">xhairsLength</property> @@ -627,7 +628,7 @@ <property name="xalign">0</property> <property name="label" translatable="yes" comments="The color of the accessibility crosshair">Co_lor:</property> <property name="use_underline">True</property> - <property name="mnemonic_widget">xHairsPicker</property> + <property name="mnemonic_widget">crosshair_picker_color_button</property> <attributes> <attribute name="scale" value="1.25"/> </attributes> @@ -645,7 +646,7 @@ <property name="can_focus">False</property> <property name="spacing">3</property> <child> - <object class="GtkColorButton" id="xHairsPicker"> + <object class="GtkColorButton" id="crosshair_picker_color_button"> <property name="use_action_appearance">False</property> <property name="visible">True</property> <property name="can_focus">True</property> @@ -692,7 +693,7 @@ <property name="label" translatable="yes">_Crosshairs:</property> <property name="use_markup">True</property> <property name="use_underline">True</property> - <property name="mnemonic_widget">xhairsEnabledSwitch</property> + <property name="mnemonic_widget">crosshair_enabled_switcher</property> <attributes> <attribute name="weight" value="bold"/> <attribute name="scale" value="1.25"/> @@ -713,7 +714,7 @@ <placeholder/> </child> <child> - <object class="GtkSwitch" id="xhairsEnabledSwitch"> + <object class="GtkSwitch" id="crosshair_enabled_switcher"> <property name="use_action_appearance">False</property> <property name="visible">True</property> <property name="can_focus">True</property> @@ -739,7 +740,7 @@ </packing> </child> <child> - <object class="GtkCheckButton" id="xHairsClipCheckbox"> + <object class="GtkCheckButton" id="crosshair_clip_checkbox"> <property name="label" translatable="yes">_Overlaps mouse cursor</property> <property name="use_action_appearance">False</property> <property name="visible">True</property> @@ -830,9 +831,9 @@ <property name="label" translatable="yes">_White on black:</property> <property name="justify">right</property> <property name="use_underline">True</property> - <property name="mnemonic_widget">inverseEnabledSwitch</property> + <property name="mnemonic_widget">inverse_enabled_switch</property> <accessibility> - <relation type="label-for" target="inverseEnabledSwitch"/> + <relation type="label-for" target="inverse_enabled_switch"/> </accessibility> <attributes> <attribute name="scale" value="1.25"/> @@ -853,10 +854,10 @@ <property name="label" translatable="yes">_Brightness:</property> <property name="justify">right</property> <property name="use_underline">True</property> - <property name="mnemonic_widget">brightnessSlider</property> + <property name="mnemonic_widget">brightness_slider</property> <property name="width_chars">12</property> <accessibility> - <relation type="label-for" target="brightnessSlider"/> + <relation type="label-for" target="brightness_slider"/> </accessibility> <attributes> <attribute name="scale" value="1.25"/> @@ -877,9 +878,9 @@ <property name="label" translatable="yes">_Contrast:</property> <property name="justify">right</property> <property name="use_underline">True</property> - <property name="mnemonic_widget">contrastSlider</property> + <property name="mnemonic_widget">contrast_slider</property> <accessibility> - <relation type="label-for" target="contrastSlider"/> + <relation type="label-for" target="contrast_slider"/> </accessibility> <attributes> <attribute name="scale" value="1.25"/> @@ -987,7 +988,7 @@ <placeholder/> </child> <child> - <object class="GtkSwitch" id="inverseEnabledSwitch"> + <object class="GtkSwitch" id="inverse_enabled_switch"> <property name="use_action_appearance">False</property> <property name="visible">True</property> <property name="can_focus">True</property> @@ -1036,7 +1037,7 @@ </packing> </child> <child> - <object class="GtkScale" id="brightnessSlider"> + <object class="GtkScale" id="brightness_slider"> <property name="visible">True</property> <property name="can_focus">True</property> <property name="adjustment">brightness</property> @@ -1100,7 +1101,7 @@ </packing> </child> <child> - <object class="GtkScale" id="contrastSlider"> + <object class="GtkScale" id="contrast_slider"> <property name="visible">True</property> <property name="can_focus">True</property> <property name="adjustment">contrast</property> @@ -1197,7 +1198,7 @@ </child> </object> </child> - </object> + </template> <object class="GtkAdjustment" id="xHairsThickness"> <property name="lower">1</property> <property name="upper">100</property> |