1 \section{\class{wxIndividualLayoutConstraint
}}\label{wxindividuallayoutconstraint
} 
   3 Objects of this class are stored in the wxIndividualLayoutConstraint class
 
   4 as one of eight possible constraints that a window can be involved in.
 
   6 Constraints are initially set to have the relationship wxUnconstrained,
 
   7 which means that their values should be calculated by looking at known constraints.
 
   9 \wxheading{Derived from
} 
  11 \helpref{wxObject
}{wxobject
} 
  15 \helpref{Overview and examples
}{constraintsoverview
},
\rtfsp 
  16 \helpref{wxLayoutConstraints
}{wxlayoutconstraints
}, 
\helpref{wxWindow::SetConstraints
}{wxwindowsetconstraints
}.
 
  18 \latexignore{\rtfignore{\wxheading{Members
}}} 
  20 \subsection{Edges and relationships
} 
  22 TODO: put this in a different section.
 
  24 The 
{\it wxEdge
}\index{wxEdge
} enumerated type specifies the type of edge or dimension of a window.
 
  26 \begin{twocollist
}\itemsep=
0pt
 
  27 \twocolitem{wxLeft
}{The left edge.
} 
  28 \twocolitem{wxTop
}{The top edge.
} 
  29 \twocolitem{wxRight
}{The right edge.
} 
  30 \twocolitem{wxBottom
}{The bottom edge.
} 
  31 \twocolitem{wxCentreX
}{The x-coordinate of the centre of the window.
} 
  32 \twocolitem{wxCentreY
}{The y-coordinate of the centre of the window.
} 
  35 The 
{\it wxRelationship
}\index{wxRelationship
} enumerated type specifies the relationship that
 
  36 this edge or dimension has with another specified edge or dimension. Normally, the user
 
  37 doesn't use these directly because functions such as 
{\it Below
} and 
{\it RightOf
} are a convenience
 
  38 for using the more general 
{\it Set
} function.
 
  40 \begin{twocollist
}\itemsep=
0pt
 
  41 \twocolitem{wxUnconstrained
}{The edge or dimension is unconstrained (the default for edges.
} 
  42 \twocolitem{wxAsIs
}{The edge or dimension is to be taken from the current window position or size (the
 
  43 default for dimensions.
} 
  44 \twocolitem{wxAbove
}{The edge should be above another edge.
} 
  45 \twocolitem{wxBelow
}{The edge should be below another edge.
} 
  46 \twocolitem{wxLeftOf
}{The edge should be to the left of another edge.
} 
  47 \twocolitem{wxRightOf
}{The edge should be to the right of another edge.
} 
  48 \twocolitem{wxSameAs
}{The edge or dimension should be the same as another edge or dimension.
} 
  49 \twocolitem{wxPercentOf
}{The edge or dimension should be a percentage of another edge or dimension.
} 
  50 \twocolitem{wxAbsolute
}{The edge or dimension should be a given absolute value.
} 
  53 \membersection{wxIndividualLayoutConstraint::wxIndividualLayoutConstraint
} 
  55 \func{void
}{wxIndividualLayoutConstraint
}{\void} 
  57 Constructor. Not used by the end-user.
 
  59 \membersection{wxIndividualLayoutConstraint::Above
} 
  61 \func{void
}{Above
}{\param{wxWindow *
}{otherWin
}, 
\param{int
}{ margin = 
0}} 
  63 Constrains this edge to be above the given window, with an
 
  64 optional margin. Implicitly, this is relative to the top edge of the other window.
 
  66 \membersection{wxIndividualLayoutConstraint::Absolute
} 
  68 \func{void
}{Absolute
}{\param{int
}{ value
}} 
  70 Constrains this edge or dimension to be the given absolute value.
 
  72 \membersection{wxIndividualLayoutConstraint::AsIs
} 
  74 \func{void
}{AsIs
}{\void} 
  76 Sets this edge or constraint to be whatever the window's value is
 
  77 at the moment. If either of the width and height constraints
 
  78 are 
{\it as is
}, the window will not be resized, but moved instead.
 
  79 This is important when considering panel items which are intended
 
  80 to have a default size, such as a button, which may take its size
 
  81 from the size of the button label.
 
  83 \membersection{wxIndividualLayoutConstraint::Below
} 
  85 \func{void
}{Below
}{\param{wxWindow *
}{otherWin
}, 
\param{int
}{ margin = 
0}} 
  87 Constrains this edge to be below the given window, with an
 
  88 optional margin. Implicitly, this is relative to the bottom edge of the other window.
 
  90 \membersection{wxIndividualLayoutConstraint::Unconstrained
} 
  92 \func{void
}{Unconstrained
}{\void} 
  94 Sets this edge or dimension to be unconstrained, that is, dependent on
 
  95 other edges and dimensions from which this value can be deduced.
 
  97 \membersection{wxIndividualLayoutConstraint::LeftOf
} 
  99 \func{void
}{LeftOf
}{\param{wxWindow *
}{otherWin
}, 
\param{int
}{ margin = 
0}} 
 101 Constrains this edge to be to the left of the given window, with an
 
 102 optional margin. Implicitly, this is relative to the left edge of the other window.
 
 104 \membersection{wxIndividualLayoutConstraint::PercentOf
} 
 106 \func{void
}{PercentOf
}{\param{wxWindow *
}{otherWin
}, 
\param{wxEdge
}{ edge
}, 
\param{int
}{ margin = 
0}} 
 108 Constrains this edge or dimension to be to a percentage of the given window, with an
 
 111 \membersection{wxIndividualLayoutConstraint::RightOf
} 
 113 \func{void
}{RightOf
}{\param{wxWindow *
}{otherWin
}, 
\param{int
}{ margin = 
0}} 
 115 Constrains this edge to be to the right of the given window, with an
 
 116 optional margin. Implicitly, this is relative to the right edge of the other window.
 
 118 \membersection{wxIndividualLayoutConstraint::SameAs
} 
 120 \func{void
}{SameAs
}{\param{wxWindow *
}{otherWin
}, 
\param{wxEdge
}{ edge
}, 
\param{int
}{ margin = 
0}} 
 122 Constrains this edge or dimension to be to the same as the edge of the given window, with an
 
 125 \membersection{wxIndividualLayoutConstraint::Set
} 
 127 \func{void
}{Set
}{\param{wxRelationship
}{ rel
}, 
\param{wxWindow *
}{otherWin
}, 
\param{wxEdge
}{ otherEdge
},
 
 128  \param{int
}{ value = 
0}, 
\param{int
}{ margin = 
0}} 
 130 Sets the properties of the constraint. Normally called by one of the convenience
 
 131 functions such as Above, RightOf, SameAs.