Form man page on IRIX

Man page or keyword search:  
man Server   31559 pages
apropos Keyword Search (all sections)
Output format
IRIX logo
[printable version]



     tixForm(n)			 Tix (4.0)		    tixForm(n)

     _________________________________________________________________

     NAME
	  tixForm - Geometry manager based on attachment rules

     SYNOPSIS
	  tixForm option arg ?arg ...?
     _________________________________________________________________

     DESCRIPTION
	  The tixForm command is used to communicate with the  tixForm
	  Geometry  Manager,  a	 geometry  manager  that  arranges the
	  geometry of the children in a	 parent	 window	 according  to
	  attachment  rules.  The  tixForm  geometry  manager  is very
	  flexible and powerful; it can be used	 to  emulate  all  the
	  existing  features  of  the  Tk  packer  and placer geometry
	  managers (see pack(n), place(n)).  The tixForm  command  can
	  have any of several forms, depending on the option argument:

	  tixForm slave ?options?
	       If the first argument to tixForm is a window name  (any
	       value   starting	 with  ``.''),	then  the  command  is
	       processed in the same way as tixForm configure.

	  tixForm check master
	       This  command  checks   whether	 there	 is   circular
	       dependency  in  the  attachments of the master's slaves
	       (see the section CIRCULAR DEPENDENCY below). It returns
	       the   Boolean   value  TRUE  if	it  discover  circular
	       dependency and FALSE otherwise.

	  tixForm configure slave ?-option value ...?
	       Sets or adjusts the  attachment	values	of  the	 slave
	       window according to the -option value argument pairs.

	       -b attachment
		    Abbreviation for the -bottom option.

	       -bottom attachment
		    Specifies an attachment for the bottom edge of the
		    slave   window.   The   attachment	 must  specied
		    according to the  section  SPECIFYING  ATTACHMENTS
		    below.

	       -bottomspring weight
		    Specifies the weight of the spring at  the	bottom
		    edge  of  the  slave window. See the section USING
		    SPRINGS below.

	       -bp value
		    Abbreviation for the -padbottom option.

     Page 1					    (printed 12/22/98)

     tixForm(n)			 Tix (4.0)		    tixForm(n)

	       -bs weight
		    Abbreviation for the -bottomspring option.

	       -fill master
		    Specifies the fillings when springs are  used  for
		    this widget. The value must be x, y, both or none.

	       -in master
		    Places the slave window into the specified	master
		    window.  If	 the  slave  was originally in another
		    master window, all attachment values with  respect
		    to	the original master window are discarded. Even
		    if the attachment values are the same  as  in  the
		    original  master window, they need to be specified
		    again.  The -in flag, when needed, must appear  as
		    the	 first	flag  after  the  name	of  the slave.
		    Otherwise an error is generated.

	       -l attachment
		    Abbreviation for the -left option.

	       -left attachment
		    Specifies an attachment for the left edge  of  the
		    slave   window.   The   attachment	 must  specied
		    according to the  section  SPECIFYING  ATTACHMENTS
		    below.

	       -leftspring weight
		    Specifies the weight of the	 spring	 at  the  left
		    edge  of  the  slave window. See the section USING
		    SPRINGS below.

	       -lp value
		    Abbreviation for the -padleft option.

	       -ls weight
		    Abbreviation for the -leftspring option.

	       -padbottom value
		    Specifies the amount of external padding to	 leave
		    on	the  bottom  side  of the slave. The value may
		    have   any	 of   the    forms    acceptable    to
		    Tk_GetPixels(3).

	       -padleft value
		    Specifies the amount of external padding to	 leave
		    on the left side of the slave.

	       -padright value
		    Specifies the amount of external padding to	 leave
		    on the right side of the slave.

     Page 2					    (printed 12/22/98)

     tixForm(n)			 Tix (4.0)		    tixForm(n)

	       -padtop value
		    Specifies the amount of external padding to	 leave
		    on the top side of the slave.

	       -padx value
		    Specifies the amount of external padding to	 leave
		    on both the left and the right sides of the slave.

	       -pady value
		    Specifies the amount of external padding to	 leave
		    on both the top and the bottom sides of the slave.

	       -r attachment
		    Abbreviation for the -right option.

	       -right attachment
		    Specifies an attachment for the right edge of  the
		    slave   window.   The   attachment	 must  specied
		    according to the  section  SPECIFYING  ATTACHMENTS
		    below.

	       -rightspring weight
		    Specifies the weight of the spring	at  the	 right
		    edge  of  the  slave window. See the section USING
		    SPRINGS below.

	       -rp value
		    Abbreviation for the -padright option.

	       -rs weight
		    Abbreviation for the -rightspring option.

	       -t attachment
		    Abbreviation for the -top option.

	       -top attachment
		    Specifies an attachment for the top	 edge  of  the
		    slave   window.   The   attachment	 must  specied
		    according to the  section  SPECIFYING  ATTACHMENTS
		    below.

	       -topspring weight
		    Specifies the weight of the spring at the top edge
		    of the slave window. See the section USING SPRINGS
		    below.

	       -tp value
		    Abbreviation for the -padtop option.

	       -ts weight
		    Abbreviation for the -topspring option.

     Page 3					    (printed 12/22/98)

     tixForm(n)			 Tix (4.0)		    tixForm(n)

	  tixForm forget slave ?slave ...?
	       Removes each of the slaves from its master  and	unmaps
	       their windows.  The slaves will no longer be managed by
	       tixForm. All attachment values with  respect  to	 their
	       master  windows	are  discarded.	 If  another  slave is
	       attached to this slave,	then  the  attachment  of  the
	       other slave will be changed to grid attachment based on
	       its geometry.

	  tixForm grid master ?x_size y_size?
	       When x_size and y_size are given, this command  returns
	       the  number  of grids of the master window in a pair of
	       integers of the form {x_size y_size}. When both	x_size
	       and  y_size  are given, this command changes the number
	       of horizontal and vertical grids on the master window.

	  tixForm info slave ?option?
	       Queries the  attachment	options	 of  a	slave  window.
	       option  can  be	any  of	 the  options  accepted by the
	       tixForm configure command. If option is given, only the
	       value  of  that	option	is  returned.  Otherwise, this
	       command returns a list whose elements are  the  current
	       configuration  state  of	 the  slave  given in the same
	       option-value form that might be	specified  to  tixForm
	       configure. The first two elements in this list list are
	       "-in master" where master is the slave's master window.

	  tixForm slaves master
	       Returns a list of all of	 the  slaves  for  the	master
	       window. The order of the slaves in the list is the same
	       as their order in the packing order. If master  has  no
	       slaves then an empty string is returned.

     SPECIFYING ATTACHMENTS
	  One can specify an attachment	 for  each  side  of  a	 slave
	  window managed by tixForm. An attachment is specified in the
	  the form "-side {anchor_point offset}". -side can be one  of
	  -top, -bottom, -left or -right.

	  Offset is given in screen  units  (i.e.  any	of  the	 forms
	  acceptable  to  Tk_GetPixels).   A positive offset indicates
	  shifting to a position to the right or bottom of  an	anchor
	  point. A negative offset indicates shifting to a position to
	  the left or top of an anchor point.

	  Anchor_point can be given in one of the following forms:

	       Grid Attachment
		    The master window is  divided  into	 a  number  of
		    horizontal	and  vertical  grids.  By  default the
		    master window is divided into 100x100  grids;  the
		    number  of	grids  can  be adjusted by the tixForm

     Page 4					    (printed 12/22/98)

     tixForm(n)			 Tix (4.0)		    tixForm(n)

		    grid command. A grid attachment  anchor  point  is
		    given  by  a  % sign followed by an integer value.
		    For example, %0 spceifies the first grid line (the
		    top	 or  left  edge	 of  the  master window). %100
		    spceifies the last grid line (the bottom or	 right
		    edge of the master window).

	       Opposite Side Attachment
		    Opposite  attachment  specifies  an	 anchor	 point
		    located  on	 the  opposite	side  of another slave
		    widget, which must be managed by  tixForm  in  the
		    same  master window. An opposite attachment anchor
		    point is given by the name of another widget.  For
		    example, "tixForm .b -top {.a 0}" attaches the top
		    side of the widget .b to the bottom of the	widget
		    .a.

	       Parallel Side Attachment
		    Opposite  attachment  specifies  an	 anchor	 point
		    located  on the same side of another slave widget,
		    which must be  managed  by	tixForm	 in  the  same
		    master window. An parallel attachment anchor point
		    is given by the sign &  follwed  by	 the  name  of
		    another  widget.   For  example,  "tixForm .b -top
		    {&.a 0}" attaches the top side of the widget .b to
		    the	 top of the widget .a, making the top sides of
		    these two widgets at the same vertical position in
		    their parent window.

	       No Attachment
		    Specifies a side of the slave to  be  attached  to
		    nothing,  indicated	 by the keyword none. When the
		    none anchor point is given,	 the  offser  must  be
		    zero.

		    When a side of a slave is attached	to  {none  0},
		    the	 position  of  this  side is calculated by the
		    position of the other side and the natural size of
		    the	 slave.	 For  example, if a the left side of a
		    widget is attached to {%0  100},  its  right  side
		    attached  to {none 0}, and the natural size of the
		    widget is 50 pixels, the right side of the	widget
		    will be positioned at pixel {%0 149}.

		    When both -top and -bottom are attached  to	 none,
		    then  by  default -top will be attached to {%0 0}.
		    When both -left and -right are attached  to	 none,
		    then by default -left will be attached to {%0 0}.

	  Shifting effects can be achieved by  specifying  a  non-zero
	  offset  with	an anchor point. In the following example, the
	  top side of widget .b is attached to the bottom of .a; hence

     Page 5					    (printed 12/22/98)

     tixForm(n)			 Tix (4.0)		    tixForm(n)

	  .b  always  appears  below .a.  Also, the left edge of .b is
	  attached to the left side of .a  with	 a  10	pixel  offest.
	  Therefore,  the  left edge of .b is always shifted 10 pixels
	  to the right of .a's left edge:

		  tixForm .b -left {.a 10} -top {.a 0}

	  ABBREVIATIONS: Certain abbreviations	can  be	 made  on  the
	  attachment  specifications:  First  an offset of zero can be
	  omitted.  Thus, the following two lines are equivalent:

		  tixForm .b -top {.a 0} -right {%100 0}
		  tixForm .b -top {.a}	 -right {%100}

	  Also, because of the way TCL handles lists,  when  you  omit
	  the  offset,	you  can also leave out the braces. So you can
	  further simplify the above to:

		  tixForm .b -top .a -right %100

	  In the second case, when the anchor point  is	 omitted,  the
	  offset  must	be  given.  A  default	anchor point is chosen
	  according to the value of the offset. If the anchor point is
	  0  or	 positive,  the default anchor point %0 is used; thus,
	  "tixForm .b -top 15" attaches	 the  top  edge	 of  .b	 to  a
	  position  15 pixels below the top edge of the master window.
	  If the anchor point is "-0" or negative, the default	anchor
	  point	 %100  is  used; thus, "tixForm .a -right -2" attaches
	  the right edge of .a to a position 2 pixels to the  left  of
	  the  master  window's	 right edge.  An further example below
	  shows a command with its equivalent abbreviation.

		  tixForm .b -top {%0 10} -bottom {%100 0}
		  tixForm .b -top 10	  -bottom -0

     USING SPRINGS
	  To be written.

     ALGORITHM OF TIXFORM
	  TixForm starts with any slave in the list of slaves  of  the
	  master  window.  Then	 it tries to determine the position of
	  each side of the slave.

	  If the attachment of a side of the slave is grid attachment,
	  the position of the side is readily determined.

	  If the attachment of this side is none, then	tixForm	 tries
	  to  determine	 the  position of the opposite side first, and
	  then use the position of the opposite side and  the  natural
	  size of the slave to determine the position of this side.

	  If  the  attachment	is   opposite	or   parallel	widget

     Page 6					    (printed 12/22/98)

     tixForm(n)			 Tix (4.0)		    tixForm(n)

	  attachments,	then  tixForm tries to determine the positions
	  of the other widget first, and then use the positions of the
	  other widget and the natural size of the slave determine the
	  position of this side. This recursive algorithmis carried on
	  until the positions of all slaves are determined.

     CIRCULAR DEPENDENCY
	  The algorithm of tixForm will fail if a circular  dependency
	  exists in the attachments of the slaves. For example:

	       tixForm .c -left .b
	       tixForm .b -right .c

	  In this example, the position of the left side of .b depends
	  on  the  right side of .c, which in turn depends on the left
	  side of .b.

	  When	a  circular  dependency	 is  discovered	  during   the
	  execution  of the tixForm algorithm, tixForm will generate a
	  background  error  and  the  geometry	 of  the  slaves   are
	  undefined  (and will be arbitrary). Notice that tixForm only
	  executes the algorithm when the specification of the slaves'
	  attachments  is complete.  Therefore, it allows intermediate
	  states of circular dependency during	the  specification  of
	  the  slaves'	attachments.   Also,  unlike  the  Motif  Form
	  manager  widget,  tixForm  defines  circular	dependency  as
	  "dependency in the same dimension". Therefore, the following
	  code fragment will does not have circular dependency because
	  the  two  widgets  do	 not  depend on each other in the same
	  dimension (.b depends .c in the horizontal dimension and  .c
	  depends on .b in the vertical dimension):

		  tixForm .b -left .c
		  tixForm .c -top .b

     BUGS
	  Springs have not been fully implemented yet.

     KEYWORDS
	  Tix(n), Form, Geometry Management

     Page 7					    (printed 12/22/98)

[top]

List of man pages available for IRIX

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net