diff options
author | Havoc Pennington <hp@pobox.com> | 2001-08-10 03:46:08 +0000 |
---|---|---|
committer | Havoc Pennington <hp@src.gnome.org> | 2001-08-10 03:46:08 +0000 |
commit | f37a0627fc3fe7676dc38b8c32856e375be59de1 (patch) | |
tree | 3246680255da5aa2ed168d8deb17a6f2a6c7343f /docs | |
parent | 439cd9a3a505424ea64d099ecbe1b4c910b79649 (diff) | |
download | gtk+-f37a0627fc3fe7676dc38b8c32856e375be59de1.tar.gz |
fix a typo.
2001-08-07 Havoc Pennington <hp@pobox.com>
* gtk/gtkfilesel.c (open_ref_dir): fix a typo.
* gtk/gtkplug.c (gtk_plug_init): remove setting of auto_shrink;
some fixage is needed here, but nothing simple. Owen understands
it. ;-)
* gtk/gtkwindow.h, gtk/gtkwindow.c: Rework code and API for window
sizing and positioning. Also, fix bug in compute_geometry_hints
(width/height confusion for setting min size).
(gtk_window_move): new function
(gtk_window_resize): new function
(gtk_window_get_size): new function
(gtk_window_get_position): new function
(gtk_window_parse_geometry): new function
* gtk/gtkwidget.c (gtk_widget_set_size_request): new function
(gtk_widget_get_size_request): new function
(gtk_widget_get_usize): delete, that was a short-lived function
;-)
(gtk_widget_set_usize): deprecate
(gtk_widget_set_uposition): deprecate, make it a trivial
gtk_window_move() wrapper
(gtk_widget_class_init): remove x/y/width/height properties,
add width_request height_request
* demos/*: update to avoid deprecated functions
* gtk/gtklayout.c: add x/y child properties
* gtk/gtkfixed.c: add x/y child properties, and get rid of
uses of "gint16"
* tests/testgtk.c (create_window_sizing): lots of tweaks to window
sizing test
* gdk/x11/gdkevents-x11.c (gdk_event_translate): Ensure that
configure events on toplevel windows are always in root window
coordinates, following ICCCM spec that all synthetic events
are in root window coords already, while real events are
in parent window coords. Previously the code assumed that
coords of 0,0 were parent window coords, which was
really broken.
* gtk/gtkcontainer.c (gtk_container_get_focus_chain): fix
warning
* gdk/gdkwindow.h (GdkWindowHints): add GDK_HINT_USER_POS
and GDK_HINT_USER_SIZE so we can set USSize and USPosition
hints in gtk_window_parse_geometry()
* gdk/x11/gdkwindow-x11.c (gdk_window_set_geometry_hints): support
new USER_POS USER_SIZE hints
Diffstat (limited to 'docs')
-rw-r--r-- | docs/Changes-2.0.txt | 16 | ||||
-rw-r--r-- | docs/reference/gdk/tmpl/windows.sgml | 2 | ||||
-rw-r--r-- | docs/reference/gtk/tmpl/gtk-unused.sgml | 30 | ||||
-rw-r--r-- | docs/reference/gtk/tmpl/gtkrc.sgml | 1 | ||||
-rw-r--r-- | docs/reference/gtk/tmpl/gtkwidget.sgml | 14 | ||||
-rw-r--r-- | docs/reference/gtk/tmpl/gtkwindow.sgml | 5 | ||||
-rw-r--r-- | docs/sizing-test.txt | 121 |
7 files changed, 171 insertions, 18 deletions
diff --git a/docs/Changes-2.0.txt b/docs/Changes-2.0.txt index ffce736df0..9b82b2d85a 100644 --- a/docs/Changes-2.0.txt +++ b/docs/Changes-2.0.txt @@ -397,6 +397,22 @@ Incompatible Changes from GTK+-1.2 to GTK+-2.0: using gdk_image_get() should really be ported to gdk_pixbuf_get_from_drawable(). +* gtk_widget_set_usize() has been renamed to + gtk_widget_set_size_request(), however the old name still exists + unless you define GTK_DISABLE_DEPRECATED. + +* gtk_widget_set_uposition() is deprecated; use gtk_window_move(), + gtk_fixed_put(), or gtk_layout_put() instead. + +* gtk_window_set_policy() is deprecated. To get the effect of + "allow_shrink", call gtk_widget_set_size_request(window, 0, 0). To + get the effect of "allow_grow", call + gtk_window_set_resizable(window, TRUE). You didn't want the effect + of auto_shrink, it made no sense. But maybe if you were using it you + want to use gtk_window_resize (window, 1, 1) to snap a window back + to its minimum size (the 1, 1 will be rounded up to the minimum + window size). + * The core GTK+ now takes care of handling mapping, unmapping and realizing the child widgets of containers in gtk_widget_set_parent(). In most cases, this allows container diff --git a/docs/reference/gdk/tmpl/windows.sgml b/docs/reference/gdk/tmpl/windows.sgml index 78e0bc8f11..c21b8f46f2 100644 --- a/docs/reference/gdk/tmpl/windows.sgml +++ b/docs/reference/gdk/tmpl/windows.sgml @@ -87,6 +87,8 @@ Windows @GDK_HINT_ASPECT: @GDK_HINT_RESIZE_INC: @GDK_HINT_WIN_GRAVITY: +@GDK_HINT_USER_POS: +@GDK_HINT_USER_SIZE: <!-- ##### STRUCT GdkGeometry ##### --> <para> diff --git a/docs/reference/gtk/tmpl/gtk-unused.sgml b/docs/reference/gtk/tmpl/gtk-unused.sgml index 8c126874d3..3c9c63eebe 100644 --- a/docs/reference/gtk/tmpl/gtk-unused.sgml +++ b/docs/reference/gtk/tmpl/gtk-unused.sgml @@ -1004,6 +1004,36 @@ the #GtkAdjustment which sets the range of the scale. @widget: the object which received the signal. +<!-- ##### ARG GtkWidget:height ##### --> +<para> + +</para> + + +<!-- ##### ARG GtkWidget:width ##### --> +<para> + +</para> + + +<!-- ##### ARG GtkWidget:x ##### --> +<para> + +</para> + + +<!-- ##### ARG GtkWidget:y ##### --> +<para> + +</para> + + +<!-- ##### ARG GtkWindow:auto-shrink ##### --> +<para> +If the window shrinks automatically when widgets within it shrink. +</para> + + <!-- ##### FUNCTION gtk_arg_copy ##### --> <para> It will either copy data into an existing argument or allocate a new argument diff --git a/docs/reference/gtk/tmpl/gtkrc.sgml b/docs/reference/gtk/tmpl/gtkrc.sgml index cc0b23b6d2..30ffca8235 100644 --- a/docs/reference/gtk/tmpl/gtkrc.sgml +++ b/docs/reference/gtk/tmpl/gtkrc.sgml @@ -495,7 +495,6 @@ This can later be composited together with other #GtkRcStyle structures to form a #GtkStyle. </para> -@parent_instance: @name: @bg_pixmap_name: @font_desc: diff --git a/docs/reference/gtk/tmpl/gtkwidget.sgml b/docs/reference/gtk/tmpl/gtkwidget.sgml index 01e7f0763b..b92fb889ee 100644 --- a/docs/reference/gtk/tmpl/gtkwidget.sgml +++ b/docs/reference/gtk/tmpl/gtkwidget.sgml @@ -1874,22 +1874,12 @@ a widget changes from un-anchored to anchored or vice-versa. </para> -<!-- ##### ARG GtkWidget:x ##### --> +<!-- ##### ARG GtkWidget:width-request ##### --> <para> </para> -<!-- ##### ARG GtkWidget:y ##### --> -<para> - -</para> - -<!-- ##### ARG GtkWidget:width ##### --> -<para> - -</para> - -<!-- ##### ARG GtkWidget:height ##### --> +<!-- ##### ARG GtkWidget:height-request ##### --> <para> </para> diff --git a/docs/reference/gtk/tmpl/gtkwindow.sgml b/docs/reference/gtk/tmpl/gtkwindow.sgml index 7d43fb870a..3fb16a1c65 100644 --- a/docs/reference/gtk/tmpl/gtkwindow.sgml +++ b/docs/reference/gtk/tmpl/gtkwindow.sgml @@ -509,11 +509,6 @@ The type of the window. The title of the window. </para> -<!-- ##### ARG GtkWindow:auto-shrink ##### --> -<para> -If the window shrinks automatically when widgets within it shrink. -</para> - <!-- ##### ARG GtkWindow:allow-shrink ##### --> <para> If the window can be resized to a smaller size by the user. diff --git a/docs/sizing-test.txt b/docs/sizing-test.txt new file mode 100644 index 0000000000..6954612d44 --- /dev/null +++ b/docs/sizing-test.txt @@ -0,0 +1,121 @@ +This is a list of things to check when testing window size/pos functions. +=== + +gtk_widget_set_size_request(): + - causes the widget to request the given size + - for toplevel windows, changes the default-requested size if + no default size is set and gtk_window_resize() has not been called + - passing -1 for either width or height reverts to "natural" request + in that dimension + - passing 0 is allowed, and results in requisition of 1x1 + (0x0 is a permitted requisition, but equivalent to 1x1, + we use 1x1 for implementation convenience) + - causes notifies on width_request, height_request properties + +gtk_window_resize(): + - causes a configure request in all cases if the window is mapped, + unless the new size is the same as the old size + - overrides the default size on map if the window is unmapped + - allows size of 0, equivalent to 1 + - clamped to geometry hints + +gtk_window_set_default_size(): + - has no effect after the window has been mapped the first time, + unless the window has been unrealized in which case it should + have an effect + - allows size of 0, equivalent to 1 + - allows size of -1 to unset the default size + - clamped to geometry hints + - gtk_window_resize() overrides it + - causes notifies on default_width, default_height properties + +gtk_window_get_default_size(): + - returns the values last passed to set_default_size(), including + -1. If set_default_size() has not been called, returns -1. + +gtk_window_move(): + - always causes a configure request if the window is mapped, + unless the last configure request we sent was for the same + position being moved to + - position may be negative to move windows offscreen + - if GTK_WIN_POS_CENTER_ALWAYS (or other future position + constraints we may add) is in effect, the move + request is clamped to obey the constraints. thus + calling gtk_window_move() on a CENTER_ALWAYS window + may trigger the window to bounce back to center if it + wasn't there + - overrides all GTK_WIN_POS_ except CENTER_ALWAYS + +gtk_window_get_size(): + - obtains the client-side known size of widget->window, + as last received from a configure event + - prior to mapping, returns the default size we will request + - between realization and mapping, computes default size + rather than looking at widget->window up-to-date size, + so the size will be correct after force-realizing a window + +gtk_window_get_position(): + - obtains the point to be passed to gtk_window_move() in order + to keep the window in its current position + - round-trips to the server to get the position; this is suboptimal + from both a race condition and speed standpoint but required to get + window frame size + - if the window is unmapped, returns the default position we will + request + +gtk_window_set_position(): + - not the inverse of get_position(), sadly + - modifies the default positioning of the window + - if set to CENTER_ALWAYS and the window is mapped, results in a + configure request moving the window to the center, unless the + window was already centered + - ignored if gtk_window_move() called, with the exception + of CENTER_ALWAYS + +gtk_window_parse_geometry(): + - parses a standard X geometry string + - toggles on one or both of GDK_HINT_USER_SIZE, GDK_HINT_USER_POS + - "xprop" shows user size/position are set on the window + - calls gtk_window_set_default_size() to set the window size + - calls gtk_window_move() to set the window position + - calls gtk_window_set_gravity() to set the window gravity + +gtk_window_reshow_with_initial_size(): + - for use by GUI builders; unrealizes and re-shows the window, + using default size (and also position, but position + is reset on any hide anyway) + - window should be positioned and sized as it was on initial map, + barring odd window managers + +gtk_window_set_geometry_hints(): + - if a hint is set with this function, we do not override it + in other parts of the code + +General behavior +=== + + - no infinite loops or nasty fighting-the-user flicker during + operations such as moving/resizing a window + +Properties +=== + +GtkWindow::default_width, GtkWindow::default_height: + - default_width is -1 if unset, or >= 0 if + a default width is set + - default_height is -1 if unset, or >= 0 if + a default height is set + +GtkWindow::allow_grow, GtkWindow::resizable: + - equivalent properties; changing one notifies on the other + - if FALSE, we set the min size to the max size in the geometry + hints. + - If the app programmer has called gtk_window_set_geometry_hints() + however and set min or max size, we don't replace the hint they + set. + +GtkWidget::width_request, GtkWidget::height_request: + - if -1, default requisition of widget is used + - otherwise, override default requisition + + |