app/Makefile.am removed.

2002-05-07  Michael Natterer  <mitch@gimp.org>

	* app/Makefile.am
	* app/nav_window.[ch]: removed.

	* app/display/Makefile.am
	* app/display/display-types.h
	* app/display/gimpnavigationview.[ch]: new widget partially based
	on the removed nav_window.

	* libgimpproxy/gimpproxytypes.h: regnenerated.

	* app/display/gimpdisplay-foreach.[ch]: removed
	gdisplays_nav_preview_resized(). The new config system will allow
	us to get notified of changes.

	* app/display/gimpdisplayshell.[ch]: added "scaled" and "scrolled"
	signals.

	* app/display/gimpdisplayshell-scale.c
	* app/display/gimpdisplayshell-scroll.c: emit "scaled" and
	"scrolled" appropriately. Removed nav_window stuff.

	* app/display/gimpdisplay.c
	* app/display/gimpdisplayshell-callbacks.c: changed accordingly.

	* app/gui/dialogs-constructors.[ch]
	* app/gui/dialogs.c
	* app/gui/menus.c: made the navigation dialog dockable.

	* app/gui/view-commands.c: changed the nav_dialog callback accordingly.

	* app/gui/preferences-dialog.c
	* app/gimprc.[ch]
	* app/config/gimpguiconfig.[ch]: removed "nav_window_per_display"
	as it's now a dockable and it's state is saved in sessionrc.

	* app/widgets/gimpnavigationpreview.[ch]: added context sensitive
	mouse cursors.

	* app/widgets/gimpimagedock.c: made it capable of holding
	display-related dialogs (like GimpNavigationView) by connecting
	to the context's "display_changed" signal.

	* app/widgets/widgets-types.h: removed inclusion of
	"display/display-types.h".

	* app/widgets/gimpbufferview.c
	* app/widgets/gimpchannellistview.c
	* app/widgets/gimpcolormapeditor.c
	* app/widgets/gimpcomponentlistitem.c
	* app/widgets/gimpdocumentview.c
	* app/widgets/gimpdrawablelistitem.c
	* app/widgets/gimpdrawablelistview.c
	* app/widgets/gimpitemlistitem.c
	* app/widgets/gimpitemlistview.c
	* app/widgets/gimplayerlistitem.c
	* app/widgets/gimplayerlistview.c
	* app/widgets/gimppreview.c
	* app/widgets/gimpvectorslistview.c: warn about inclusion of
	"display/display-types.h".
This commit is contained in:
Michael Natterer 2002-05-07 16:23:14 +00:00 committed by Michael Natterer
parent 8b53758d0b
commit b6c56ff9ac
66 changed files with 1735 additions and 2140 deletions

View File

@ -1,3 +1,65 @@
2002-05-07 Michael Natterer <mitch@gimp.org>
* app/Makefile.am
* app/nav_window.[ch]: removed.
* app/display/Makefile.am
* app/display/display-types.h
* app/display/gimpnavigationview.[ch]: new widget partially based
on the removed nav_window.
* libgimpproxy/gimpproxytypes.h: regnenerated.
* app/display/gimpdisplay-foreach.[ch]: removed
gdisplays_nav_preview_resized(). The new config system will allow
us to get notified of changes.
* app/display/gimpdisplayshell.[ch]: added "scaled" and "scrolled"
signals.
* app/display/gimpdisplayshell-scale.c
* app/display/gimpdisplayshell-scroll.c: emit "scaled" and
"scrolled" appropriately. Removed nav_window stuff.
* app/display/gimpdisplay.c
* app/display/gimpdisplayshell-callbacks.c: changed accordingly.
* app/gui/dialogs-constructors.[ch]
* app/gui/dialogs.c
* app/gui/menus.c: made the navigation dialog dockable.
* app/gui/view-commands.c: changed the nav_dialog callback accordingly.
* app/gui/preferences-dialog.c
* app/gimprc.[ch]
* app/config/gimpguiconfig.[ch]: removed "nav_window_per_display"
as it's now a dockable and it's state is saved in sessionrc.
* app/widgets/gimpnavigationpreview.[ch]: added context sensitive
mouse cursors.
* app/widgets/gimpimagedock.c: made it capable of holding
display-related dialogs (like GimpNavigationView) by connecting
to the context's "display_changed" signal.
* app/widgets/widgets-types.h: removed inclusion of
"display/display-types.h".
* app/widgets/gimpbufferview.c
* app/widgets/gimpchannellistview.c
* app/widgets/gimpcolormapeditor.c
* app/widgets/gimpcomponentlistitem.c
* app/widgets/gimpdocumentview.c
* app/widgets/gimpdrawablelistitem.c
* app/widgets/gimpdrawablelistview.c
* app/widgets/gimpitemlistitem.c
* app/widgets/gimpitemlistview.c
* app/widgets/gimplayerlistitem.c
* app/widgets/gimplayerlistview.c
* app/widgets/gimppreview.c
* app/widgets/gimpvectorslistview.c: warn about inclusion of
"display/display-types.h".
2002-05-07 Sven Neumann <sven@gimp.org>
Moved slovenian translation to the stable branch where they should

View File

@ -24,8 +24,6 @@ bin_PROGRAMS = gimp-1.3
## gui stuff for gui/, display/ or widgets/
##
gui_sources = \
nav_window.c \
nav_window.h \
undo_history.c \
undo_history.h

View File

@ -42,7 +42,6 @@
#include "view-commands.h"
#include "gimprc.h"
#include "nav_window.h"
#define return_if_no_display(gdisp, data) \
@ -136,17 +135,8 @@ view_navigation_window_cmd_callback (GtkWidget *widget,
shell = GIMP_DISPLAY_SHELL (gdisp->shell);
if (gimprc.nav_window_per_display)
{
if (! shell->nav_dialog)
shell->nav_dialog = nav_dialog_create (shell);
nav_dialog_show (shell->nav_dialog);
}
else
{
nav_dialog_show_auto (gdisp->gimage->gimp);
}
gimp_dialog_factory_dialog_raise (global_dock_factory,
"gimp-navigation-view", -1);
}
void

View File

