diff options
author | Federico Mena Quintero <federico@novell.com> | 2009-01-14 20:18:54 +0000 |
---|---|---|
committer | Federico Mena Quintero <federico@src.gnome.org> | 2009-01-14 20:18:54 +0000 |
commit | d133ab3ac0cb7065f9fda9e576d063298c654ffd (patch) | |
tree | 4c244149ba7e0be755b2ee81dc016b57204448c4 /gtk/gtkfilechooserdialog.c | |
parent | 1d4694ec799a0ade83ea071d929e41aa980fe21b (diff) | |
download | gtk+-d133ab3ac0cb7065f9fda9e576d063298c654ffd.tar.gz |
Don't clamp the restored size of the file chooser dialog
* gtk/gtkfilechooserdialog.c
(file_chooser_widget_default_size_changed): Simply resize the
dialog to the default size without any fancy clamping. Also,
leave in place ifdef-ed out code to restore the file chooser's
position in addition to its size. The code to restore the
position doesn't quite work yet, but we'll leave it in as a
reference.
Signed-off-by: Federico Mena Quintero <federico@novell.com>
svn path=/trunk/; revision=22118
Diffstat (limited to 'gtk/gtkfilechooserdialog.c')
-rw-r--r-- | gtk/gtkfilechooserdialog.c | 65 |
1 files changed, 32 insertions, 33 deletions
diff --git a/gtk/gtkfilechooserdialog.c b/gtk/gtkfilechooserdialog.c index ec42374de1..cfa836d45e 100644 --- a/gtk/gtkfilechooserdialog.c +++ b/gtk/gtkfilechooserdialog.c @@ -25,6 +25,7 @@ #include "gtkfilechooserwidget.h" #include "gtkfilechooserutils.h" #include "gtkfilechooserembed.h" +#include "gtkfilechoosersettings.h" #include "gtkfilesystem.h" #include "gtktypebuiltins.h" #include "gtkintl.h" @@ -154,37 +155,33 @@ file_chooser_widget_file_activated (GtkFileChooser *chooser, g_list_free (children); } +#if 0 +/* FIXME: to see why this function is ifdef-ed out, see the comment below in + * file_chooser_widget_default_size_changed(). + */ static void -clamp_to_screen (GtkWidget *widget, - gint *width, - gint *height) +load_position (int *out_xpos, int *out_ypos) { - GdkScreen *screen; - int monitor_num; - GdkRectangle monitor; - - g_return_if_fail (GTK_WIDGET_REALIZED (widget)); - - screen = gtk_widget_get_screen (widget); - monitor_num = gdk_screen_get_monitor_at_window (screen, widget->window); - - gdk_screen_get_monitor_geometry (screen, monitor_num, &monitor); + GtkFileChooserSettings *settings; + int x, y, width, height; - if (width) - *width = MIN (*width, (monitor.width * 3) / 4); + settings = _gtk_file_chooser_settings_new (); + _gtk_file_chooser_settings_get_geometry (settings, &x, &y, &width, &height); + g_object_unref (settings); - if (height) - *height = MIN (*height, (monitor.height * 3) / 4); + *out_xpos = x; + *out_ypos = y; } +#endif static void file_chooser_widget_default_size_changed (GtkWidget *widget, GtkFileChooserDialog *dialog) { GtkFileChooserDialogPrivate *priv; - gint width, height; gint default_width, default_height; GtkRequisition req, widget_req; + int xpos, ypos; priv = GTK_FILE_CHOOSER_DIALOG_GET_PRIVATE (dialog); @@ -197,27 +194,29 @@ file_chooser_widget_default_size_changed (GtkWidget *widget, * that widget->requisition is meaningful. */ gtk_widget_size_request (GTK_WIDGET (dialog), &req); gtk_widget_size_request (widget, &widget_req); - - width = req.width - widget_req.width; - height = req.height - widget_req.height; - } - else - { - width = GTK_WIDGET (dialog)->allocation.width - widget->allocation.width; - height = GTK_WIDGET (dialog)->allocation.height - widget->allocation.height; } _gtk_file_chooser_embed_get_default_size (GTK_FILE_CHOOSER_EMBED (priv->widget), &default_width, &default_height); - /* Ideal target size plus any extra size */ - width = default_width + width + (2 * GTK_CONTAINER (dialog)->border_width); - height = default_height + height + (2 * GTK_CONTAINER (dialog)->border_width); - - if (GTK_WIDGET_REALIZED (dialog)) - clamp_to_screen (GTK_WIDGET (dialog), &width, &height); + gtk_window_resize (GTK_WINDOW (dialog), default_width, default_height); - gtk_window_resize (GTK_WINDOW (dialog), width, height); + if (!GTK_WIDGET_MAPPED (dialog)) + { +#if 0 + /* FIXME: the code to restore the position does not work yet. It is not + * clear whether it is actually desirable --- if enabled, applications + * would not be able to say "center the file chooser on top of my toplevel + * window". So, we don't use this code at all. + */ + load_position (&xpos, &ypos); + if (xpos >= 0 && ypos >= 0) + { + gtk_window_set_position (GTK_WINDOW (dialog), GTK_WIN_POS_NONE); + gtk_window_move (GTK_WINDOW (dialog), xpos, ypos); + } +#endif + } } static void |