/* PIKA - Photo and Image Kooker Application * a rebranding of The GNU Image Manipulation Program (created with heckimp) * A derived work which may be trivial. However, any changes may be (C)2023 by Aldercone Studio * * Original copyright, applying to most contents (license remains unchanged): * Copyright (C) 1995 Spencer Kimball and Peter Mattis * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "config.h" #include #include #include "libpikamath/pikamath.h" #include "libpikaconfig/pikaconfig.h" #include "libpikawidgets/pikawidgets.h" #include "actions-types.h" #include "config/pikadisplayoptions.h" #include "config/pikaguiconfig.h" #include "core/pika.h" #include "core/pikacontext.h" #include "core/pikaimage.h" #include "core/pikagrouplayer.h" #include "widgets/pikaactiongroup.h" #include "widgets/pikacolordialog.h" #include "widgets/pikadock.h" #include "widgets/pikadialogfactory.h" #include "widgets/pikatoggleaction.h" #include "widgets/pikauimanager.h" #include "widgets/pikawidgets-utils.h" #include "widgets/pikawindowstrategy.h" #include "display/pikadisplay.h" #include "display/pikadisplay-foreach.h" #include "display/pikadisplayshell.h" #include "display/pikadisplayshell-appearance.h" #include "display/pikadisplayshell-filter-dialog.h" #include "display/pikadisplayshell-rotate.h" #include "display/pikadisplayshell-rotate-dialog.h" #include "display/pikadisplayshell-scale.h" #include "display/pikadisplayshell-scale-dialog.h" #include "display/pikadisplayshell-scroll.h" #include "display/pikadisplayshell-close.h" #include "display/pikaimagewindow.h" #include "dialogs/color-profile-dialog.h" #include "dialogs/dialogs.h" #include "menus/menus.h" #include "actions.h" #include "view-commands.h" #include "pika-intl.h" #define SET_ACTIVE(manager,action_name,active) \ { PikaActionGroup *group = \ pika_ui_manager_get_action_group (manager, "view"); \ pika_action_group_set_action_active (group, action_name, active); } #define IS_ACTIVE_DISPLAY(display) \ ((display) == \ pika_context_get_display (pika_get_user_context ((display)->pika))) /* local function prototypes */ static void view_padding_color_dialog_update (PikaColorDialog *dialog, const PikaRGB *color, PikaColorDialogState state, PikaDisplayShell *shell); /* public functions */ void view_new_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; return_if_no_display (display, data); shell = pika_display_get_shell (display); pika_create_display (display->pika, pika_display_get_image (display), shell->unit, pika_zoom_model_get_factor (shell->zoom), G_OBJECT (pika_widget_get_monitor (GTK_WIDGET (shell)))); } void view_close_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; PikaImage *image; return_if_no_display (display, data); shell = pika_display_get_shell (display); image = pika_display_get_image (display); /* Check for the image so we don't close the last display. */ if (image) pika_display_shell_close (shell, FALSE); } void view_scroll_center_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; return_if_no_display (display, data); pika_display_shell_scroll_center_image (pika_display_get_shell (display), TRUE, TRUE); } void view_zoom_fit_in_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; return_if_no_display (display, data); pika_display_shell_scale_fit_in (pika_display_get_shell (display)); } void view_zoom_fill_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; return_if_no_display (display, data); pika_display_shell_scale_fill (pika_display_get_shell (display)); } void view_zoom_selection_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaImage *image; gint x, y, width, height; return_if_no_display (display, data); return_if_no_image (image, data); pika_item_bounds (PIKA_ITEM (pika_image_get_mask (image)), &x, &y, &width, &height); pika_display_shell_scale_to_rectangle (pika_display_get_shell (display), PIKA_ZOOM_IN, x, y, width, height, FALSE); } void view_zoom_revert_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; return_if_no_display (display, data); pika_display_shell_scale_revert (pika_display_get_shell (display)); } void view_zoom_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; PikaActionSelectType select_type; return_if_no_shell (shell, data); select_type = (PikaActionSelectType) g_variant_get_int32 (value); switch (select_type) { case PIKA_ACTION_SELECT_FIRST: pika_display_shell_scale (shell, PIKA_ZOOM_OUT_MAX, 0.0, PIKA_ZOOM_FOCUS_BEST_GUESS); break; case PIKA_ACTION_SELECT_LAST: pika_display_shell_scale (shell, PIKA_ZOOM_IN_MAX, 0.0, PIKA_ZOOM_FOCUS_BEST_GUESS); break; case PIKA_ACTION_SELECT_PREVIOUS: pika_display_shell_scale (shell, PIKA_ZOOM_OUT, 0.0, PIKA_ZOOM_FOCUS_BEST_GUESS); break; case PIKA_ACTION_SELECT_NEXT: pika_display_shell_scale (shell, PIKA_ZOOM_IN, 0.0, PIKA_ZOOM_FOCUS_BEST_GUESS); break; case PIKA_ACTION_SELECT_SKIP_PREVIOUS: pika_display_shell_scale (shell, PIKA_ZOOM_OUT_MORE, 0.0, PIKA_ZOOM_FOCUS_BEST_GUESS); break; case PIKA_ACTION_SELECT_SKIP_NEXT: pika_display_shell_scale (shell, PIKA_ZOOM_IN_MORE, 0.0, PIKA_ZOOM_FOCUS_BEST_GUESS); break; default: { gdouble scale = pika_zoom_model_get_factor (shell->zoom); scale = action_select_value (select_type, scale, 0.0, 512.0, 1.0, 1.0 / 8.0, 1.0, 16.0, 0.0, FALSE); /* min = 1.0 / 256, max = 256.0 */ /* scale = min * (max / min)**(i/n), i = 0..n */ scale = pow (65536.0, scale / 512.0) / 256.0; pika_display_shell_scale (shell, PIKA_ZOOM_TO, scale, PIKA_ZOOM_FOCUS_BEST_GUESS); break; } } } void view_zoom_explicit_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gint factor; return_if_no_shell (shell, data); factor = g_variant_get_int32 (value); if (factor != 0 /* not Other... */) { if (fabs (factor - pika_zoom_model_get_factor (shell->zoom)) > 0.0001) pika_display_shell_scale (shell, PIKA_ZOOM_TO, (gdouble) factor / 10000, PIKA_ZOOM_FOCUS_RETAIN_CENTERING_ELSE_BEST_GUESS); } } /* not a PikaActionCallback */ void view_zoom_other_cmd_callback (PikaAction *action, gpointer data) { PikaDisplayShell *shell; return_if_no_shell (shell, data); /* check if we are activated by the user or from * view_actions_set_zoom(), also this is really a GtkToggleAction * NOT a PikaToggleAction */ if (pika_toggle_action_get_active (PIKA_TOGGLE_ACTION (action)) && shell->other_scale != pika_zoom_model_get_factor (shell->zoom)) { pika_display_shell_scale_dialog (shell); } } void view_show_all_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; gboolean active; return_if_no_display (display, data); shell = pika_display_get_shell (display); active = g_variant_get_boolean (value); if (active != shell->show_all) { PikaImageWindow *window = pika_display_shell_get_window (shell); pika_display_shell_set_show_all (shell, active); if (window) SET_ACTIVE (menus_get_image_manager_singleton (display->pika), "view-show-all", shell->show_all); if (IS_ACTIVE_DISPLAY (display)) SET_ACTIVE (shell->popup_manager, "view-show-all", shell->show_all); } } void view_dot_for_dot_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; gboolean active; return_if_no_display (display, data); shell = pika_display_get_shell (display); active = g_variant_get_boolean (value); if (active != shell->dot_for_dot) { PikaImageWindow *window = pika_display_shell_get_window (shell); pika_display_shell_scale_set_dot_for_dot (shell, active); if (window) SET_ACTIVE (menus_get_image_manager_singleton (display->pika), "view-dot-for-dot", shell->dot_for_dot); if (IS_ACTIVE_DISPLAY (display)) SET_ACTIVE (shell->popup_manager, "view-dot-for-dot", shell->dot_for_dot); } } void view_flip_horizontally_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; gboolean active; return_if_no_display (display, data); shell = pika_display_get_shell (display); active = g_variant_get_boolean (value); if (active != shell->flip_horizontally) { pika_display_shell_flip (shell, active, shell->flip_vertically); } } void view_flip_vertically_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; gboolean active; return_if_no_display (display, data); shell = pika_display_get_shell (display); active = g_variant_get_boolean (value); if (active != shell->flip_vertically) { pika_display_shell_flip (shell, shell->flip_horizontally, active); } } void view_flip_reset_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; return_if_no_display (display, data); shell = pika_display_get_shell (display); pika_display_shell_flip (shell, FALSE, FALSE); } void view_rotate_absolute_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; PikaActionSelectType select_type; gdouble angle = 0.0; return_if_no_display (display, data); select_type = (PikaActionSelectType) g_variant_get_int32 (value); shell = pika_display_get_shell (display); angle = action_select_value (select_type, 0.0, -180.0, 180.0, 0.0, 1.0, 15.0, 90.0, 0.0, TRUE); pika_display_shell_rotate_to (shell, angle); } void view_rotate_relative_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; PikaActionSelectType select_type; gdouble delta = 0.0; return_if_no_display (display, data); select_type = (PikaActionSelectType) g_variant_get_int32 (value); shell = pika_display_get_shell (display); delta = action_select_value (select_type, 0.0, -180.0, 180.0, 0.0, 1.0, 15.0, 90.0, 0.0, TRUE); pika_display_shell_rotate (shell, delta); } void view_rotate_other_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; return_if_no_display (display, data); shell = pika_display_get_shell (display); pika_display_shell_rotate_dialog (shell); } void view_reset_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; return_if_no_display (display, data); shell = pika_display_get_shell (display); pika_display_shell_rotate_to (shell, 0.0); pika_display_shell_flip (shell, FALSE, FALSE); } void view_scroll_horizontal_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; GtkAdjustment *adj; PikaActionSelectType select_type; gdouble offset; return_if_no_shell (shell, data); select_type = (PikaActionSelectType) g_variant_get_int32 (value); adj = shell->hsbdata; offset = action_select_value (select_type, gtk_adjustment_get_value (adj), gtk_adjustment_get_lower (adj), gtk_adjustment_get_upper (adj) - gtk_adjustment_get_page_size (adj), gtk_adjustment_get_lower (adj), 1, gtk_adjustment_get_step_increment (adj), gtk_adjustment_get_page_increment (adj), 0, FALSE); gtk_adjustment_set_value (shell->hsbdata, offset); } void view_scroll_vertical_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; GtkAdjustment *adj; PikaActionSelectType select_type; gdouble offset; return_if_no_shell (shell, data); select_type = (PikaActionSelectType) g_variant_get_int32 (value); adj = shell->vsbdata; offset = action_select_value (select_type, gtk_adjustment_get_value (adj), gtk_adjustment_get_lower (adj), gtk_adjustment_get_upper (adj) - gtk_adjustment_get_page_size (adj), gtk_adjustment_get_lower (adj), 1, gtk_adjustment_get_step_increment (adj), gtk_adjustment_get_page_increment (adj), 0, FALSE); gtk_adjustment_set_value (shell->vsbdata, offset); } void view_navigation_window_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { Pika *pika; PikaDisplayShell *shell; return_if_no_pika (pika, data); return_if_no_shell (shell, data); pika_window_strategy_show_dockable_dialog (PIKA_WINDOW_STRATEGY (pika_get_window_strategy (pika)), pika, pika_dialog_factory_get_singleton (), pika_widget_get_monitor (GTK_WIDGET (shell)), "pika-navigation-view"); } void view_display_filters_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; GtkWidget *dialog; return_if_no_shell (shell, data); #define FILTERS_DIALOG_KEY "pika-display-filters-dialog" dialog = dialogs_get_dialog (G_OBJECT (shell), FILTERS_DIALOG_KEY); if (! dialog) { dialog = pika_display_shell_filter_dialog_new (shell); dialogs_attach_dialog (G_OBJECT (shell), FILTERS_DIALOG_KEY, dialog); } gtk_window_present (GTK_WINDOW (dialog)); } void view_color_management_reset_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; PikaColorConfig *global_config; PikaColorConfig *shell_config; return_if_no_shell (shell, data); global_config = PIKA_CORE_CONFIG (shell->display->config)->color_management; shell_config = pika_display_shell_get_color_config (shell); pika_config_copy (PIKA_CONFIG (global_config), PIKA_CONFIG (shell_config), 0); shell->color_config_set = FALSE; } void view_color_management_enable_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; PikaColorConfig *color_config; PikaColorManagementMode mode; gboolean active; return_if_no_shell (shell, data); color_config = pika_display_shell_get_color_config (shell); active = g_variant_get_boolean (value); mode = pika_color_config_get_mode (color_config); if (active) { if (mode != PIKA_COLOR_MANAGEMENT_SOFTPROOF) mode = PIKA_COLOR_MANAGEMENT_DISPLAY; } else { mode = PIKA_COLOR_MANAGEMENT_OFF; } if (mode != pika_color_config_get_mode (color_config)) { g_object_set (color_config, "mode", mode, NULL); shell->color_config_set = TRUE; } } void view_color_management_softproof_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; PikaColorConfig *color_config; PikaColorManagementMode mode; gboolean active; return_if_no_shell (shell, data); color_config = pika_display_shell_get_color_config (shell); active = g_variant_get_boolean (value); mode = pika_color_config_get_mode (color_config); if (active) { mode = PIKA_COLOR_MANAGEMENT_SOFTPROOF; } else { if (mode != PIKA_COLOR_MANAGEMENT_OFF) mode = PIKA_COLOR_MANAGEMENT_DISPLAY; } if (mode != pika_color_config_get_mode (color_config)) { g_object_set (color_config, "mode", mode, NULL); shell->color_config_set = TRUE; } } void view_display_intent_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; PikaColorConfig *color_config; PikaColorRenderingIntent intent; return_if_no_shell (shell, data); intent = (PikaColorRenderingIntent) g_variant_get_int32 (value); color_config = pika_display_shell_get_color_config (shell); if (intent != pika_color_config_get_display_intent (color_config)) { g_object_set (color_config, "display-rendering-intent", intent, NULL); shell->color_config_set = TRUE; } } void view_display_bpc_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; PikaColorConfig *color_config; gboolean active; return_if_no_shell (shell, data); color_config = pika_display_shell_get_color_config (shell); active = g_variant_get_boolean (value); if (active != pika_color_config_get_display_bpc (color_config)) { g_object_set (color_config, "display-use-black-point-compensation", active, NULL); shell->color_config_set = TRUE; } } void view_softproof_gamut_check_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; PikaColorConfig *color_config; gboolean active; return_if_no_shell (shell, data); color_config = pika_display_shell_get_color_config (shell); active = g_variant_get_boolean (value); if (active != pika_color_config_get_simulation_gamut_check (color_config)) { g_object_set (color_config, "simulation-gamut-check", active, NULL); shell->color_config_set = TRUE; } } void view_toggle_selection_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_selection (shell)) { pika_display_shell_set_show_selection (shell, active); } } void view_toggle_layer_boundary_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_layer (shell)) { pika_display_shell_set_show_layer (shell, active); } } void view_toggle_canvas_boundary_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_canvas (shell)) { pika_display_shell_set_show_canvas (shell, active); } } void view_toggle_menubar_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_menubar (shell)) { pika_display_shell_set_show_menubar (shell, active); } } void view_toggle_rulers_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_rulers (shell)) { pika_display_shell_set_show_rulers (shell, active); } } void view_toggle_scrollbars_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_scrollbars (shell)) { pika_display_shell_set_show_scrollbars (shell, active); } } void view_toggle_statusbar_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_statusbar (shell)) { pika_display_shell_set_show_statusbar (shell, active); } } void view_toggle_guides_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_guides (shell)) { pika_display_shell_set_show_guides (shell, active); } } void view_toggle_grid_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_grid (shell)) { pika_display_shell_set_show_grid (shell, active); } } void view_toggle_sample_points_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_show_sample_points (shell)) { pika_display_shell_set_show_sample_points (shell, active); } } void view_snap_to_guides_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_snap_to_guides (shell)) { pika_display_shell_set_snap_to_guides (shell, active); } } void view_snap_to_grid_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_snap_to_grid (shell)) { pika_display_shell_set_snap_to_grid (shell, active); } } void view_snap_to_canvas_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_snap_to_canvas (shell)) { pika_display_shell_set_snap_to_canvas (shell, active); } } void view_snap_to_vectors_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_snap_to_vectors (shell)) { pika_display_shell_set_snap_to_vectors (shell, active); } } void view_snap_to_bbox_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_snap_to_bbox (shell)) { pika_display_shell_set_snap_to_bbox (shell, active); } } void view_snap_to_equidistance_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_snap_to_equidistance (shell)) pika_display_shell_set_snap_to_equidistance (shell, active); } void view_padding_color_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaImageWindow *window; PikaDisplayShell *shell; PikaDisplayOptions *options; PikaCanvasPaddingMode padding_mode; gboolean fullscreen; return_if_no_display (display, data); padding_mode = (PikaCanvasPaddingMode) g_variant_get_int32 (value); shell = pika_display_get_shell (display); window = pika_display_shell_get_window (shell); if (window) fullscreen = pika_image_window_get_fullscreen (window); else fullscreen = FALSE; if (fullscreen) options = shell->fullscreen_options; else options = shell->options; #define PADDING_COLOR_DIALOG_KEY "pika-padding-color-dialog" switch (padding_mode) { case PIKA_CANVAS_PADDING_MODE_DEFAULT: case PIKA_CANVAS_PADDING_MODE_LIGHT_CHECK: case PIKA_CANVAS_PADDING_MODE_DARK_CHECK: dialogs_destroy_dialog (G_OBJECT (shell), PADDING_COLOR_DIALOG_KEY); options->padding_mode_set = TRUE; pika_display_shell_set_padding (shell, padding_mode, &options->padding_color); break; case PIKA_CANVAS_PADDING_MODE_CUSTOM: { GtkWidget *dialog; PikaRGB *old_color = g_new (PikaRGB, 1); PikaCanvasPaddingMode old_padding_mode; dialog = dialogs_get_dialog (G_OBJECT (shell), PADDING_COLOR_DIALOG_KEY); if (! dialog) { PikaImage *image = pika_display_get_image (display); PikaDisplayShell *shell = pika_display_get_shell (display); dialog = pika_color_dialog_new (PIKA_VIEWABLE (image), action_data_get_context (data), FALSE, _("Set Canvas Padding Color"), PIKA_ICON_FONT, _("Set Custom Canvas Padding Color"), GTK_WIDGET (shell), NULL, NULL, &options->padding_color, TRUE, FALSE); g_signal_connect (dialog, "update", G_CALLBACK (view_padding_color_dialog_update), shell); dialogs_attach_dialog (G_OBJECT (shell), PADDING_COLOR_DIALOG_KEY, dialog); } *old_color = options->padding_color; old_padding_mode = options->padding_mode; g_object_set_data_full (G_OBJECT (dialog), "old-color", old_color, g_free); g_object_set_data (G_OBJECT (dialog), "old-padding-mode", GINT_TO_POINTER (old_padding_mode)); gtk_window_present (GTK_WINDOW (dialog)); } break; case PIKA_CANVAS_PADDING_MODE_RESET: dialogs_destroy_dialog (G_OBJECT (shell), PADDING_COLOR_DIALOG_KEY); { PikaDisplayOptions *default_options; options->padding_mode_set = FALSE; if (fullscreen) default_options = display->config->default_fullscreen_view; else default_options = display->config->default_view; pika_display_shell_set_padding (shell, default_options->padding_mode, &default_options->padding_color); pika_display_shell_set_padding_in_show_all (shell, default_options->padding_in_show_all); } break; } } void view_padding_color_in_show_all_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; gboolean active; return_if_no_shell (shell, data); active = g_variant_get_boolean (value); if (active != pika_display_shell_get_padding_in_show_all (shell)) { pika_display_shell_set_padding_in_show_all (shell, active); } } void view_shrink_wrap_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplayShell *shell; return_if_no_shell (shell, data); pika_display_shell_scale_shrink_wrap (shell, FALSE); } void view_fullscreen_cmd_callback (PikaAction *action, GVariant *value, gpointer data) { PikaDisplay *display; PikaDisplayShell *shell; PikaImageWindow *window; return_if_no_display (display, data); shell = pika_display_get_shell (display); window = pika_display_shell_get_window (shell); if (window) { gboolean active = g_variant_get_boolean (value); pika_image_window_set_fullscreen (window, active); } } /* private functions */ static void view_padding_color_dialog_update (PikaColorDialog *dialog, const PikaRGB *color, PikaColorDialogState state, PikaDisplayShell *shell) { PikaImageWindow *window; PikaDisplayOptions *options; PikaRGB *old_color; PikaCanvasPaddingMode old_padding_mode; gboolean fullscreen; window = pika_display_shell_get_window (shell); old_color = g_object_get_data (G_OBJECT (dialog), "old-color"); old_padding_mode = GPOINTER_TO_INT (g_object_get_data (G_OBJECT (dialog), "old-padding-mode")); g_return_if_fail (old_color); if (window) fullscreen = pika_image_window_get_fullscreen (window); else fullscreen = FALSE; if (fullscreen) options = shell->fullscreen_options; else options = shell->options; switch (state) { case PIKA_COLOR_DIALOG_OK: options->padding_mode_set = TRUE; pika_display_shell_set_padding (shell, PIKA_CANVAS_PADDING_MODE_CUSTOM, color); gtk_widget_destroy (GTK_WIDGET (dialog)); break; case PIKA_COLOR_DIALOG_CANCEL: pika_display_shell_set_padding (shell, old_padding_mode, old_color); gtk_widget_destroy (GTK_WIDGET (dialog)); break; case PIKA_COLOR_DIALOG_UPDATE: pika_display_shell_set_padding (shell, PIKA_CANVAS_PADDING_MODE_CUSTOM, color); break; default: break; } }