1998-07-12 09:21:16 +00:00
|
|
|
\section{\class{wxTreeLayout}}\label{wxtreelayout}
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
wxTreeLayout provides layout of simple trees with one root node, drawn left-to-right,
|
|
|
|
with user-defined spacing between nodes.
|
|
|
|
|
|
|
|
wxTreeLayout is an abstract class that must be subclassed. The programmer
|
|
|
|
defines various member functions which will access whatever data structures
|
|
|
|
are appropriate for the application, and wxTreeLayout uses these when laying
|
|
|
|
out the tree.
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
Nodes are identified by long integer identifiers. The derived class
|
2000-02-28 13:42:59 +00:00
|
|
|
communicates the actual tree structure to wxTreeLayout by defining \helpref{wxTreeLayout::GetChildren}{wxtreelayoutgetchildren}\rtfsp
|
|
|
|
and \helpref{wxTreeLayout::GetNodeParent}{wxtreelayoutgetnodeparent} functions.
|
1998-07-12 09:21:16 +00:00
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
The application should call \helpref{wxTreeLayout::DoLayout}{wxtreelayoutdolayout} to do the tree
|
1998-07-12 09:21:16 +00:00
|
|
|
layout. Depending on how the derived class has been defined, either
|
2000-02-28 15:57:06 +00:00
|
|
|
\rtfsp\helpref{wxTreeLayout::Draw}{wxtreelayoutdraw} must be called (for example by the OnPaint member
|
1998-07-12 09:21:16 +00:00
|
|
|
of a wxScrolledWindow) or the application-defined drawing code should be called
|
|
|
|
as normal.
|
|
|
|
|
|
|
|
For example, if you have an image drawing system already defined, you
|
|
|
|
may want wxTreeLayout to position existing node images in that system. So you
|
|
|
|
just need a way for wxTreeLayout to set the node image positions according to
|
|
|
|
the layout algorithm, and the rest will be done by your own image drawing
|
|
|
|
system.
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
The algorithm is due to Gabriel Robins \cite{robins87}, a linear-time
|
|
|
|
algorithm originally implemented in LISP for AI applications.
|
|
|
|
|
|
|
|
The original algorithm has been modified so that both X and Y planes
|
|
|
|
are calculated simultaneously, increasing efficiency slightly. The basic
|
|
|
|
code is only a page or so long.
|
|
|
|
|
|
|
|
\helponly{Below is the example tree generated by the program test.cc.
|
|
|
|
|
|
|
|
\begin{figure}
|
|
|
|
$$\image{11cm;0cm}{treetst.ps}$$
|
|
|
|
\caption{Example tree}\label{exampletree}
|
|
|
|
\end{figure}
|
|
|
|
}
|
|
|
|
|
1998-07-12 09:21:16 +00:00
|
|
|
\wxheading{Derived from}
|
|
|
|
|
|
|
|
wxObject
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\wxheading{See also}
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\helpref{wxTreeLayoutStored}{wxtreelayoutstored}
|
2000-02-28 13:42:59 +00:00
|
|
|
|
1998-07-12 09:21:16 +00:00
|
|
|
\latexignore{\rtfignore{\wxheading{Members}}}
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::wxTreeLayout}
|
|
|
|
|
|
|
|
\func{}{wxTreeLayout}{\void}
|
|
|
|
|
|
|
|
Constructor.
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\membersection{wxTreeLayout::ActivateNode}\label{wxtreelayoutactivatenode}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{void}{ActivateNode}{\param{long}{ id}, \param{bool }{active}}
|
|
|
|
|
|
|
|
Define this so wxTreeLayout can turn nodes on and off for drawing purposes
|
2000-02-28 15:57:06 +00:00
|
|
|
(not all nodes may be connected in the tree). See also \helpref{wxTreeLayout::NodeActive}{wxtreelayoutnodeactive}.
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\membersection{wxTreeLayout::CalcLayout}
|
|
|
|
|
|
|
|
\func{void}{CalcLayout}{\param{long}{ id}, \param{int}{ level}}
|
|
|
|
|
|
|
|
Private function for laying out a branch.
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\membersection{wxTreeLayout::DoLayout}\label{wxtreelayoutdolayout}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{void}{DoLayout}{\param{wxDC\&}{ dc}, \param{long}{ topNode = -1}}
|
|
|
|
|
|
|
|
Calculates the layout for the tree, optionally specifying the top node.
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\membersection{wxTreeLayout::Draw}\label{wxtreelayoutdraw}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{void}{Draw}{\param{wxDC\&}{ dc}}
|
|
|
|
|
|
|
|
Call this to let wxTreeLayout draw the tree itself, once the layout has been
|
2000-02-28 15:57:06 +00:00
|
|
|
calculated with \helpref{wxTreeLayout::DoLayout}{wxtreelayoutdolayout}.
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\membersection{wxTreeLayout::DrawBranch}
|
|
|
|
|
|
|
|
\func{void}{DrawBranch}{\param{long}{ from}, \param{long}{ to}, \param{wxDC\&}{ dc}}
|
|
|
|
|
|
|
|
Defined by wxTreeLayout to draw an arc between two nodes.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::DrawBranches}
|
|
|
|
|
|
|
|
\func{void}{DrawBranches}{\param{wxDC\&}{ dc}}
|
|
|
|
|
|
|
|
Defined by wxTreeLayout to draw the arcs between nodes.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::DrawNode}
|
|
|
|
|
|
|
|
\func{void}{DrawNode}{\param{long}{ id}, \param{wxDC\&}{ dc}}
|
|
|
|
|
|
|
|
Defined by wxTreeLayout to draw a node.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::DrawNodes}
|
|
|
|
|
|
|
|
\func{void}{DrawNodes}{\param{wxDC\&}{ dc}}
|
|
|
|
|
|
|
|
Defined by wxTreeLayout to draw the nodes.
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\membersection{wxTreeLayout::GetChildren}\label{wxtreelayoutgetchildren}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{void}{GetChildren}{\param{long}{ id}, \param{wxList \&}{list}}
|
|
|
|
|
|
|
|
Must be defined to return the children of node {\it id} in the given list
|
|
|
|
of integers.
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\membersection{wxTreeLayout::GetNextNode}\label{wxtreelayoutgetnextnode}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{long}{GetNextNode}{\param{long}{ id}}
|
|
|
|
|
|
|
|
Must be defined to return the next node after {\it id}, so that wxTreeLayout can
|
|
|
|
iterate through all relevant nodes. The ordering is not important.
|
|
|
|
The function should return -1 if there are no more nodes.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetNodeName}
|
|
|
|
|
|
|
|
\constfunc{wxString}{GetNodeName}{\param{long}{ id}}
|
|
|
|
|
|
|
|
May optionally be defined to get a node's name (for example if leaving
|
|
|
|
the drawing to wxTreeLayout).
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetNodeSize}
|
|
|
|
|
|
|
|
\constfunc{void}{GetNodeSize}{\param{long}{ id}, \param{long*}{ x}, \param{long*}{ y}}
|
|
|
|
|
|
|
|
Can be defined to indicate a node's size, or left to wxTreeLayout to use the
|
|
|
|
name as an indication of size.
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\membersection{wxTreeLayout::GetNodeParent}\label{wxtreelayoutgetnodeparent}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\constfunc{long}{GetNodeParent}{\param{long}{ id}}
|
|
|
|
|
|
|
|
Must be defined to return the parent node of {\it id}.
|
|
|
|
The function should return -1 if there is no parent.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetNodeX}
|
|
|
|
|
|
|
|
\constfunc{long}{GetNodeX}{\param{long}{ id}}
|
|
|
|
|
|
|
|
Must be defined to return the current X position of the node. Note that
|
|
|
|
coordinates are assumed to be at the top-left of the node so some conversion
|
|
|
|
may be necessary for your application.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetNodeY}
|
|
|
|
|
|
|
|
\constfunc{long}{GetNodeY}{\param{long}{ id}}
|
|
|
|
|
|
|
|
Must be defined to return the current Y position of the node. Note that
|
|
|
|
coordinates are assumed to be at the top-left of the node so some conversion
|
|
|
|
may be necessary for your application.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetLeftMargin}
|
|
|
|
|
|
|
|
\constfunc{long}{GetLeftMargin}{\void}
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
Gets the left margin set with \helpref{wxTreeLayout::SetMargins}{wxtreelayoutsetmargins}.
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetOrientation}
|
|
|
|
|
|
|
|
\constfunc{bool}{GetOrientation}{\void}
|
|
|
|
|
2003-01-18 00:16:34 +00:00
|
|
|
Gets the orientation: true means top-to-bottom, false means left-to-right (the default).
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetTopMargin}
|
|
|
|
|
|
|
|
\constfunc{long}{GetTopMargin}{\void}
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
Gets the top margin set with \helpref{wxTreeLayout::SetMargins}{wxtreelayoutsetmargins}.
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetTopNode}
|
|
|
|
|
|
|
|
\constfunc{long}{GetTopNode}{\void}
|
|
|
|
|
|
|
|
wxTreeLayout calls this to get the top of the tree. Don't redefine this; call
|
2000-02-28 15:57:06 +00:00
|
|
|
\rtfsp\helpref{wxTreeLayout::SetTopNode}{wxtreelayoutsettopnode} instead before calling \helpref{wxTreeLayout::DoLayout}{wxtreelayoutdolayout}.
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetXSpacing}
|
|
|
|
|
|
|
|
\constfunc{long}{GetXSpacing}{\void}
|
|
|
|
|
|
|
|
Gets the horizontal spacing between nodes.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::GetYSpacing}
|
|
|
|
|
|
|
|
\constfunc{long}{GetYSpacing}{\void}
|
|
|
|
|
|
|
|
Gets the vertical spacing between nodes.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::Initialize}
|
|
|
|
|
|
|
|
\func{void}{Initialize}{\void}
|
|
|
|
|
|
|
|
Initializes wxTreeLayout. Call from application or overridden {\bf Initialize}
|
|
|
|
or constructor.
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\membersection{wxTreeLayout::NodeActive}\label{wxtreelayoutnodeactive}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{bool}{NodeActive}{\param{long}{ id}}
|
|
|
|
|
|
|
|
Define this so wxTreeLayout can know which nodes are to be drawn (not all
|
2000-02-28 15:57:06 +00:00
|
|
|
nodes may be connected in the tree). See also \helpref{wxTreeLayout::ActivateNode}{wxtreelayoutactivatenode}.
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\membersection{wxTreeLayout::SetNodeName}
|
|
|
|
|
|
|
|
\func{void}{SetNodeName}{\param{long}{ id}, \param{const wxString\& }{ name}}
|
|
|
|
|
|
|
|
May optionally be defined to set a node's name.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::SetNodeX}
|
|
|
|
|
|
|
|
\func{void}{SetNodeX}{\param{long}{ id}, \param{long}{ x}}
|
|
|
|
|
|
|
|
Must be defined to set the current X position of the node. Note that
|
|
|
|
coordinates are assumed to be at the top-left of the node so some conversion
|
|
|
|
may be necessary for your application.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::SetNodeY}
|
|
|
|
|
|
|
|
\func{void}{SetNodeY}{\param{long}{ id}, \param{long}{ y}}
|
|
|
|
|
|
|
|
Must be defined to set the current Y position of the node. Note that
|
|
|
|
coordinates are assumed to be at the top-left of the node so some conversion
|
|
|
|
may be necessary for your application.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::SetOrientation}
|
|
|
|
|
|
|
|
\func{void}{SetOrientation}{\param{bool}{ orientation}}
|
|
|
|
|
2003-01-18 00:16:34 +00:00
|
|
|
Sets the tree orientation: true means top-to-bottom, false means left-to-right (the default).
|
1998-07-12 09:21:16 +00:00
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\membersection{wxTreeLayout::SetTopNode}\label{wxtreelayoutsettopnode}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{void}{SetTopNode}{\param{long}{ id}}
|
|
|
|
|
|
|
|
Call this to identify the top of the tree to wxTreeLayout.
|
|
|
|
|
|
|
|
\membersection{wxTreeLayout::SetSpacing}
|
|
|
|
|
|
|
|
\func{void}{SetSpacing}{\param{long}{ x}, \param{long}{ y}}
|
|
|
|
|
|
|
|
Sets the horizontal and vertical spacing between nodes in the tree.
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\membersection{wxTreeLayout::SetMargins}\label{wxtreelayoutsetmargins}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{void}{SetMargins}{\param{long}{ x}, \param{long}{ y}}
|
|
|
|
|
|
|
|
Sets the left and top margins of the whole tree.
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\section{\class{wxTreeLayoutStored}}\label{wxtreelayoutstored}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
wxTreeLayoutStored provides storage for node labels, position and client data. It also provides hit-testing
|
1998-07-12 09:21:16 +00:00
|
|
|
(which node a mouse event occurred on). It is usually a more convenient class to use than wxTreeLayout.
|
|
|
|
|
|
|
|
\wxheading{Derived from}
|
|
|
|
|
2000-02-28 13:42:59 +00:00
|
|
|
\helpref{wxTreeLayout}{wxtreelayout}\\
|
|
|
|
\helpref{wxObject}{wxobject}
|
|
|
|
|
|
|
|
\wxheading{See also}
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\helpref{wxTreeLayout}{wxtreelayout}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\latexignore{\rtfignore{\wxheading{Members}}}
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\membersection{wxTreeLayoutStored::wxTreeLayoutStored}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\func{}{wxTreeLayoutStored}{\param{int }{noNodes = 200}}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
Constructor. Specify the maximum number of nodes to be allocated.
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\membersection{wxTreeLayoutStored::AddChild}\label{wxtreelayoutstoredaddchild}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{long}{AddChild}{\param{const wxString\&}{ name}, \param{const wxString\&}{ parent = ""}}
|
|
|
|
|
|
|
|
Adds a child with a given parent, returning the node id.
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\membersection{wxTreeLayoutStored::GetClientData}\label{wxtreelayoutstoredgetclientdata}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\constfunc{long}{GetClientData}{\param{long}{ id}}
|
|
|
|
|
|
|
|
Gets the client data for the given node.
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\membersection{wxTreeLayoutStored::GetNode}\label{wxtreelayoutstoredgetnode}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\constfunc{wxStoredNode*}{GetNode}{\param{long}{ id}}
|
|
|
|
|
|
|
|
Returns the wxStoredNode object for the given node id.
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\membersection{wxTreeLayoutStored::GetNodeCount}\label{wxtreelayoutstoredgetnodecount}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\constfunc{int}{GetNodeCount}{\void}
|
|
|
|
|
|
|
|
Returns the current number of nodes.
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\membersection{wxTreeLayoutStored::GetNumNodes}\label{wxtreelayoutstoredgetnumnodes}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\constfunc{int}{GetNumNodes}{\void}
|
|
|
|
|
|
|
|
Returns the maximum number of nodes.
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\membersection{wxTreeLayoutStored::HitTest}\label{wxtreelayoutstoredhittest}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{wxString}{HitTest}{\param{wxMouseEvent\&}{ event}, \param{wxDC\& }{dc}}
|
|
|
|
|
|
|
|
Returns a string with the node name corresponding to the position of the mouse event, or the empty string if no node
|
|
|
|
was detected.
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\membersection{wxTreeLayoutStored::NameToId}\label{wxtreelayoutstorednametoid}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{long}{NameToId}{\param{const wxString\&}{ name}}
|
|
|
|
|
|
|
|
Returns the id for the given node name, or -1 if there was no such node.
|
|
|
|
|
2000-02-28 15:57:06 +00:00
|
|
|
\membersection{wxTreeLayoutStored::SetClientData}\label{wxtreelayoutstoredsetclientdata}
|
1998-07-12 09:21:16 +00:00
|
|
|
|
|
|
|
\func{void}{SetClientData}{\param{long}{ id}, \param{long}{ clientData}}
|
|
|
|
|
|
|
|
Sets client data for the given node.
|
|
|
|
|