@ -52,7 +52,6 @@ enum
PROP_PERFECT_MOUSE,
PROP_DEFAULT_THRESHOLD,
PROP_NAV_PREVIEW_SIZE,
PROP_NAV_WINDOW_PER_DISPLAY,
PROP_INFO_WINDOW_PER_DISPLAY,
PROP_TRUST_DIRTY_FLAG,
PROP_SAVE_DEVICE_STATUS,
@ -130,9 +129,6 @@ gimp_gui_config_class_init (GimpGuiConfigClass *klass)
GIMP_CONFIG_INSTALL_PROP_ENUM (object_class, PROP_NAV_PREVIEW_SIZE,
"navigation-preview-size",
GIMP_TYPE_PREVIEW_SIZE, GIMP_PREVIEW_SIZE_HUGE);
GIMP_CONFIG_INSTALL_PROP_BOOLEAN (object_class, PROP_NAV_WINDOW_PER_DISPLAY,
"navigation-window-per-display",
FALSE);
GIMP_CONFIG_INSTALL_PROP_BOOLEAN (object_class, PROP_INFO_WINDOW_PER_DISPLAY,
"info-window-per-display",
FALSE);
@ -218,9 +214,6 @@ gimp_gui_config_set_property (GObject *object,
case PROP_NAV_PREVIEW_SIZE:
gui_config->nav_preview_size = g_value_get_enum (value);
break;
case PROP_NAV_WINDOW_PER_DISPLAY:
gui_config->nav_window_per_display = g_value_get_boolean (value);
break;
case PROP_INFO_WINDOW_PER_DISPLAY:
gui_config->info_window_per_display = g_value_get_boolean (value);
break;
@ -299,9 +292,6 @@ gimp_gui_config_get_property (GObject *object,
case PROP_NAV_PREVIEW_SIZE:
g_value_set_enum (value, gui_config->nav_preview_size);
break;
case PROP_NAV_WINDOW_PER_DISPLAY:
g_value_set_boolean (value, gui_config->nav_window_per_display);
break;
case PROP_INFO_WINDOW_PER_DISPLAY:
g_value_set_boolean (value, gui_config->info_window_per_display);
break;

View File

@ -47,7 +47,6 @@ struct _GimpGuiConfig
gboolean perfect_mouse;
gint default_threshold;
GimpPreviewSize nav_preview_size;
gboolean nav_window_per_display;
gboolean info_window_per_display;
gboolean trust_dirty_flag;
gboolean save_device_status;

View File

@ -41,7 +41,6 @@
#include "gimpdisplayshell-handlers.h"
#include "gimprc.h"
#include "nav_window.h"
#include "libgimp/gimpintl.h"

View File

@ -64,6 +64,7 @@
#include "display/gimpdisplay.h"
#include "display/gimpdisplayshell.h"
#include "display/gimpdisplayshell-filter-dialog.h"
#include "display/gimpnavigationview.h"
#include "about-dialog.h"
#include "brushes-commands.h"
@ -126,6 +127,8 @@ static void dialogs_set_path_context_func (GimpDockable *dockable,
GimpContext *context);
static void dialogs_set_indexed_palette_context_func (GimpDockable *dockable,
GimpContext *context);
static void dialogs_set_navigation_context_func (GimpDockable *dockable,
GimpContext *context);
static GtkWidget * dialogs_dockable_new (GtkWidget *widget,
const gchar *name,
@ -142,6 +145,9 @@ static void dialogs_path_view_image_changed (GimpContext *context,
static void dialogs_indexed_palette_image_changed (GimpContext *context,
GimpImage *gimage,
GimpColormapEditor *editor);
static void dialogs_navigation_display_changed (GimpContext *context,
GimpDisplay *gdisp,
GimpNavigationView *view);
/**********************/
@ -900,6 +906,31 @@ dialogs_edit_palette_func (GimpData *data)
}
/* display views */
GtkWidget *
dialogs_navigation_view_new (GimpDialogFactory *factory,
GimpContext *context,
gint preview_size)
{
GimpDisplay *gdisp;
GimpDisplayShell *shell = NULL;
GtkWidget *view;
gdisp = gimp_context_get_display (context);
if (gdisp)
shell = GIMP_DISPLAY_SHELL (gdisp->shell);
view = gimp_navigation_view_new (shell);
return dialogs_dockable_new (view,
_("Display Navigation"), _("Navigation"),
NULL,
dialogs_set_navigation_context_func);
}
/* private functions */
static void
@ -1243,6 +1274,41 @@ dialogs_set_indexed_palette_context_func (GimpDockable *dockable,
}
}
static void
dialogs_set_navigation_context_func (GimpDockable *dockable,
GimpContext *context)
{
GimpNavigationView *view;
view = (GimpNavigationView *) g_object_get_data (G_OBJECT (dockable),
"gimp-dialogs-view");
if (view)
{
if (dockable->context)
{
g_signal_handlers_disconnect_by_func (G_OBJECT (dockable->context),
dialogs_navigation_display_changed,
view);
}
if (context)
{
g_signal_connect (G_OBJECT (context), "display_changed",
G_CALLBACK (dialogs_navigation_display_changed),
view);
dialogs_navigation_display_changed (context,
gimp_context_get_display (context),
view);
}
else
{
dialogs_navigation_display_changed (NULL, NULL, view);
}
}
}
static GtkWidget *
dialogs_dockable_new (GtkWidget *widget,
const gchar *name,
@ -1287,3 +1353,16 @@ dialogs_indexed_palette_image_changed (GimpContext *context,
{
gimp_colormap_editor_set_image (editor, gimage);
}
static void
dialogs_navigation_display_changed (GimpContext *context,
GimpDisplay *gdisp,
GimpNavigationView *view)
{
GimpDisplayShell *shell = NULL;
if (gdisp)
shell = GIMP_DISPLAY_SHELL (gdisp->shell);
gimp_navigation_view_set_shell (view, shell);
}

View File

@ -143,5 +143,9 @@ GtkWidget * dialogs_palette_editor_get (GimpDialogFactory *factory,
gint preview_size);
void dialogs_edit_palette_func (GimpData *data);
GtkWidget * dialogs_navigation_view_new (GimpDialogFactory *factory,
GimpContext *context,
gint preview_size);
#endif /* __DIALOGS_CONSTRUCTORS_H__ */

View File

@ -79,7 +79,9 @@ static const GimpDialogFactoryEntry dock_entries[] =
{ "gimp-brush-editor", dialogs_brush_editor_get, 0, TRUE, FALSE, FALSE, TRUE },
{ "gimp-gradient-editor", dialogs_gradient_editor_get, 0, TRUE, FALSE, FALSE, TRUE },
{ "gimp-palette-editor", dialogs_palette_editor_get, 0, TRUE, FALSE, FALSE, TRUE }
{ "gimp-palette-editor", dialogs_palette_editor_get, 0, TRUE, FALSE, FALSE, TRUE },
{ "gimp-navigation-view", dialogs_navigation_view_new, 0, FALSE, FALSE, FALSE, TRUE }
};

View File

@ -172,7 +172,6 @@ static guint old_max_new_image_size;
static GimpThumbnailSize old_thumbnail_size;
static gboolean old_trust_dirty_flag;
static gboolean old_use_help;
static gboolean old_nav_window_per_display;
static gboolean old_info_window_follows_mouse;
static gint old_help_browser;
static gint old_cursor_mode;
@ -185,7 +184,6 @@ static gint edit_min_colors;
static gboolean edit_install_cmap;
static gboolean edit_cycled_marching_ants;
static gint edit_last_opened_size;
static gboolean edit_nav_window_per_display;
static gboolean edit_info_window_follows_mouse;
static gboolean edit_disable_tearoff_menus;
static gchar * edit_temp_path = NULL;
@ -368,7 +366,6 @@ prefs_check_settings (Gimp *gimp)
edit_install_cmap != old_install_cmap ||
edit_cycled_marching_ants != old_cycled_marching_ants ||
edit_last_opened_size != old_last_opened_size ||
edit_nav_window_per_display != old_nav_window_per_display ||
edit_info_window_follows_mouse != old_info_window_follows_mouse ||
edit_disable_tearoff_menus != old_disable_tearoff_menus ||
@ -506,7 +503,6 @@ prefs_save_callback (GtkWidget *widget,
gboolean save_install_cmap;
gboolean save_cycled_marching_ants;
gint save_last_opened_size;
gboolean save_nav_window_per_display;
gboolean save_info_window_follows_mouse;
gchar *save_temp_path;
gchar *save_swap_path;
@ -557,7 +553,6 @@ prefs_save_callback (GtkWidget *widget,
save_install_cmap = gimprc.install_cmap;
save_cycled_marching_ants = gimprc.cycled_marching_ants;
save_last_opened_size = gimprc.last_opened_size;
save_nav_window_per_display = gimprc.nav_window_per_display;
save_info_window_follows_mouse = gimprc.info_window_follows_mouse;
save_temp_path = base_config->temp_path;
@ -779,12 +774,6 @@ prefs_save_callback (GtkWidget *widget,
gimprc.last_opened_size = edit_last_opened_size;
update = g_list_append (update, "last-opened-size");
}
if (edit_nav_window_per_display != old_nav_window_per_display)
{
gimprc.nav_window_per_display = edit_nav_window_per_display;
update = g_list_append (update, "nav-window-per-display");
remove = g_list_append (remove, "nav-window-follows-auto");
}
if (edit_info_window_follows_mouse != old_info_window_follows_mouse)
{
gimprc.info_window_follows_mouse = edit_info_window_follows_mouse;
@ -869,7 +858,6 @@ prefs_save_callback (GtkWidget *widget,
gimprc.install_cmap = save_install_cmap;
gimprc.cycled_marching_ants = save_cycled_marching_ants;
gimprc.last_opened_size = save_last_opened_size;
gimprc.nav_window_per_display = save_nav_window_per_display;
gimprc.info_window_follows_mouse = save_info_window_follows_mouse;
base_config->temp_path = save_temp_path;
@ -952,7 +940,9 @@ prefs_cancel_callback (GtkWidget *widget,
if (gimprc.nav_preview_size != old_nav_preview_size)
{
gimprc.nav_preview_size = old_nav_preview_size;
#if 0
gdisplays_nav_preview_resized ();
#endif
}
if ((gimprc.transparency_type != old_transparency_type) ||
(gimprc.transparency_size != old_transparency_size))
@ -980,7 +970,6 @@ prefs_cancel_callback (GtkWidget *widget,
edit_install_cmap = old_install_cmap;
edit_cycled_marching_ants = old_cycled_marching_ants;
edit_last_opened_size = old_last_opened_size;
edit_nav_window_per_display = old_nav_window_per_display;
edit_info_window_follows_mouse = old_info_window_follows_mouse;
edit_disable_tearoff_menus = old_disable_tearoff_menus;
@ -1041,7 +1030,6 @@ prefs_toggle_callback (GtkWidget *widget,
data == &edit_stingy_memory_use ||
data == &edit_install_cmap ||
data == &edit_cycled_marching_ants ||
data == &edit_nav_window_per_display ||
data == &edit_info_window_follows_mouse ||
data == &edit_disable_tearoff_menus)
{
@ -1105,7 +1093,9 @@ prefs_nav_preview_size_callback (GtkWidget *widget,
{
gimp_menu_item_update (widget, data);
#if 0
gdisplays_nav_preview_resized ();
#endif
}
static void
@ -1643,7 +1633,6 @@ preferences_dialog_create (Gimp *gimp)
edit_install_cmap = gimprc.install_cmap;
edit_cycled_marching_ants = gimprc.cycled_marching_ants;
edit_last_opened_size = gimprc.last_opened_size;
edit_nav_window_per_display = gimprc.nav_window_per_display;
edit_info_window_follows_mouse = gimprc.info_window_follows_mouse;
edit_disable_tearoff_menus = gimprc.disable_tearoff_menus;
@ -1718,7 +1707,6 @@ preferences_dialog_create (Gimp *gimp)
old_install_cmap = edit_install_cmap;
old_cycled_marching_ants = edit_cycled_marching_ants;
old_last_opened_size = edit_last_opened_size;
old_nav_window_per_display = edit_nav_window_per_display;
old_info_window_follows_mouse = edit_info_window_follows_mouse;
old_disable_tearoff_menus = edit_disable_tearoff_menus;
@ -2102,8 +2090,6 @@ preferences_dialog_create (Gimp *gimp)
/* Dialog Bahaviour */
vbox2 = prefs_frame_new (_("Dialog Behavior"), GTK_CONTAINER (vbox));
prefs_check_button_new (_("Navigation Window per Display"),
&edit_nav_window_per_display, GTK_BOX (vbox2));
prefs_check_button_new (_("Info Window Follows Mouse"),
&edit_info_window_follows_mouse, GTK_BOX (vbox2));

View File

@ -49,6 +49,8 @@ libappdisplay_a_sources = @STRIP_BEGIN@ \
gimpdisplayshell-scroll.h \
gimpdisplayshell-selection.c \
gimpdisplayshell-selection.h \
gimpnavigationview.c \
gimpnavigationview.h \
gimpprogress.c \
gimpprogress.h \
gimpstatusbar.c \

View File

@ -26,13 +26,14 @@
#include "display/display-enums.h"
typedef struct _GimpDisplay GimpDisplay; /*< proxy-resume >*/
typedef struct _GimpDisplayShell GimpDisplayShell;
typedef struct _GimpDisplay GimpDisplay; /*< proxy-resume >*/
typedef struct _GimpDisplayShell GimpDisplayShell;
typedef struct _GimpStatusbar GimpStatusbar; /*< proxy-skip >*/
typedef struct _GimpNavigationView GimpNavigationView; /*< proxy-skip >*/
typedef struct _GimpStatusbar GimpStatusbar;
typedef struct _NavigationDialog NavigationDialog;
typedef struct _Selection Selection;
typedef struct _NavigationDialog NavigationDialog;
typedef struct _Selection Selection;
#endif /* __DISPLAY_TYPES_H__ */

View File

@ -28,8 +28,6 @@
#include "gimpdisplay-foreach.h"
#include "gimpdisplayshell.h"
#include "nav_window.h"
void
gdisplays_foreach (GFunc func,
@ -52,27 +50,6 @@ gdisplays_expose_full (void)
}
}
void
gdisplays_nav_preview_resized (void)
{
GimpDisplayShell *shell;
GSList *list;
for (list = display_list; list; list = g_slist_next (list))
{
shell = GIMP_DISPLAY_SHELL (GIMP_DISPLAY (list->data)->shell);
if (shell->nav_dialog)
nav_dialog_preview_resized (shell->nav_dialog);
if (shell->nav_popup)
{
nav_dialog_free (NULL, shell->nav_popup);
shell->nav_popup = NULL;
}
}
}
gboolean
gdisplays_dirty (void)
{

View File

@ -31,7 +31,6 @@ gboolean gdisplays_dirty (void);
void gdisplays_delete (void);
void gdisplays_flush (void);
void gdisplays_finish_draw (void);
void gdisplays_nav_preview_resized (void);
void gdisplays_set_busy (void);
void gdisplays_unset_busy (void);

View File

@ -41,7 +41,6 @@
#include "gimpdisplayshell-handlers.h"
#include "gimprc.h"
#include "nav_window.h"
#include "libgimp/gimpintl.h"

View File

@ -57,10 +57,10 @@
#include "gimpdisplayshell-scale.h"
#include "gimpdisplayshell-scroll.h"
#include "gimpdisplayshell-selection.h"
#include "gimpnavigationview.h"
#include "gimpstatusbar.h"
#include "gimprc.h"
#include "nav_window.h"
#include "libgimp/gimpintl.h"
@ -1241,7 +1241,7 @@ gimp_display_shell_nav_button_press (GtkWidget *widget,
{
if ((bevent->type == GDK_BUTTON_PRESS) && (bevent->button == 1))
{
nav_dialog_create_popup (shell, widget, bevent->x, bevent->y);
gimp_navigation_view_popup (shell, widget, bevent->x, bevent->y);
}
return TRUE;

View File

@ -41,6 +41,7 @@
#include "core/gimpimage-new.h"
#include "core/gimplayer.h"
#include "core/gimplayermask.h"
#include "core/gimpmarshal.h"
#include "core/gimppattern.h"
#include "file/file-utils.h"
@ -70,7 +71,6 @@
#include "gimpstatusbar.h"
#include "gimprc.h"
#include "nav_window.h"
#include "undo.h"
#include "libgimp/gimpintl.h"
@ -78,6 +78,13 @@
#define MAX_TITLE_BUF 256
enum
{
SCALED,
SCROLLED,
LAST_SIGNAL
};
/* local function prototypes */
@ -114,6 +121,8 @@ static void gimp_display_shell_close_warning_callback (GtkWidget *widget
gpointer data);
static guint display_shell_signals[LAST_SIGNAL] = { 0 };
static GtkWindowClass *parent_class = NULL;
@ -167,6 +176,24 @@ gimp_display_shell_class_init (GimpDisplayShellClass *klass)
parent_class = g_type_class_peek_parent (klass);
display_shell_signals[SCALED] =
g_signal_new ("scaled",
G_TYPE_FROM_CLASS (klass),
G_SIGNAL_RUN_FIRST,
G_STRUCT_OFFSET (GimpDisplayShellClass, scaled),
NULL, NULL,
gimp_marshal_VOID__VOID,
G_TYPE_NONE, 0);
display_shell_signals[SCROLLED] =
g_signal_new ("scrolled",
G_TYPE_FROM_CLASS (klass),
G_SIGNAL_RUN_FIRST,
G_STRUCT_OFFSET (GimpDisplayShellClass, scrolled),
NULL, NULL,
gimp_marshal_VOID__VOID,
G_TYPE_NONE, 0);
object_class->destroy = gimp_display_shell_destroy;
widget_class->delete_event = gimp_display_shell_delete_event;
@ -234,7 +261,6 @@ gimp_display_shell_init (GimpDisplayShell *shell)
shell->warning_dialog = NULL;
shell->info_dialog = NULL;
shell->nav_dialog = NULL;
shell->nav_popup = NULL;
shell->filters = NULL;
@ -336,15 +362,9 @@ gimp_display_shell_destroy (GtkObject *object)
shell->info_dialog = NULL;
}
/* free the nav_dialog unconditionally because nav_dialog_free(shell,NULL)
* acts as notification for the global nav dialog
*/
nav_dialog_free (shell, shell->nav_dialog);
shell->nav_dialog = NULL;
if (shell->nav_popup)
{
nav_dialog_free (shell, shell->nav_popup);
gtk_widget_destroy (shell->nav_popup);
shell->nav_popup = NULL;
}
@ -784,6 +804,22 @@ gimp_display_shell_reconnect (GimpDisplayShell *shell)
gimp_display_shell_shrink_wrap (shell);
}
void
gimp_display_shell_scaled (GimpDisplayShell *shell)
{
g_return_if_fail (GIMP_IS_DISPLAY_SHELL (shell));
g_signal_emit (G_OBJECT (shell), display_shell_signals[SCALED], 0);
}
void
gimp_display_shell_scrolled (GimpDisplayShell *shell)
{
g_return_if_fail (GIMP_IS_DISPLAY_SHELL (shell));
g_signal_emit (G_OBJECT (shell), display_shell_signals[SCROLLED], 0);
}
void
gimp_display_shell_transform_coords (GimpDisplayShell *shell,
GimpCoords *image_coords,

View File

@ -99,8 +99,7 @@ struct _GimpDisplayShell
GtkWidget *warning_dialog; /* close warning dialog */
InfoDialog *info_dialog; /* image information dialog */
NavigationDialog *nav_dialog; /* image navigation dialog */
NavigationDialog *nav_popup; /* navigation popup */
GtkWidget *nav_popup; /* navigation popup */
GList *filters; /* color display conversion stuff */
GtkWidget *filters_dialog; /* color display filter dialog */
@ -109,6 +108,9 @@ struct _GimpDisplayShell
struct _GimpDisplayShellClass
{
GtkWindowClass parent_class;
void (* scaled) (GimpDisplayShell *shell);
void (* scrolled) (GimpDisplayShell *shell);
};
@ -121,6 +123,9 @@ void gimp_display_shell_close (GimpDisplayShell *shell,
void gimp_display_shell_reconnect (GimpDisplayShell *shell);
void gimp_display_shell_scaled (GimpDisplayShell *shell);
void gimp_display_shell_scrolled (GimpDisplayShell *shell);
void gimp_display_shell_transform_coords (GimpDisplayShell *shell,
GimpCoords *image_coords,
GimpCoords *display_coords);

View File

@ -40,7 +40,6 @@
#include "gimpstatusbar.h"
#include "gimprc.h"
#include "nav_window.h"
/* local function prototypes */
@ -150,10 +149,7 @@ gimp_display_shell_scale_setup (GimpDisplayShell *shell)
gtk_widget_queue_draw (GTK_WIDGET (hruler));
gtk_widget_queue_draw (GTK_WIDGET (vruler));
nav_dialog_update (shell->nav_dialog);
if (shell->nav_popup)
nav_dialog_update (shell->nav_popup);
gimp_display_shell_scaled (shell);
#if 0
g_print ("offset_x: %d\n"

View File

@ -37,7 +37,6 @@
#include "gimpdisplayshell-scroll.h"
#include "gimprc.h"
#include "nav_window.h"
gboolean
@ -127,10 +126,7 @@ gimp_display_shell_scroll (GimpDisplayShell *shell,
gimp_display_flush (shell->gdisp);
}
nav_dialog_update (shell->nav_dialog);
if (shell->nav_popup)
nav_dialog_update (shell->nav_popup);
gimp_display_shell_scrolled (shell);
/* Make sure graphics expose events are processed before scrolling
* again

View File

@ -41,6 +41,7 @@
#include "core/gimpimage-new.h"
#include "core/gimplayer.h"
#include "core/gimplayermask.h"
#include "core/gimpmarshal.h"
#include "core/gimppattern.h"
#include "file/file-utils.h"
@ -70,7 +71,6 @@
#include "gimpstatusbar.h"
#include "gimprc.h"
#include "nav_window.h"
#include "undo.h"
#include "libgimp/gimpintl.h"
@ -78,6 +78,13 @@
#define MAX_TITLE_BUF 256
enum
{
SCALED,
SCROLLED,
LAST_SIGNAL
};
/* local function prototypes */
@ -114,6 +121,8 @@ static void gimp_display_shell_close_warning_callback (GtkWidget *widget
gpointer data);
static guint display_shell_signals[LAST_SIGNAL] = { 0 };
static GtkWindowClass *parent_class = NULL;
@ -167,6 +176,24 @@ gimp_display_shell_class_init (GimpDisplayShellClass *klass)
parent_class = g_type_class_peek_parent (klass);
display_shell_signals[SCALED] =
g_signal_new ("scaled",
G_TYPE_FROM_CLASS (klass),
G_SIGNAL_RUN_FIRST,
G_STRUCT_OFFSET (GimpDisplayShellClass, scaled),
NULL, NULL,
gimp_marshal_VOID__VOID,
G_TYPE_NONE, 0);
display_shell_signals[SCROLLED] =
g_signal_new ("scrolled",
G_TYPE_FROM_CLASS (klass),
G_SIGNAL_RUN_FIRST,
G_STRUCT_OFFSET (GimpDisplayShellClass, scrolled),
NULL, NULL,
gimp_marshal_VOID__VOID,
G_TYPE_NONE, 0);
object_class->destroy = gimp_display_shell_destroy;
widget_class->delete_event = gimp_display_shell_delete_event;
@ -234,7 +261,6 @@ gimp_display_shell_init (GimpDisplayShell *shell)
shell->warning_dialog = NULL;
shell->info_dialog = NULL;
shell->nav_dialog = NULL;
shell->nav_popup = NULL;
shell->filters = NULL;
@ -336,15 +362,9 @@ gimp_display_shell_destroy (GtkObject *object)
shell->info_dialog = NULL;
}
/* free the nav_dialog unconditionally because nav_dialog_free(shell,NULL)
* acts as notification for the global nav dialog
*/
nav_dialog_free (shell, shell->nav_dialog);
shell->nav_dialog = NULL;
if (shell->nav_popup)
{
nav_dialog_free (shell, shell->nav_popup);
gtk_widget_destroy (shell->nav_popup);
shell->nav_popup = NULL;
}
@ -784,6 +804,22 @@ gimp_display_shell_reconnect (GimpDisplayShell *shell)
gimp_display_shell_shrink_wrap (shell);
}
void
gimp_display_shell_scaled (GimpDisplayShell *shell)
{
g_return_if_fail (GIMP_IS_DISPLAY_SHELL (shell));
g_signal_emit (G_OBJECT (shell), display_shell_signals[SCALED], 0);
}
void
gimp_display_shell_scrolled (GimpDisplayShell *shell)
{
g_return_if_fail (GIMP_IS_DISPLAY_SHELL (shell));
g_signal_emit (G_OBJECT (shell), display_shell_signals[SCROLLED], 0);
}
void
gimp_display_shell_transform_coords (GimpDisplayShell *shell,
GimpCoords *image_coords,

View File

@ -99,8 +99,7 @@ struct _GimpDisplayShell
GtkWidget *warning_dialog; /* close warning dialog */
InfoDialog *info_dialog; /* image information dialog */
NavigationDialog *nav_dialog; /* image navigation dialog */
NavigationDialog *nav_popup; /* navigation popup */
GtkWidget *nav_popup; /* navigation popup */
GList *filters; /* color display conversion stuff */
GtkWidget *filters_dialog; /* color display filter dialog */
@ -109,6 +108,9 @@ struct _GimpDisplayShell
struct _GimpDisplayShellClass
{
GtkWindowClass parent_class;
void (* scaled) (GimpDisplayShell *shell);
void (* scrolled) (GimpDisplayShell *shell);
};
@ -121,6 +123,9 @@ void gimp_display_shell_close (GimpDisplayShell *shell,
void gimp_display_shell_reconnect (GimpDisplayShell *shell);
void gimp_display_shell_scaled (GimpDisplayShell *shell);
void gimp_display_shell_scrolled (GimpDisplayShell *shell);
void gimp_display_shell_transform_coords (GimpDisplayShell *shell,
GimpCoords *image_coords,
GimpCoords *display_coords);

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,77 @@
/* The GIMP -- an image manipulation program
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
*
* gimpnavigationview.h
* Copyright (C) 2002 Michael Natterer <mitch@gimp.org>
*
* partly based on app/nav_window
* Copyright (C) 1999 Andy Thomas <alt@gimp.org>
*
* 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 2 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, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef __GIMP_NAVIGATION_VIEW_H__
#define __GIMP_NAVIGATION_VIEW_H__
#include "widgets/gimpeditor.h"
#define GIMP_TYPE_NAVIGATION_VIEW (gimp_navigation_view_get_type ())
#define GIMP_NAVIGATION_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GIMP_TYPE_NAVIGATION_VIEW, GimpNavigationView))
#define GIMP_NAVIGATION_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GIMP_TYPE_NAVIGATION_VIEW, GimpNavigationViewClass))
#define GIMP_IS_NAVIGATION_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GIMP_TYPE_NAVIGATION_VIEW))
#define GIMP_IS_NAVIGATION_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GIMP_TYPE_NAVIGATION_VIEW))
#define GIMP_NAVIGATION_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GIMP_TYPE_NAVIGATION_VIEW, GimpNavigationViewClass))
typedef struct _GimpNavigationViewClass GimpNavigationViewClass;
struct _GimpNavigationView
{
GimpEditor parent_instance;
GimpDisplayShell *shell;
GtkWidget *preview;
GtkWidget *zoom_label;
GtkAdjustment *zoom_adjustment;
GtkWidget *zoom_out_button;
GtkWidget *zoom_in_button;
GtkWidget *zoom_100_button;
GtkWidget *zoom_fit_button;
GtkWidget *shrink_wrap_button;
};
struct _GimpNavigationViewClass
{
GimpEditorClass parent_class;
};
GType gimp_navigation_view_get_type (void) G_GNUC_CONST;
GtkWidget * gimp_navigation_view_new (GimpDisplayShell *shell);
void gimp_navigation_view_set_shell (GimpNavigationView *view,
GimpDisplayShell *shell);
void gimp_navigation_view_popup (GimpDisplayShell *shell,
GtkWidget *widget,
gint click_x,
gint click_y);
#endif /* __GIMP_NAVIGATION_VIEW_H__ */

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,77 @@
/* The GIMP -- an image manipulation program
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
*
* gimpnavigationview.h
* Copyright (C) 2002 Michael Natterer <mitch@gimp.org>
*
* partly based on app/nav_window
* Copyright (C) 1999 Andy Thomas <alt@gimp.org>
*
* 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 2 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, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef __GIMP_NAVIGATION_VIEW_H__
#define __GIMP_NAVIGATION_VIEW_H__
#include "widgets/gimpeditor.h"
#define GIMP_TYPE_NAVIGATION_VIEW (gimp_navigation_view_get_type ())
#define GIMP_NAVIGATION_VIEW(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GIMP_TYPE_NAVIGATION_VIEW, GimpNavigationView))
#define GIMP_NAVIGATION_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GIMP_TYPE_NAVIGATION_VIEW, GimpNavigationViewClass))
#define GIMP_IS_NAVIGATION_VIEW(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GIMP_TYPE_NAVIGATION_VIEW))
#define GIMP_IS_NAVIGATION_VIEW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GIMP_TYPE_NAVIGATION_VIEW))
#define GIMP_NAVIGATION_VIEW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GIMP_TYPE_NAVIGATION_VIEW, GimpNavigationViewClass))
typedef struct _GimpNavigationViewClass GimpNavigationViewClass;
struct _GimpNavigationView
{
GimpEditor parent_instance;
GimpDisplayShell *shell;
GtkWidget *preview;
GtkWidget *zoom_label;
GtkAdjustment *zoom_adjustment;
GtkWidget *zoom_out_button;
GtkWidget *zoom_in_button;
GtkWidget *zoom_100_button;
GtkWidget *zoom_fit_button;
GtkWidget *shrink_wrap_button;
};
struct _GimpNavigationViewClass
{
GimpEditorClass parent_class;
};
GType gimp_navigation_view_get_type (void) G_GNUC_CONST;
GtkWidget * gimp_navigation_view_new (GimpDisplayShell *shell);
void gimp_navigation_view_set_shell (GimpNavigationView *view,
GimpDisplayShell *shell);
void gimp_navigation_view_popup (GimpDisplayShell *shell,
GtkWidget *widget,
gint click_x,
gint click_y);
#endif /* __GIMP_NAVIGATION_VIEW_H__ */

View File

@ -212,7 +212,6 @@ GimpRc gimprc =
/* max_new_image_size */ 33554432, /* 32 MB */
/* trust_dirty_flag */ FALSE,
/* use_help */ TRUE,
/* nav_window_per_display */ FALSE,
/* info_window_follows_mouse */ TRUE,
/* help_browser */ GIMP_HELP_BROWSER_GIMP,
/* cursor_mode */ GIMP_CURSOR_MODE_TOOL_ICON,
@ -272,8 +271,6 @@ static ParseFunc funcs[] =
{ "dont-trust-dirty-flag", TT_BOOLEAN, NULL, &gimprc.trust_dirty_flag },
{ "use-help", TT_BOOLEAN, &gimprc.use_help, NULL },
{ "dont-use-help", TT_BOOLEAN, NULL, &gimprc.use_help },
{ "nav-window-per-display", TT_BOOLEAN, &gimprc.nav_window_per_display, NULL },
{ "nav-window-follows-auto", TT_BOOLEAN, NULL, &gimprc.nav_window_per_display },
{ "info-window-follows-mouse", TT_BOOLEAN, &gimprc.info_window_follows_mouse, NULL },
{ "info-window-per-display", TT_BOOLEAN, NULL, &gimprc.info_window_follows_mouse },
{ "help-browser", TT_XHELPBROWSER, &gimprc.help_browser, NULL },

View File

@ -59,7 +59,6 @@ struct _GimpRc
guint max_new_image_size;
gboolean trust_dirty_flag;
gboolean use_help;
gboolean nav_window_per_display;
gboolean info_window_follows_mouse;
gint help_browser;
gint cursor_mode;

View File

@ -64,6 +64,7 @@
#include "display/gimpdisplay.h"
#include "display/gimpdisplayshell.h"
#include "display/gimpdisplayshell-filter-dialog.h"
#include "display/gimpnavigationview.h"
#include "about-dialog.h"
#include "brushes-commands.h"
@ -126,6 +127,8 @@ static void dialogs_set_path_context_func (GimpDockable *dockable,
GimpContext *context);
static void dialogs_set_indexed_palette_context_func (GimpDockable *dockable,
GimpContext *context);
static void dialogs_set_navigation_context_func (GimpDockable *dockable,
GimpContext *context);
static GtkWidget * dialogs_dockable_new (GtkWidget *widget,
const gchar *name,
@ -142,6 +145,9 @@ static void dialogs_path_view_image_changed (GimpContext *context,
static void dialogs_indexed_palette_image_changed (GimpContext *context,
GimpImage *gimage,
GimpColormapEditor *editor);
static void dialogs_navigation_display_changed (GimpContext *context,
GimpDisplay *gdisp,
GimpNavigationView *view);
/**********************/
@ -900,6 +906,31 @@ dialogs_edit_palette_func (GimpData *data)
}
/* display views */
GtkWidget *
dialogs_navigation_view_new (GimpDialogFactory *factory,
GimpContext *context,
gint preview_size)
{
GimpDisplay *gdisp;
GimpDisplayShell *shell = NULL;
GtkWidget *view;
gdisp = gimp_context_get_display (context);
if (gdisp)
shell = GIMP_DISPLAY_SHELL (gdisp->shell);
view = gimp_navigation_view_new (shell);
return dialogs_dockable_new (view,
_("Display Navigation"), _("Navigation"),
NULL,
dialogs_set_navigation_context_func);
}
/* private functions */
static void
@ -1243,6 +1274,41 @@ dialogs_set_indexed_palette_context_func (GimpDockable *dockable,
}
}
static void
dialogs_set_navigation_context_func (GimpDockable *dockable,
GimpContext *context)
{
GimpNavigationView *view;
view = (GimpNavigationView *) g_object_get_data (G_OBJECT (dockable),
"gimp-dialogs-view");
if (view)
{
if (dockable->context)
{
g_signal_handlers_disconnect_by_func (G_OBJECT (dockable->context),
dialogs_navigation_display_changed,
view);
}
if (context)
{
g_signal_connect (G_OBJECT (context), "display_changed",
G_CALLBACK (dialogs_navigation_display_changed),
view);
dialogs_navigation_display_changed (context,
gimp_context_get_display (context),
view);
}
else
{
dialogs_navigation_display_changed (NULL, NULL, view);
}
}
}
static GtkWidget *
dialogs_dockable_new (GtkWidget *widget,
const gchar *name,
@ -1287,3 +1353,16 @@ dialogs_indexed_palette_image_changed (GimpContext *context,
{
gimp_colormap_editor_set_image (editor, gimage);
}
static void
dialogs_navigation_display_changed (GimpContext *context,
GimpDisplay *gdisp,
GimpNavigationView *view)
{
GimpDisplayShell *shell = NULL;
if (gdisp)
shell = GIMP_DISPLAY_SHELL (gdisp->shell);
gimp_navigation_view_set_shell (view, shell);
}

View File

@ -143,5 +143,9 @@ GtkWidget * dialogs_palette_editor_get (GimpDialogFactory *factory,
gint preview_size);
void dialogs_edit_palette_func (GimpData *data);
GtkWidget * dialogs_navigation_view_new (GimpDialogFactory *factory,
GimpContext *context,
gint preview_size);
#endif /* __DIALOGS_CONSTRUCTORS_H__ */

View File

@ -79,7 +79,9 @@ static const GimpDialogFactoryEntry dock_entries[] =
{ "gimp-brush-editor", dialogs_brush_editor_get, 0, TRUE, FALSE, FALSE, TRUE },
{ "gimp-gradient-editor", dialogs_gradient_editor_get, 0, TRUE, FALSE, FALSE, TRUE },
{ "gimp-palette-editor", dialogs_palette_editor_get, 0, TRUE, FALSE, FALSE, TRUE }
{ "gimp-palette-editor", dialogs_palette_editor_get, 0, TRUE, FALSE, FALSE, TRUE },
{ "gimp-navigation-view", dialogs_navigation_view_new, 0, FALSE, FALSE, FALSE, TRUE }
};

View File

@ -481,6 +481,10 @@ static GimpItemFactoryEntry image_entries[] =
"<StockItem>", GTK_STOCK_ZOOM_FIT },
NULL,
"view/zoom.html", NULL },
{ { N_("/View/Shrink Wrap"), "<control>E",
view_shrink_wrap_cmd_callback, 0 },
NULL,
"view/shrink_wrap.html", NULL },
/* <Image>/View/Zoom */
@ -589,10 +593,6 @@ static GimpItemFactoryEntry image_entries[] =
"<StockItem>", GTK_STOCK_NEW },
NULL,
"view/new_view.html", NULL },
{ { N_("/View/Shrink Wrap"), "<control>E",
view_shrink_wrap_cmd_callback, 0 },
NULL,
"view/shrink_wrap.html", NULL },
/* <Image>/Image/Mode */
@ -1364,6 +1364,7 @@ static GimpItemFactoryEntry dialogs_entries[] =
"<StockItem>", GTK_STOCK_SELECT_COLOR),
ADD_TAB (N_("/Add Tab/Buffers..."), "gimp-buffer-list", NULL, NULL),
ADD_TAB (N_("/Add Tab/Images..."), "gimp-image-list", NULL, NULL),
ADD_TAB (N_("/Add Tab/Navigation..."), "gimp-navigation-view", NULL, NULL),
SEPARATOR ("/Add Tab/---"),

View File

@ -172,7 +172,6 @@ static guint old_max_new_image_size;
static GimpThumbnailSize old_thumbnail_size;
static gboolean old_trust_dirty_flag;
static gboolean old_use_help;
static gboolean old_nav_window_per_display;
static gboolean old_info_window_follows_mouse;
static gint old_help_browser;
static gint old_cursor_mode;
@ -185,7 +184,6 @@ static gint edit_min_colors;
static gboolean edit_install_cmap;
static gboolean edit_cycled_marching_ants;
static gint edit_last_opened_size;
static gboolean edit_nav_window_per_display;
static gboolean edit_info_window_follows_mouse;
static gboolean edit_disable_tearoff_menus;
static gchar * edit_temp_path = NULL;
@ -368,7 +366,6 @@ prefs_check_settings (Gimp *gimp)
edit_install_cmap != old_install_cmap ||
edit_cycled_marching_ants != old_cycled_marching_ants ||
edit_last_opened_size != old_last_opened_size ||
edit_nav_window_per_display != old_nav_window_per_display ||
edit_info_window_follows_mouse != old_info_window_follows_mouse ||
edit_disable_tearoff_menus != old_disable_tearoff_menus ||
@ -506,7 +503,6 @@ prefs_save_callback (GtkWidget *widget,
gboolean save_install_cmap;
gboolean save_cycled_marching_ants;
gint save_last_opened_size;
gboolean save_nav_window_per_display;
gboolean save_info_window_follows_mouse;
gchar *save_temp_path;
gchar *save_swap_path;
@ -557,7 +553,6 @@ prefs_save_callback (GtkWidget *widget,
save_install_cmap = gimprc.install_cmap;
save_cycled_marching_ants = gimprc.cycled_marching_ants;
save_last_opened_size = gimprc.last_opened_size;
save_nav_window_per_display = gimprc.nav_window_per_display;
save_info_window_follows_mouse = gimprc.info_window_follows_mouse;
save_temp_path = base_config->temp_path;
@ -779,12 +774,6 @@ prefs_save_callback (GtkWidget *widget,
gimprc.last_opened_size = edit_last_opened_size;
update = g_list_append (update, "last-opened-size");
}
if (edit_nav_window_per_display != old_nav_window_per_display)
{
gimprc.nav_window_per_display = edit_nav_window_per_display;
update = g_list_append (update, "nav-window-per-display");
remove = g_list_append (remove, "nav-window-follows-auto");
}
if (edit_info_window_follows_mouse != old_info_window_follows_mouse)
{
gimprc.info_window_follows_mouse = edit_info_window_follows_mouse;
@ -869,7 +858,6 @@ prefs_save_callback (GtkWidget *widget,
gimprc.install_cmap = save_install_cmap;
gimprc.cycled_marching_ants = save_cycled_marching_ants;
gimprc.last_opened_size = save_last_opened_size;
gimprc.nav_window_per_display = save_nav_window_per_display;
gimprc.info_window_follows_mouse = save_info_window_follows_mouse;
base_config->temp_path = save_temp_path;
@ -952,7 +940,9 @@ prefs_cancel_callback (GtkWidget *widget,
if (gimprc.nav_preview_size != old_nav_preview_size)
{
gimprc.nav_preview_size = old_nav_preview_size;
#if 0
gdisplays_nav_preview_resized ();
#endif
}
if ((gimprc.transparency_type != old_transparency_type) ||
(gimprc.transparency_size != old_transparency_size))
@ -980,7 +970,6 @@ prefs_cancel_callback (GtkWidget *widget,
edit_install_cmap = old_install_cmap;
edit_cycled_marching_ants = old_cycled_marching_ants;
edit_last_opened_size = old_last_opened_size;
edit_nav_window_per_display = old_nav_window_per_display;
edit_info_window_follows_mouse = old_info_window_follows_mouse;
edit_disable_tearoff_menus = old_disable_tearoff_menus;
@ -1041,7 +1030,6 @@ prefs_toggle_callback (GtkWidget *widget,
data == &edit_stingy_memory_use ||
data == &edit_install_cmap ||
data == &edit_cycled_marching_ants ||
data == &edit_nav_window_per_display ||
data == &edit_info_window_follows_mouse ||
data == &edit_disable_tearoff_menus)
{
@ -1105,7 +1093,9 @@ prefs_nav_preview_size_callback (GtkWidget *widget,
{
gimp_menu_item_update (widget, data);
#if 0
gdisplays_nav_preview_resized ();
#endif
}
static void
@ -1643,7 +1633,6 @@ preferences_dialog_create (Gimp *gimp)
edit_install_cmap = gimprc.install_cmap;
edit_cycled_marching_ants = gimprc.cycled_marching_ants;
edit_last_opened_size = gimprc.last_opened_size;
edit_nav_window_per_display = gimprc.nav_window_per_display;
edit_info_window_follows_mouse = gimprc.info_window_follows_mouse;
edit_disable_tearoff_menus = gimprc.disable_tearoff_menus;
@ -1718,7 +1707,6 @@ preferences_dialog_create (Gimp *gimp)
old_install_cmap = edit_install_cmap;
old_cycled_marching_ants = edit_cycled_marching_ants;
old_last_opened_size = edit_last_opened_size;
old_nav_window_per_display = edit_nav_window_per_display;
old_info_window_follows_mouse = edit_info_window_follows_mouse;
old_disable_tearoff_menus = edit_disable_tearoff_menus;
@ -2102,8 +2090,6 @@ preferences_dialog_create (Gimp *gimp)
/* Dialog Bahaviour */
vbox2 = prefs_frame_new (_("Dialog Behavior"), GTK_CONTAINER (vbox));
prefs_check_button_new (_("Navigation Window per Display"),
&edit_nav_window_per_display, GTK_BOX (vbox2));
prefs_check_button_new (_("Info Window Follows Mouse"),
&edit_info_window_follows_mouse, GTK_BOX (vbox2));

View File

@ -42,7 +42,6 @@
#include "view-commands.h"
#include "gimprc.h"
#include "nav_window.h"
#define return_if_no_display(gdisp, data) \
@ -136,17 +135,8 @@ view_navigation_window_cmd_callback (GtkWidget *widget,
shell = GIMP_DISPLAY_SHELL (gdisp->shell);
if (gimprc.nav_window_per_display)
{
if (! shell->nav_dialog)
shell->nav_dialog = nav_dialog_create (shell);
nav_dialog_show (shell->nav_dialog);
}
else
{
nav_dialog_show_auto (gdisp->gimage->gimp);
}
gimp_dialog_factory_dialog_raise (global_dock_factory,
"gimp-navigation-view", -1);
}
void

View File

@ -481,6 +481,10 @@ static GimpItemFactoryEntry image_entries[] =
"<StockItem>", GTK_STOCK_ZOOM_FIT },
NULL,
"view/zoom.html", NULL },
{ { N_("/View/Shrink Wrap"), "<control>E",
view_shrink_wrap_cmd_callback, 0 },
NULL,
"view/shrink_wrap.html", NULL },
/* <Image>/View/Zoom */
@ -589,10 +593,6 @@ static GimpItemFactoryEntry image_entries[] =
"<StockItem>", GTK_STOCK_NEW },
NULL,
"view/new_view.html", NULL },
{ { N_("/View/Shrink Wrap"), "<control>E",
view_shrink_wrap_cmd_callback, 0 },
NULL,
"view/shrink_wrap.html", NULL },
/* <Image>/Image/Mode */
@ -1364,6 +1364,7 @@ static GimpItemFactoryEntry dialogs_entries[] =
"<StockItem>", GTK_STOCK_SELECT_COLOR),
ADD_TAB (N_("/Add Tab/Buffers..."), "gimp-buffer-list", NULL, NULL),
ADD_TAB (N_("/Add Tab/Images..."), "gimp-image-list", NULL, NULL),
ADD_TAB (N_("/Add Tab/Navigation..."), "gimp-navigation-view", NULL, NULL),
SEPARATOR ("/Add Tab/---"),

View File

@ -1,745 +0,0 @@
/* The GIMP -- an image manipulation program
* 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 2 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, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#include "config.h"
#include <stdlib.h>
#include <gtk/gtk.h>
#include <gdk/gdkkeysyms.h>
#include "libgimpmath/gimpmath.h"
#include "libgimpwidgets/gimpwidgets.h"
#include "widgets/widgets-types.h"
#include "base/temp-buf.h"
#include "core/gimp.h"
#include "core/gimpcontainer.h"
#include "core/gimpcontext.h"
#include "core/gimpimage.h"
#include "core/gimplist.h"
#include "file/file-utils.h"
#include "display/gimpdisplay.h"
#include "display/gimpdisplay-foreach.h"
#include "display/gimpdisplayshell.h"
#include "display/gimpdisplayshell-scroll.h"
#include "display/gimpdisplayshell-scale.h"
#include "widgets/gimpnavigationpreview.h"
#include "app_procs.h"
#include "gimprc.h"
#include "nav_window.h"
#include "libgimp/gimpintl.h"
#define BORDER_PEN_WIDTH 3
#define MAX_SCALE_BUF 20
struct _NavigationDialog
{
GtkWidget *shell;
GtkWidget *preview;
GtkWidget *zoom_label;
GtkObject *zoom_adjustment;
GimpDisplayShell *disp_shell;
gboolean block_adj_sig;
gboolean frozen;
};
static NavigationDialog * nav_dialog_new (GimpDisplayShell *shell);
static gchar * nav_dialog_title (GimpDisplayShell *shell);
static GtkWidget * nav_dialog_create_preview (NavigationDialog *nav_dialog,
GimpImage *gimage);
static void nav_dialog_update_marker (NavigationDialog *nav_dialog);
static void nav_dialog_close_callback (GtkWidget *widget,
NavigationDialog *nav_dialog);
static void nav_dialog_marker_changed (GimpNavigationPreview *preview,
gint x,
gint y,
NavigationDialog *nav_dialog);
static void nav_dialog_zoom (GimpNavigationPreview *preview,
GimpZoomType direction,
NavigationDialog *nav_dialog);
static void nav_dialog_scroll (GimpNavigationPreview *preview,
GdkScrollDirection direction,
NavigationDialog *nav_dialog);
static gboolean nav_dialog_button_release (GtkWidget *widget,
GdkEventButton *bevent,
NavigationDialog *nav_dialog);
static void nav_dialog_zoom_in (GtkWidget *widget,
NavigationDialog *nav_dialog);
static void nav_dialog_zoom_out (GtkWidget *widget,
NavigationDialog *nav_dialog);
static void nav_dialog_zoom_adj_changed (GtkAdjustment *adj,
NavigationDialog *nav_dialog);
static void nav_dialog_display_changed (GimpContext *context,
GimpDisplay *gdisp,
NavigationDialog *nav_dialog);
static NavigationDialog *nav_window_auto = NULL;
/* public functions */
NavigationDialog *
nav_dialog_create (GimpDisplayShell *shell)
{
NavigationDialog *nav_dialog;
GtkWidget *abox;
GtkWidget *frame;
GtkWidget *hbox;
GtkWidget *button;
GtkWidget *image;
GtkWidget *hscale;
gchar *title;
gchar scale_str[MAX_SCALE_BUF];
title = nav_dialog_title (shell);
nav_dialog = nav_dialog_new (shell);
nav_dialog->shell = gimp_dialog_new (title, "navigation_dialog",
gimp_standard_help_func,
"dialogs/navigation_window.html",
GTK_WIN_POS_MOUSE,
FALSE, TRUE, TRUE,
"_delete_event_",
nav_dialog_close_callback,
nav_dialog, NULL, NULL, TRUE, TRUE,
NULL);
g_free (title);
gtk_dialog_set_has_separator (GTK_DIALOG (nav_dialog->shell), FALSE);
gtk_widget_hide (GTK_DIALOG (nav_dialog->shell)->action_area);
g_object_weak_ref (G_OBJECT (nav_dialog->shell),
(GWeakNotify) g_free,
nav_dialog);
/* the preview */
abox = gtk_alignment_new (0.5, 0.5, 0.0, 0.0);
gtk_box_pack_start (GTK_BOX (GTK_DIALOG (nav_dialog->shell)->vbox), abox,
TRUE, TRUE, 0);
gtk_widget_show (abox);
frame = gtk_frame_new (NULL);
gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_IN);
gtk_container_add (GTK_CONTAINER (abox), frame);
gtk_widget_show (frame);
nav_dialog->preview = nav_dialog_create_preview (nav_dialog,
shell->gdisp->gimage);
gtk_container_add (GTK_CONTAINER (frame), nav_dialog->preview);
gtk_widget_show (nav_dialog->preview);
nav_dialog_update_marker (nav_dialog);
/* the zoom scale */
nav_dialog->zoom_adjustment =
gtk_adjustment_new (0.0, -15.0, 16.0, 1.0, 1.0, 1.0);
g_signal_connect (G_OBJECT (nav_dialog->zoom_adjustment), "value_changed",
G_CALLBACK (nav_dialog_zoom_adj_changed),
nav_dialog);
hscale = gtk_hscale_new (GTK_ADJUSTMENT (nav_dialog->zoom_adjustment));
gtk_scale_set_draw_value (GTK_SCALE (hscale), FALSE);
gtk_scale_set_digits (GTK_SCALE (hscale), 0);
gtk_box_pack_end (GTK_BOX (GTK_DIALOG (nav_dialog->shell)->vbox), hscale,
FALSE, FALSE, 0);
gtk_widget_show (hscale);
/* the zoom buttons */
hbox = gtk_hbox_new (FALSE, 0);
gtk_box_pack_end (GTK_BOX (GTK_DIALOG (nav_dialog->shell)->vbox), hbox,
FALSE, FALSE, 0);
gtk_widget_show (hbox);
button = gtk_button_new ();
GTK_WIDGET_UNSET_FLAGS (button, GTK_RECEIVES_DEFAULT);
gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, FALSE, 0);
gtk_widget_show (button);
image = gtk_image_new_from_stock (GTK_STOCK_ZOOM_OUT, GTK_ICON_SIZE_MENU);
gtk_container_add (GTK_CONTAINER (button), image);
gtk_widget_show (image);
g_signal_connect (G_OBJECT (button), "clicked",
G_CALLBACK (nav_dialog_zoom_out),
nav_dialog);
/* user zoom ratio */
g_snprintf (scale_str, sizeof (scale_str), "%d:%d",
SCALEDEST (nav_dialog->disp_shell->gdisp),
SCALESRC (nav_dialog->disp_shell->gdisp));
nav_dialog->zoom_label = gtk_label_new (scale_str);
gtk_box_pack_start (GTK_BOX (hbox), nav_dialog->zoom_label, TRUE, TRUE, 0);
gtk_widget_show (nav_dialog->zoom_label);
button = gtk_button_new ();
GTK_WIDGET_UNSET_FLAGS (button, GTK_RECEIVES_DEFAULT);
gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, FALSE, 0);
gtk_widget_show (button);
image = gtk_image_new_from_stock (GTK_STOCK_ZOOM_IN, GTK_ICON_SIZE_MENU);
gtk_container_add (GTK_CONTAINER (button), image);
gtk_widget_show (image);
g_signal_connect (G_OBJECT (button), "clicked",
G_CALLBACK (nav_dialog_zoom_in),
nav_dialog);
return nav_dialog;
}
void
nav_dialog_create_popup (GimpDisplayShell *shell,
GtkWidget *widget,
gint button_x,
gint button_y)
{
NavigationDialog *nav_dialog;
GimpNavigationPreview *preview;
gint x, y;
gint x_org, y_org;
gint scr_w, scr_h;
if (! shell->nav_popup)
{
GtkWidget *frame;
GtkWidget *preview_frame;
shell->nav_popup = nav_dialog = nav_dialog_new (shell);
nav_dialog->shell = gtk_window_new (GTK_WINDOW_POPUP);
g_object_weak_ref (G_OBJECT (nav_dialog->shell),
(GWeakNotify) g_free,
nav_dialog);
frame = gtk_frame_new (NULL);
gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_OUT);
gtk_container_add (GTK_CONTAINER (nav_dialog->shell), frame);
gtk_widget_show (frame);
preview_frame = gtk_frame_new (NULL);
gtk_frame_set_shadow_type (GTK_FRAME (preview_frame), GTK_SHADOW_IN);
gtk_container_add (GTK_CONTAINER (frame), preview_frame);
gtk_widget_show (preview_frame);
nav_dialog->preview = nav_dialog_create_preview (nav_dialog,
shell->gdisp->gimage);
gtk_container_add (GTK_CONTAINER (preview_frame), nav_dialog->preview);
gtk_widget_show (nav_dialog->preview);
g_signal_connect (G_OBJECT (nav_dialog->preview), "button_release_event",
G_CALLBACK (nav_dialog_button_release),
nav_dialog);
}
else
{
nav_dialog = shell->nav_popup;
gtk_widget_hide (nav_dialog->shell);
}
nav_dialog_update_marker (nav_dialog);
preview = GIMP_NAVIGATION_PREVIEW (nav_dialog->preview);
/* decide where to put the popup */
gdk_window_get_origin (widget->window, &x_org, &y_org);
scr_w = gdk_screen_width ();
scr_h = gdk_screen_height ();
x = (x_org + button_x -
preview->p_x -
((preview->p_width - BORDER_PEN_WIDTH + 1) * 0.5) - 2);
y = (y_org + button_y -
preview->p_y -
((preview->p_height - BORDER_PEN_WIDTH + 1) * 0.5) - 2);
/* If the popup doesn't fit into the screen, we have a problem.
* We move the popup onscreen and risk that the pointer is not
* in the square representing the viewable area anymore. Moving
* the pointer will make the image scroll by a large amount,
* but then it works as usual. Probably better than a popup that
* is completely unusable in the lower right of the screen.
*
* Warping the pointer would be another solution ...
*/
x = (x < 0) ? 0 : x;
y = (y < 0) ? 0 : y;
x = (x + preview->p_width > scr_w) ? scr_w - preview->p_width - 2 : x;
y = (y + preview->p_height > scr_h) ? scr_h - preview->p_height - 2 : y;
gtk_window_move (GTK_WINDOW (nav_dialog->shell), x, y);
gtk_widget_show (nav_dialog->shell);
gdk_flush ();
/* fill in then grab pointer */
preview->motion_offset_x =
(preview->p_width - BORDER_PEN_WIDTH + 1) * 0.5;
preview->motion_offset_y =
(preview->p_height - BORDER_PEN_WIDTH + 1) * 0.5;
gimp_navigation_preview_grab_pointer (preview);
}
void
nav_dialog_free (GimpDisplayShell *del_shell,
NavigationDialog *nav_dialog)
{
/* So this functions works both ways..
* it will come in here with nav_dialog == null
* if the auto mode is on...
*/
if (nav_dialog)
{
gtk_widget_destroy (nav_dialog->shell);
}
else if (nav_window_auto)
{
GimpDisplay *gdisp = NULL;
GList *list;
/* Only freeze if we are displaying the image we have deleted */
if (nav_window_auto->disp_shell != del_shell)
return;
for (list = GIMP_LIST (the_gimp->images)->list;
list;
list = g_list_next (list))
{
gdisp = gdisplays_check_valid (NULL, GIMP_IMAGE (list->data));
if (gdisp)
break;
}
if (gdisp)
{
nav_dialog_display_changed (NULL, gdisp, nav_window_auto);
}
else
{
/* Clear window and freeze */
nav_window_auto->frozen = TRUE;
gtk_window_set_title (GTK_WINDOW (nav_window_auto->shell),
_("Navigation: No Image"));
gtk_widget_set_sensitive (nav_window_auto->shell, FALSE);
nav_window_auto->disp_shell = NULL;
gtk_widget_hide (GTK_WIDGET (nav_window_auto->shell));
}
}
}
void
nav_dialog_show (NavigationDialog *nav_dialog)
{
g_return_if_fail (nav_dialog != NULL);
if (! GTK_WIDGET_VISIBLE (nav_dialog->shell))
{
gtk_widget_show (nav_dialog->shell);
}
else
{
gdk_window_raise (nav_dialog->shell->window);
}
}
void
nav_dialog_show_auto (Gimp *gimp)
{
GimpContext *context;
GimpDisplay *gdisp;
g_return_if_fail (GIMP_IS_GIMP (gimp));
context = gimp_get_user_context (gimp);
gdisp = gimp_context_get_display (context);
if (! gdisp)
return;
if (! nav_window_auto)
{
nav_window_auto = nav_dialog_create (GIMP_DISPLAY_SHELL (gdisp->shell));
g_signal_connect (G_OBJECT (context), "display_changed",
G_CALLBACK (nav_dialog_display_changed),
nav_window_auto);
}
nav_dialog_show (nav_window_auto);
gtk_widget_set_sensitive (nav_window_auto->shell, TRUE);
nav_window_auto->frozen = FALSE;
}
void
nav_dialog_update (NavigationDialog *nav_dialog)
{
/* So this functions works both ways..
* it will come in here with info_win == null
* if the auto mode is on...
*/
if (! nav_dialog)
{
if (nav_window_auto && ! nav_window_auto->frozen)
{
nav_dialog_update (nav_window_auto);
}
return;
}
if (! GTK_WIDGET_VISIBLE (nav_dialog->shell))
return;
if (nav_dialog->zoom_label)
{
gchar scale_str[MAX_SCALE_BUF];
/* Update the zoom scale string */
g_snprintf (scale_str, sizeof (scale_str), "%d:%d",
SCALEDEST (nav_dialog->disp_shell->gdisp),
SCALESRC (nav_dialog->disp_shell->gdisp));
gtk_label_set_text (GTK_LABEL (nav_dialog->zoom_label), scale_str);
}
if (nav_dialog->zoom_adjustment)
{
GtkAdjustment *adj;
gdouble f;
gdouble val;
adj = GTK_ADJUSTMENT (nav_dialog->zoom_adjustment);
f = (((gdouble) SCALEDEST (nav_dialog->disp_shell->gdisp)) /
((gdouble) SCALESRC (nav_dialog->disp_shell->gdisp)));
if (f < 1.0)
val = -1.0 / f;
else
val = f;
if (abs ((gint) adj->value) != (gint) (val - 1) &&
! nav_dialog->block_adj_sig)
{
adj->value = val;
gtk_adjustment_changed (GTK_ADJUSTMENT (nav_dialog->zoom_adjustment));
}
}
nav_dialog_update_marker (nav_dialog);
}
void
nav_dialog_preview_resized (NavigationDialog *nav_dialog)
{
if (! nav_dialog)
return;
}
/* private functions */
static NavigationDialog *
nav_dialog_new (GimpDisplayShell *shell)
{
NavigationDialog *nav_dialog;
nav_dialog = g_new0 (NavigationDialog, 1);
nav_dialog->shell = NULL;
nav_dialog->preview = NULL;
nav_dialog->zoom_label = NULL;
nav_dialog->zoom_adjustment = NULL;
nav_dialog->disp_shell = shell;
nav_dialog->block_adj_sig = FALSE;
nav_dialog->frozen = FALSE;
return nav_dialog;
}
static gchar *
nav_dialog_title (GimpDisplayShell *shell)
{
gchar *basename;
gchar *title;
basename = file_utils_uri_to_utf8_basename (gimp_image_get_uri (shell->gdisp->gimage));
title = g_strdup_printf (_("Navigation: %s-%d.%d"),
basename,
gimp_image_get_ID (shell->gdisp->gimage),
shell->gdisp->instance);
g_free (basename);
return title;
}
static GtkWidget *
nav_dialog_create_preview (NavigationDialog *nav_dialog,
GimpImage *gimage)
{
GtkWidget *preview;
preview = gimp_navigation_preview_new (gimage, gimprc.nav_preview_size);
g_signal_connect (G_OBJECT (preview), "marker_changed",
G_CALLBACK (nav_dialog_marker_changed),
nav_dialog);
g_signal_connect (G_OBJECT (preview), "zoom",
G_CALLBACK (nav_dialog_zoom),
nav_dialog);
g_signal_connect (G_OBJECT (preview), "scroll",
G_CALLBACK (nav_dialog_scroll),
nav_dialog);
return preview;
}
static void
nav_dialog_update_marker (NavigationDialog *nav_dialog)
{
GimpImage *gimage;
gdouble xratio;
gdouble yratio; /* Screen res ratio */
/* Calculate preview size */
gimage = nav_dialog->disp_shell->gdisp->gimage;
xratio = SCALEFACTOR_X (nav_dialog->disp_shell->gdisp);
yratio = SCALEFACTOR_Y (nav_dialog->disp_shell->gdisp);
if (GIMP_PREVIEW (nav_dialog->preview)->dot_for_dot !=
nav_dialog->disp_shell->gdisp->dot_for_dot)
gimp_preview_set_dot_for_dot (GIMP_PREVIEW (nav_dialog->preview),
nav_dialog->disp_shell->gdisp->dot_for_dot);
gimp_navigation_preview_set_marker
(GIMP_NAVIGATION_PREVIEW (nav_dialog->preview),
RINT (nav_dialog->disp_shell->offset_x / xratio),
RINT (nav_dialog->disp_shell->offset_y / yratio),
RINT (nav_dialog->disp_shell->disp_width / xratio),
RINT (nav_dialog->disp_shell->disp_height / yratio));
}
static void
nav_dialog_close_callback (GtkWidget *widget,
NavigationDialog *nav_dialog)
{
gtk_widget_hide (nav_dialog->shell);
}
static void
nav_dialog_marker_changed (GimpNavigationPreview *nav_preview,
gint x,
gint y,
NavigationDialog *nav_dialog)
{
gdouble xratio;
gdouble yratio;
gint xoffset;
gint yoffset;
xratio = SCALEFACTOR_X (nav_dialog->disp_shell->gdisp);
yratio = SCALEFACTOR_Y (nav_dialog->disp_shell->gdisp);
xoffset = x * xratio - nav_dialog->disp_shell->offset_x;
yoffset = y * yratio - nav_dialog->disp_shell->offset_y;
gimp_display_shell_scroll (nav_dialog->disp_shell, xoffset, yoffset);
}
static void
nav_dialog_zoom (GimpNavigationPreview *nav_preview,
GimpZoomType direction,
NavigationDialog *nav_dialog)
{
gimp_display_shell_scale (nav_dialog->disp_shell, direction);
}
static void
nav_dialog_scroll (GimpNavigationPreview *nav_preview,
GdkScrollDirection direction,
NavigationDialog *nav_dialog)
{
GtkAdjustment *adj = NULL;
gdouble value;
switch (direction)
{
case GDK_SCROLL_LEFT:
case GDK_SCROLL_RIGHT:
adj = nav_dialog->disp_shell->hsbdata;
break;
case GDK_SCROLL_UP:
case GDK_SCROLL_DOWN:
adj = nav_dialog->disp_shell->vsbdata;
break;
}
g_assert (adj != NULL);
value = adj->value;
switch (direction)
{
case GDK_SCROLL_LEFT:
case GDK_SCROLL_UP:
value -= adj->page_increment / 2;
break;
case GDK_SCROLL_RIGHT:
case GDK_SCROLL_DOWN:
value += adj->page_increment / 2;
break;
}
value = CLAMP (value, adj->lower, adj->upper - adj->page_size);
gtk_adjustment_set_value (adj, value);
}
static gboolean
nav_dialog_button_release (GtkWidget *widget,
GdkEventButton *bevent,
NavigationDialog *nav_dialog)
{
if (bevent->button == 1)
{
gtk_widget_hide (nav_dialog->shell);
}
return FALSE;
}
static void
nav_dialog_zoom_in (GtkWidget *widget,
NavigationDialog *nav_dialog)
{
gimp_display_shell_scale (nav_dialog->disp_shell, GIMP_ZOOM_IN);
}
static void
nav_dialog_zoom_out (GtkWidget *widget,
NavigationDialog *nav_dialog)
{
gimp_display_shell_scale (nav_dialog->disp_shell, GIMP_ZOOM_OUT);
}
static void
nav_dialog_zoom_adj_changed (GtkAdjustment *adj,
NavigationDialog *nav_dialog)
{
gint scalesrc;
gint scaledest;
if (adj->value < 0.0)
{
scalesrc = abs ((gint) adj->value - 1);
scaledest = 1;
}
else
{
scaledest = abs ((gint) adj->value + 1);
scalesrc = 1;
}
nav_dialog->block_adj_sig = TRUE;
gimp_display_shell_scale (nav_dialog->disp_shell,
(scaledest * 100) + scalesrc);
nav_dialog->block_adj_sig = FALSE;
}
static void
nav_dialog_display_changed (GimpContext *context,
GimpDisplay *gdisp,
NavigationDialog *nav_dialog)
{
GimpDisplay *old_gdisp = NULL;
GimpImage *gimage;
gchar *title;
if (nav_dialog->disp_shell)
old_gdisp = nav_dialog->disp_shell->gdisp;
if (gdisp == old_gdisp || ! gdisp)
return;
gtk_widget_set_sensitive (nav_window_auto->shell, TRUE);
nav_dialog->frozen = FALSE;
title = nav_dialog_title (GIMP_DISPLAY_SHELL (gdisp->shell));
gtk_window_set_title (GTK_WINDOW (nav_dialog->shell), title);
g_free (title);
gimage = gdisp->gimage;
if (gimage && gimp_container_have (context->gimp->images,
GIMP_OBJECT (gimage)))
{
nav_dialog->disp_shell = GIMP_DISPLAY_SHELL (gdisp->shell);
gimp_preview_set_viewable (GIMP_PREVIEW (nav_dialog->preview),
GIMP_VIEWABLE (gdisp->gimage));
nav_dialog_update (nav_dialog);
}
}

View File

@ -1,39 +0,0 @@
/* The GIMP -- an image manipulation program
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
* Copyright (C) 1999 Andy Thomas alt@gimp.org
*
* 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 2 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, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef __NAV_WINDOW_H__
#define __NAV_WINDOW_H__
NavigationDialog * nav_dialog_create (GimpDisplayShell *shell);
void nav_dialog_create_popup (GimpDisplayShell *shell,
GtkWidget *widget,
gint button_x,
gint button_y);
void nav_dialog_free (GimpDisplayShell *del_shell,
NavigationDialog *nav_dialog);
void nav_dialog_show (NavigationDialog *nav_dialog);
void nav_dialog_show_auto (Gimp *gimp);
void nav_dialog_update (NavigationDialog *nav_dialog);
void nav_dialog_preview_resized (NavigationDialog *nav_dialog);
#endif /* __NAV_WINDOW_H__ */

View File

@ -27,6 +27,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpbuffer.h"
#include "core/gimpcontainer.h"
#include "core/gimpcontext.h"

View File

@ -33,6 +33,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpchannel.h"
#include "core/gimpcontainer.h"
#include "core/gimpimage.h"

View File

@ -33,6 +33,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpchannel.h"
#include "core/gimpcontainer.h"
#include "core/gimpimage.h"

View File

@ -36,6 +36,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpcontainer.h"
#include "core/gimpimage.h"
#include "core/gimpmarshal.h"

View File

@ -27,6 +27,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpimage.h"
#include "core/gimpviewable.h"

View File

@ -29,6 +29,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpcontainer.h"
#include "core/gimpcontext.h"
#include "core/gimpedit.h"

View File

@ -32,6 +32,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpdrawable.h"
#include "display/gimpdisplay-foreach.h"

View File

@ -33,6 +33,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpchannel.h"
#include "core/gimpcontainer.h"
#include "core/gimpdrawable.h"

View File

@ -33,6 +33,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpchannel.h"
#include "core/gimpcontainer.h"
#include "core/gimpdrawable.h"

View File

@ -46,22 +46,25 @@
#define DEFAULT_MINIMAL_WIDTH 250
static void gimp_image_dock_class_init (GimpImageDockClass *klass);
static void gimp_image_dock_init (GimpImageDock *dock);
static void gimp_image_dock_class_init (GimpImageDockClass *klass);
static void gimp_image_dock_init (GimpImageDock *dock);
static void gimp_image_dock_destroy (GtkObject *object);
static void gimp_image_dock_destroy (GtkObject *object);
static void gimp_image_dock_style_set (GtkWidget *widget,
GtkStyle *prev_style);
static void gimp_image_dock_style_set (GtkWidget *widget,
GtkStyle *prev_style);
static void gimp_image_dock_factory_image_changed (GimpContext *context,
GimpImage *gimage,
GimpDock *dock);
static void gimp_image_dock_image_changed (GimpContext *context,
GimpImage *gimage,
GimpDock *dock);
static void gimp_image_dock_auto_clicked (GtkWidget *widget,
GimpDock *dock);
static void gimp_image_dock_factory_display_changed (GimpContext *context,
GimpObject *gdisp,
GimpDock *dock);
static void gimp_image_dock_factory_image_changed (GimpContext *context,
GimpImage *gimage,
GimpDock *dock);
static void gimp_image_dock_image_changed (GimpContext *context,
GimpImage *gimage,
GimpDock *dock);
static void gimp_image_dock_auto_clicked (GtkWidget *widget,
GimpDock *dock);
static GimpDockClass *parent_class = NULL;
@ -230,6 +233,10 @@ gimp_image_dock_new (GimpDialogFactory *dialog_factory,
gimp_context_copy_property (dialog_factory->context, context,
GIMP_CONTEXT_PROP_IMAGE);
g_signal_connect_object (G_OBJECT (dialog_factory->context), "display_changed",
G_CALLBACK (gimp_image_dock_factory_display_changed),
G_OBJECT (image_dock),
0);
g_signal_connect_object (G_OBJECT (dialog_factory->context), "image_changed",
G_CALLBACK (gimp_image_dock_factory_image_changed),
G_OBJECT (image_dock),
@ -278,6 +285,21 @@ gimp_image_dock_set_show_image_menu (GimpImageDock *image_dock,
image_dock->show_image_menu = show ? TRUE : FALSE;
}
static void
gimp_image_dock_factory_display_changed (GimpContext *context,
GimpObject *gdisp,
GimpDock *dock)
{
GimpImageDock *image_dock;
image_dock = GIMP_IMAGE_DOCK (dock);
if (gdisp && image_dock->auto_follow_active)
{
gimp_context_set_display (dock->context, gdisp);
}
}
static void
gimp_image_dock_factory_image_changed (GimpContext *context,
GimpImage *gimage,
@ -289,6 +311,8 @@ gimp_image_dock_factory_image_changed (GimpContext *context,
if (gimage && image_dock->auto_follow_active)
{
/* won't do anything if we already set the display above
*/
gimp_context_set_image (dock->context, gimage);
}
}
@ -333,11 +357,22 @@ gimp_image_dock_auto_clicked (GtkWidget *widget,
if (image_dock->auto_follow_active)
{
GimpImage *gimage;
GimpObject *gdisp;
gimage = gimp_context_get_image (dock->dialog_factory->context);
gdisp = gimp_context_get_display (dock->dialog_factory->context);
if (gimage)
gimp_context_set_image (dock->context, gimage);
if (gdisp)
{
gimp_context_set_display (dock->context, gdisp);
}
else
{
GimpImage *gimage;
gimage = gimp_context_get_image (dock->dialog_factory->context);
if (gimage)
gimp_context_set_image (dock->context, gimage);
}
}
}

View File

@ -32,6 +32,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpitem.h"
#include "display/gimpdisplay-foreach.h"

View File

@ -33,6 +33,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpchannel.h"
#include "core/gimpcontainer.h"
#include "core/gimpimage.h"

View File

@ -33,6 +33,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpchannel.h"
#include "core/gimpcontainer.h"
#include "core/gimpimage.h"

View File

@ -33,6 +33,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpdrawable.h"
#include "core/gimpimage.h"
#include "core/gimplayer.h"

View File

@ -28,6 +28,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpcontainer.h"
#include "core/gimpdrawable.h"
#include "core/gimplayer.h"

View File

@ -28,6 +28,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpcontainer.h"
#include "core/gimpdrawable.h"
#include "core/gimplayer.h"

View File

@ -46,22 +46,25 @@
#define DEFAULT_MINIMAL_WIDTH 250
static void gimp_image_dock_class_init (GimpImageDockClass *klass);
static void gimp_image_dock_init (GimpImageDock *dock);
static void gimp_image_dock_class_init (GimpImageDockClass *klass);
static void gimp_image_dock_init (GimpImageDock *dock);
static void gimp_image_dock_destroy (GtkObject *object);
static void gimp_image_dock_destroy (GtkObject *object);
static void gimp_image_dock_style_set (GtkWidget *widget,
GtkStyle *prev_style);
static void gimp_image_dock_style_set (GtkWidget *widget,
GtkStyle *prev_style);
static void gimp_image_dock_factory_image_changed (GimpContext *context,
GimpImage *gimage,
GimpDock *dock);
static void gimp_image_dock_image_changed (GimpContext *context,
GimpImage *gimage,
GimpDock *dock);
static void gimp_image_dock_auto_clicked (GtkWidget *widget,
GimpDock *dock);
static void gimp_image_dock_factory_display_changed (GimpContext *context,
GimpObject *gdisp,
GimpDock *dock);
static void gimp_image_dock_factory_image_changed (GimpContext *context,
GimpImage *gimage,
GimpDock *dock);
static void gimp_image_dock_image_changed (GimpContext *context,
GimpImage *gimage,
GimpDock *dock);
static void gimp_image_dock_auto_clicked (GtkWidget *widget,
GimpDock *dock);
static GimpDockClass *parent_class = NULL;
@ -230,6 +233,10 @@ gimp_image_dock_new (GimpDialogFactory *dialog_factory,
gimp_context_copy_property (dialog_factory->context, context,
GIMP_CONTEXT_PROP_IMAGE);
g_signal_connect_object (G_OBJECT (dialog_factory->context), "display_changed",
G_CALLBACK (gimp_image_dock_factory_display_changed),
G_OBJECT (image_dock),
0);
g_signal_connect_object (G_OBJECT (dialog_factory->context), "image_changed",
G_CALLBACK (gimp_image_dock_factory_image_changed),
G_OBJECT (image_dock),
@ -278,6 +285,21 @@ gimp_image_dock_set_show_image_menu (GimpImageDock *image_dock,
image_dock->show_image_menu = show ? TRUE : FALSE;
}
static void
gimp_image_dock_factory_display_changed (GimpContext *context,
GimpObject *gdisp,
GimpDock *dock)
{
GimpImageDock *image_dock;
image_dock = GIMP_IMAGE_DOCK (dock);
if (gdisp && image_dock->auto_follow_active)
{
gimp_context_set_display (dock->context, gdisp);
}
}
static void
gimp_image_dock_factory_image_changed (GimpContext *context,
GimpImage *gimage,
@ -289,6 +311,8 @@ gimp_image_dock_factory_image_changed (GimpContext *context,
if (gimage && image_dock->auto_follow_active)
{
/* won't do anything if we already set the display above
*/
gimp_context_set_image (dock->context, gimage);
}
}
@ -333,11 +357,22 @@ gimp_image_dock_auto_clicked (GtkWidget *widget,
if (image_dock->auto_follow_active)
{
GimpImage *gimage;
GimpObject *gdisp;
gimage = gimp_context_get_image (dock->dialog_factory->context);
gdisp = gimp_context_get_display (dock->dialog_factory->context);
if (gimage)
gimp_context_set_image (dock->context, gimage);
if (gdisp)
{
gimp_context_set_display (dock->context, gdisp);
}
else
{
GimpImage *gimage;
gimage = gimp_context_get_image (dock->dialog_factory->context);
if (gimage)
gimp_context_set_image (dock->context, gimage);
}
}
}

View File

@ -2,7 +2,10 @@
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
*
* GimpNavigationPreview Widget
* Copyright (C) 2001 Michael Natterer <mitch@gimp.org>
* Copyright (C) 2001-2002 Michael Natterer <mitch@gimp.org>
*
* partly based on app/nav_window
* Copyright (C) 1999 Andy Thomas <alt@gimp.org>
*
* 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
@ -165,6 +168,9 @@ gimp_navigation_preview_init (GimpNavigationPreview *preview)
{
GTK_WIDGET_SET_FLAGS (preview, GTK_CAN_FOCUS);
gtk_widget_add_events (GTK_WIDGET (preview), (GDK_POINTER_MOTION_MASK |
GDK_KEY_PRESS_MASK));
preview->x = 0;
preview->y = 0;
preview->width = 0;
@ -245,6 +251,9 @@ gimp_navigation_preview_move_to (GimpNavigationPreview *nav_preview,
preview = GIMP_PREVIEW (nav_preview);
if (! preview->viewable)
return;
tx = CLAMP (tx, 0, preview->width);
ty = CLAMP (ty, 0, preview->height);
@ -286,7 +295,7 @@ gimp_navigation_preview_grab_pointer (GimpNavigationPreview *nav_preview)
gtk_grab_add (widget);
cursor = gdk_cursor_new (GDK_CROSSHAIR);
cursor = gdk_cursor_new (GDK_FLEUR);
gdk_pointer_grab (widget->window, TRUE,
GDK_BUTTON_RELEASE_MASK |
@ -318,6 +327,8 @@ gimp_navigation_preview_button_press (GtkWidget *widget,
ty > nav_preview->p_y &&
ty < (nav_preview->p_y + nav_preview->p_height)))
{
GdkCursor *cursor;
nav_preview->motion_offset_x = nav_preview->p_width / 2;
nav_preview->motion_offset_y = nav_preview->p_height / 2;
@ -325,6 +336,10 @@ gimp_navigation_preview_button_press (GtkWidget *widget,
ty -= nav_preview->motion_offset_y;
gimp_navigation_preview_move_to (nav_preview, tx, ty);
cursor = gdk_cursor_new (GDK_FLEUR);
gdk_window_set_cursor (widget->window, cursor);
gdk_cursor_unref (cursor);
}
else
{
@ -423,7 +438,34 @@ gimp_navigation_preview_motion_notify (GtkWidget *widget,
nav_preview = GIMP_NAVIGATION_PREVIEW (widget);
if (! nav_preview->has_grab)
return FALSE;
{
GdkCursor *cursor;
if (nav_preview->p_x == 0 &&
nav_preview->p_y == 0 &&
nav_preview->p_width == GIMP_PREVIEW (widget)->width &&
nav_preview->p_height == GIMP_PREVIEW (widget)->height)
{
gdk_window_set_cursor (widget->window, NULL);
return FALSE;
}
else if (mevent->x >= nav_preview->p_x &&
mevent->y >= nav_preview->p_y &&
mevent->x < nav_preview->p_x + nav_preview->p_width &&
mevent->y < nav_preview->p_y + nav_preview->p_height)
{
cursor = gdk_cursor_new (GDK_FLEUR);
}
else
{
cursor = gdk_cursor_new (GDK_HAND2);
}
gdk_window_set_cursor (widget->window, cursor);
gdk_cursor_unref (cursor);
return FALSE;
}
gdk_window_get_pointer (widget->window, &tx, &ty, &mask);
@ -532,16 +574,22 @@ gimp_navigation_preview_new (GimpImage *gimage,
{
GimpPreview *preview;
g_return_val_if_fail (GIMP_IS_IMAGE (gimage), NULL);
g_return_val_if_fail (! gimage || GIMP_IS_IMAGE (gimage), NULL);
g_return_val_if_fail (size > 0 && size <= 256, NULL);
preview = g_object_new (GIMP_TYPE_NAVIGATION_PREVIEW, NULL);
preview->is_popup = TRUE;
gimp_preview_set_viewable (preview, GIMP_VIEWABLE (gimage));
gimp_preview_set_size (preview, size, 0);
if (gimage)
{
gimp_preview_set_viewable (preview, GIMP_VIEWABLE (gimage));
gimp_preview_set_size (preview, size, 0);
}
else
{
preview->size = size;
}
return GTK_WIDGET (preview);
}

View File

@ -2,7 +2,10 @@
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
*
* GimpNavigationPreview Widget
* Copyright (C) 2001 Michael Natterer <mitch@gimp.org>
* Copyright (C) 2001-2002 Michael Natterer <mitch@gimp.org>
*
* partly based on app/nav_window
* Copyright (C) 1999 Andy Thomas <alt@gimp.org>
*
* 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

View File

@ -2,7 +2,10 @@
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
*
* GimpNavigationPreview Widget
* Copyright (C) 2001 Michael Natterer <mitch@gimp.org>
* Copyright (C) 2001-2002 Michael Natterer <mitch@gimp.org>
*
* partly based on app/nav_window
* Copyright (C) 1999 Andy Thomas <alt@gimp.org>
*
* 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
@ -165,6 +168,9 @@ gimp_navigation_preview_init (GimpNavigationPreview *preview)
{
GTK_WIDGET_SET_FLAGS (preview, GTK_CAN_FOCUS);
gtk_widget_add_events (GTK_WIDGET (preview), (GDK_POINTER_MOTION_MASK |
GDK_KEY_PRESS_MASK));
preview->x = 0;
preview->y = 0;
preview->width = 0;
@ -245,6 +251,9 @@ gimp_navigation_preview_move_to (GimpNavigationPreview *nav_preview,
preview = GIMP_PREVIEW (nav_preview);
if (! preview->viewable)
return;
tx = CLAMP (tx, 0, preview->width);
ty = CLAMP (ty, 0, preview->height);
@ -286,7 +295,7 @@ gimp_navigation_preview_grab_pointer (GimpNavigationPreview *nav_preview)
gtk_grab_add (widget);
cursor = gdk_cursor_new (GDK_CROSSHAIR);
cursor = gdk_cursor_new (GDK_FLEUR);
gdk_pointer_grab (widget->window, TRUE,
GDK_BUTTON_RELEASE_MASK |
@ -318,6 +327,8 @@ gimp_navigation_preview_button_press (GtkWidget *widget,
ty > nav_preview->p_y &&
ty < (nav_preview->p_y + nav_preview->p_height)))
{
GdkCursor *cursor;
nav_preview->motion_offset_x = nav_preview->p_width / 2;
nav_preview->motion_offset_y = nav_preview->p_height / 2;
@ -325,6 +336,10 @@ gimp_navigation_preview_button_press (GtkWidget *widget,
ty -= nav_preview->motion_offset_y;
gimp_navigation_preview_move_to (nav_preview, tx, ty);
cursor = gdk_cursor_new (GDK_FLEUR);
gdk_window_set_cursor (widget->window, cursor);
gdk_cursor_unref (cursor);
}
else
{
@ -423,7 +438,34 @@ gimp_navigation_preview_motion_notify (GtkWidget *widget,
nav_preview = GIMP_NAVIGATION_PREVIEW (widget);
if (! nav_preview->has_grab)
return FALSE;
{
GdkCursor *cursor;
if (nav_preview->p_x == 0 &&
nav_preview->p_y == 0 &&
nav_preview->p_width == GIMP_PREVIEW (widget)->width &&
nav_preview->p_height == GIMP_PREVIEW (widget)->height)
{
gdk_window_set_cursor (widget->window, NULL);
return FALSE;
}
else if (mevent->x >= nav_preview->p_x &&
mevent->y >= nav_preview->p_y &&
mevent->x < nav_preview->p_x + nav_preview->p_width &&
mevent->y < nav_preview->p_y + nav_preview->p_height)
{
cursor = gdk_cursor_new (GDK_FLEUR);
}
else
{
cursor = gdk_cursor_new (GDK_HAND2);
}
gdk_window_set_cursor (widget->window, cursor);
gdk_cursor_unref (cursor);
return FALSE;
}
gdk_window_get_pointer (widget->window, &tx, &ty, &mask);
@ -532,16 +574,22 @@ gimp_navigation_preview_new (GimpImage *gimage,
{
GimpPreview *preview;
g_return_val_if_fail (GIMP_IS_IMAGE (gimage), NULL);
g_return_val_if_fail (! gimage || GIMP_IS_IMAGE (gimage), NULL);
g_return_val_if_fail (size > 0 && size <= 256, NULL);
preview = g_object_new (GIMP_TYPE_NAVIGATION_PREVIEW, NULL);
preview->is_popup = TRUE;
gimp_preview_set_viewable (preview, GIMP_VIEWABLE (gimage));
gimp_preview_set_size (preview, size, 0);
if (gimage)
{
gimp_preview_set_viewable (preview, GIMP_VIEWABLE (gimage));
gimp_preview_set_size (preview, size, 0);
}
else
{
preview->size = size;
}
return GTK_WIDGET (preview);
}

View File

@ -2,7 +2,10 @@
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
*
* GimpNavigationPreview Widget
* Copyright (C) 2001 Michael Natterer <mitch@gimp.org>
* Copyright (C) 2001-2002 Michael Natterer <mitch@gimp.org>
*
* partly based on app/nav_window
* Copyright (C) 1999 Andy Thomas <alt@gimp.org>
*
* 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

View File

@ -32,6 +32,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "base/temp-buf.h"
#include "core/gimpmarshal.h"

View File

@ -32,6 +32,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "base/temp-buf.h"
#include "core/gimpmarshal.h"

View File

@ -33,6 +33,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpchannel.h"
#include "core/gimpcontainer.h"
#include "core/gimpimage.h"

View File

@ -33,6 +33,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "core/gimpchannel.h"
#include "core/gimpcontainer.h"
#include "core/gimpimage.h"

View File

@ -32,6 +32,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "base/temp-buf.h"
#include "core/gimpmarshal.h"

View File

@ -32,6 +32,9 @@
#include "widgets-types.h"
#warning FIXME #include "display/display-types.h"
#include "display/display-types.h"
#include "base/temp-buf.h"
#include "core/gimpmarshal.h"

View File

@ -24,8 +24,6 @@
#include "core/core-types.h"
#include "display/display-types.h"
#include "widgets/widgets-enums.h"

View File

@ -161,8 +161,8 @@ typedef enum /*< skip >*/
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
typedef struct _GimpDisplay GimpDisplay; /*< proxy-resume >*/
typedef struct _GimpDisplayShell GimpDisplayShell;
typedef struct _GimpDisplay GimpDisplay; /*< proxy-resume >*/
typedef struct _GimpDisplayShell GimpDisplayShell;
#endif /* __GIMP_PROXY_TYPES_H__ */