1Tk_MaintainGeometry(3)       Tk Library Procedures      Tk_MaintainGeometry(3)
2
3
4
5______________________________________________________________________________
6

NAME

8       Tk_MaintainGeometry,  Tk_UnmaintainGeometry  - maintain geometry of one
9       window relative to another
10

SYNOPSIS

12       #include <tk.h>
13
14       Tk_MaintainGeometry(slave, master, x, y, width, height)
15
16       Tk_UnmaintainGeometry(slave, master)
17

ARGUMENTS

19       Tk_Window   slave    (in)      Window whose  geometry  is  to  be  con‐
20                                      trolled.
21
22       Tk_Window   master   (in)      Window  relative to which slave's geome‐
23                                      try will be controlled.
24
25       int         x        (in)      Desired x-coordinate of slave in master,
26                                      measured  in  pixels  from the inside of
27                                      master's left border to the  outside  of
28                                      slave's left border.
29
30       int         y        (in)      Desired y-coordinate of slave in master,
31                                      measured in pixels from  the  inside  of
32                                      master's  top  border  to the outside of
33                                      slave's top border.
34
35       int         width    (in)      Desired width for slave, in pixels.
36
37       int         height   (in)      Desired height for slave, in pixels.
38_________________________________________________________________
39
40

DESCRIPTION

42       Tk_MaintainGeometry and Tk_UnmaintainGeometry make it easier for geome‐
43       try  managers  to deal with slaves whose masters are not their parents.
44       Three problems arise if the master for a slave is not its parent:
45
46       [1]    The x- and y-position of the slave must be translated  from  the
47              coordinate  system  of  the  master to that of the parent before
48              positioning the slave.
49
50       [2]    If the master window, or any of its ancestors up to the  slave's
51              parent, is moved, then the slave must be repositioned within its
52              parent in order to maintain the correct position relative to the
53              master.
54
55       [3]    If  the  master  or  one of its ancestors is mapped or unmapped,
56              then the slave must be mapped or unmapped to correspond.
57
58       None of these problems is an issue if the parent  and  master  are  the
59       same.   For example, if the master or one of its ancestors is unmapped,
60       the slave is automatically removed by the screen by X.
61
62       Tk_MaintainGeometry deals with these problems for slaves whose  masters
63       aren't  their  parents,  as well as handling the simpler case of slaves
64       whose masters are  their  parents.   Tk_MaintainGeometry  is  typically
65       called  by a window manager once it has decided where a slave should be
66       positioned relative to its master.  Tk_MaintainGeometry translates  the
67       coordinates  to  the coordinate system of slave's parent and then moves
68       and resizes the slave appropriately.   Furthermore,  it  remembers  the
69       desired  position  and creates event handlers to monitor the master and
70       all of its ancestors up to (but not including) the slave's parent.   If
71       any  of  these windows is moved, mapped, or unmapped, the slave will be
72       adjusted so that it is mapped only when the master is  mapped  and  its
73       geometry  relative  to  the master remains as specified by x, y, width,
74       and height.
75
76       When a window manager relinquishes control over  a  window,  or  if  it
77       decides  that it does not want the window to appear on the screen under
78       any conditions, it calls Tk_UnmaintainGeometry.   Tk_UnmaintainGeometry
79       unmaps the window and cancels any previous calls to Tk_MaintainGeometry
80       for the master-slave pair, so that  the  slave's  geometry  and  mapped
81       state  are  no  longer maintained automatically.  Tk_UnmaintainGeometry
82       need not be called by a geometry manager if the slave, the  master,  or
83       any  of the master's ancestors is destroyed:  Tk will call it automati‐
84       cally.
85
86       If Tk_MaintainGeometry is called repeatedly for the  same  master-slave
87       pair,  the  information  from the most recent call supersedes any older
88       information.  If Tk_UnmaintainGeometry is  called  for  a  master-slave
89       pair that is isn't currently managed, the call has no effect.
90
91

KEYWORDS

93       geometry manager, map, master, parent, position, slave, unmap
94
95
96
97Tk                                    4.0               Tk_MaintainGeometry(3)
Impressum