-\chapter{Class reference}\label{classref}
-\setheader{{\it CHAPTER \thechapter}}{}{}{}{}{{\it CHAPTER \thechapter}}%
-\setfooter{\thepage}{}{}{}{}{\thepage}
-
-These are the main \ogl\ classes.
-
-\section{\class{wxOGLConstraint}}\label{wxoglconstraint}
-
-\overview{wxCompositeShape overview}{compositeshapeoverview}
-
-An wxOGLConstraint object helps specify how child shapes are laid out with respect
-to siblings and parents.
-
-\wxheading{Derived from}
-
-wxObject
-
-\wxheading{See also}
-
-\helpref{wxCompositeShape}{wxcompositeshape}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxOGLConstraint::wxOGLConstraint}\label{wxoglconstraintconstr}
-
-\func{}{wxOGLConstraint}{\void}
-
-Default constructor.
-
-\func{}{wxOGLConstraint}{\param{int}{ type}, \param{wxShape *}{constraining}, \param{wxList\& }{constrained}}
-
-Constructor.
-
-\wxheading{Parameters}
-
-\docparam{constraining}{The shape which is used as the reference for positioning the {\it constrained} objects.}
-
-\docparam{constrained}{Contains a list of wxShapes which are to be constrained (with respect
-to {\it constraining}) using {\it type}.}
-
-\docparam{type}{Can be one of:
-
-\begin{itemize}\itemsep=0pt
-\item {\bf gyCONSTRAINT\_CENTRED\_VERTICALLY}: the Y co-ordinates of the centres of the
-bounding boxes of the constrained objects and the constraining object
-will be the same
-\item {\bf gyCONSTRAINT\_CENTRED\_HORIZONTALLY}: the X co-ordinates of the centres of the
-bounding boxes of the constrained objects and the constraining object
-will be the same
-\item {\bf gyCONSTRAINT\_CENTRED\_BOTH}: the co-ordinates of the centres of the bounding boxes
-of the constrained objects and the constraining object will be the same
-\item {\bf gyCONSTRAINT\_LEFT\_OF}: the X co-ordinates of the right hand vertical edges
-of the bounding boxes of the constrained objects will be less than
-the X co-ordinate of the left hand vertical edge of the bounding box
-of the constraining object
-\item {\bf gyCONSTRAINT\_RIGHT\_OF}: the X co-ordinates of the left hand vertical edges
-of the bounding boxes of the constrained objects will be greater than
-the X co-ordinate of the right hand vertical edge of the bounding box
-of the constraining object
-\item {\bf gyCONSTRAINT\_ABOVE}: the Y co-ordinates of the bottom horizontal edges of the
-bounding boxes of the constrained objects will be less than the
-Y co-ordinate of the top horizontal edge of the bounding box of the
-constraining object
-\item {\bf gyCONSTRAINT\_BELOW}: the Y co-ordinates of the top horizontal edges of the
-bounding boxes of the constrained objects will be greater than
-the X co-ordinate of the bottom horizontal edge of the bounding box
-of the constraining object
-\item {\bf gyCONSTRAINT\_ALIGNED\_TOP}: the Y co-ordinates of the top horizontal edges of the
-bounding boxes of the constrained objects will be the same as the
-Y co-ordinate of the top horizontal edge of the bounding box of the
-constraining object
-\item {\bf gyCONSTRAINT\_ALIGNED\_BOTTOM}: the Y co-ordinates of the bottom horizontal edges
-of the bounding boxes of the constrained objects will be the same as
-the Y co-ordinate of the bottom horizontal edge of the bounding box
-of the constraining object
-\item {\bf gyCONSTRAINT\_ALIGNED\_LEFT}: the X co-ordinates of the left hand vertical edges
-of the bounding boxes of the constrained objects will be the same as
-the X co-ordinate of the left hand vertical edge of the bounding box
-of the constraining object
-\item {\bf gyCONSTRAINT\_ALIGNED\_RIGHT}: the X co-ordinates of the right hand vertical edges
-of the bounding boxes of the constrained objects will be the same as
-the X co-ordinate of the right hand vertical edge of the bounding box
-of the constraining object
-\item {\bf gyCONSTRAINT\_MIDALIGNED\_TOP}: the Y co-ordinates of the centres of
-the bounding boxes of the constrained objects will be the same
-as the Y co-ordinate of the top horizontal edge of
-the bounding box of the constraining object
-\item {\bf gyCONSTRAINT\_MIDALIGNED\_BOTTOM}: the Y co-ordinates of the centres of
-the bounding boxes of the constrained objects will be the same
-as the Y co-ordinate of the bottom horizontal edge of
-the bounding box of the constraining object
-\item {\bf gyCONSTRAINT\_MIDALIGNED\_LEFT}: the X co-ordinates of the centres of
-the bounding boxes of the constrained objects will be the same
-as the X co-ordinate of the left hand vertical edge of
-the bounding box of the constraining object
-\item {\bf gyCONSTRAINT\_MIDALIGNED\_RIGHT}: the X co-ordinates of the centres of
-the bounding boxes of the constrained objects will be the same as
-the X co-ordinate of the right hand vertical edge of
-the bounding box of the constraining object
-\end{itemize}
-}
-
-\membersection{wxOGLConstraint::\destruct{wxOGLConstraint}}
-
-\func{}{\destruct{wxOGLConstraint}}{\void}
-
-Destructor.
-
-\membersection{wxOGLConstraint::Equals}
-
-\func{bool}{Equals}{\param{double}{ x}, \param{double}{ y}}
-
-Returns TRUE if {\it x} and {\it y} are approximately equal (for the purposes
-of evaluating the constraint).
-
-\membersection{wxOGLConstraint::Evaluate}
-
-\func{bool}{Evaluate}{\void}
-
-Evaluates this constraint, returning TRUE if anything changed.
-
-\membersection{wxOGLConstraint::SetSpacing}\label{wxoglconstraintsetspacing}
-
-\func{void}{SetSpacing}{\param{double}{ x}, \param{double}{ y}}
-
-Sets the horizontal and vertical spacing for the constraint.
-
-\section{\class{wxBitmapShape}}\label{wxbitmapshape}
-
-Draws a bitmap (non-resizable).
-
-\wxheading{Derived from}
-
-\helpref{wxRectangleShape}{wxrectangleshape}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxBitmapShape::wxBitmapShape}
-
-\func{}{wxBitmapShape}{\void}
-
-Constructor.
-
-\membersection{wxBitmapShape::\destruct{wxBitmapShape}}
-
-\func{}{\destruct{wxBitmapShape}}{\void}
-
-Destructor.
-
-\membersection{wxBitmapShape::GetBitmap}
-
-\constfunc{wxBitmap\&}{GetBitmap}{\void}
-
-Returns a reference to the bitmap associated with this shape.
-
-\membersection{wxBitmapShape::GetFilename}
-
-\constfunc{wxString}{GetFilename}{\void}
-
-Returns the bitmap filename.
-
-\membersection{wxBitmapShape::SetBitmap}
-
-\func{void}{SetBitmap}{\param{const wxBitmap\&}{ bitmap}}
-
-Sets the bitmap associated with this shape. You can delete the bitmap
-from the calling application, since reference counting will take care of
-holding on to the internal bitmap data.
-
-\membersection{wxBitmapShape::SetFilename}
-
-\func{void}{SetFilename}{\param{const wxString\& }{filename}}
-
-Sets the bitmap filename.
-
-\section{\class{wxDiagram}}\label{wxdiagram}
-
-Encapsulates an entire diagram, with methods for reading/writing and drawing.
-A diagram has an associated wxShapeCanvas.
-
-\wxheading{Derived from}
-
-wxObject
-
-\wxheading{See also}
-
-\helpref{wxShapeCanvas}{wxshapecanvas}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxDiagram::wxDiagram}
-
-\func{}{wxDiagram}{\void}
-
-Constructor.
-
-\membersection{wxDiagram::\destruct{wxDiagram}}
-
-\func{}{\destruct{wxDiagram}}{\void}
-
-Destructor.
-
-\membersection{wxDiagram::AddShape}
-
-\func{void}{AddShape}{\param{wxShape*}{shape}, \param{wxShape *}{addAfter = NULL}}
-
-Adds a shape to the diagram. If {\it addAfter} is non-NULL, the shape will be added after this
-one.
-
-\membersection{wxDiagram::Clear}
-
-\func{void}{Clear}{\param{wxDC\&}{ dc}}
-
-Clears the specified device context.
-
-\membersection{wxDiagram::DeleteAllShapes}
-
-\func{void}{DeletesAllShapes}{\void}
-
-Removes and deletes all shapes in the diagram.
-
-\membersection{wxDiagram::DrawOutline}
-
-\func{void}{DrawOutline}{\param{wxDC\&}{ dc}, \param{double}{ x1}, \param{double}{ y1}, \param{double}{ x2}, \param{double}{ y2}}
-
-Draws an outline rectangle on the current device context.
-
-\membersection{wxDiagram::FindShape}\label{wxdiagramfindshape}
-
-\constfunc{wxShape*}{FindShape}{\param{long}{ id}}
-
-Returns the shape for the given identifier.
-
-\membersection{wxDiagram::GetCanvas}
-
-\constfunc{wxShapeCanvas*}{GetCanvas}{\void}
-
-Returns the shape canvas associated with this diagram.
-
-\membersection{wxDiagram::GetCount}\label{wxdiagramgetcount}
-
-\constfunc{int}{GetCount}{\void}
-
-Returns the number of shapes in the diagram.
-
-\membersection{wxDiagram::GetGridSpacing}
-
-\constfunc{double}{GetGridSpacing}{\void}
-
-Returns the grid spacing.
-
-\membersection{wxDiagram::GetMouseTolerance}
-
-\func{int}{GetMouseTolerance}{\void}
-
-Returns the tolerance within which a mouse move is ignored.
-
-\membersection{wxDiagram::GetShapeList}
-
-\constfunc{wxList*}{GetShapeList}{\void}
-
-Returns a pointer to the internal shape list.
-
-\membersection{wxDiagram::GetQuickEditMode}
-
-\constfunc{bool}{GetQuickEditMode}{\void}
-
-Returns quick edit mode.
-
-\membersection{wxDiagram::GetSnapToGrid}
-
-\constfunc{bool}{GetSnapToGrid}{\void}
-
-Returns snap-to-grid mode.
-
-\membersection{wxDiagram::InsertShape}
-
-\func{void}{InsertShape}{\param{wxShape *}{shape}}
-
-Inserts a shape at the front of the shape list.
-
-\membersection{wxDiagram::LoadFile}
-
-\func{bool}{LoadFile}{\param{const wxString\& }{filename}}
-
-Loads the diagram from a file.
-
-\membersection{wxDiagram::OnDatabaseLoad}
-
-\func{void}{OnDatabaseLoad}{\param{wxExprDatabase\&}{ database}}
-
-Called just after the nodes and lines have been read from the wxExprDatabase. You may override this;
-the default member does nothing.
-
-\membersection{wxDiagram::OnDatabaseSave}
-
-\func{void}{OnDatabaseSave}{\param{wxExprDatabase\&}{ database}}
-
-Called just after the nodes and lines have been written to the wxExprDatabase. You may override this;
-the default member does nothing.
-
-\membersection{wxDiagram::OnHeaderLoad}
-
-\func{bool}{OnHeaderLoad}{\param{wxExprDatabase\&}{ database}, \param{wxExpr\&}{ expr}}
-
-Called to allow the `diagram' header object to be read. The default member reads no further information.
-You may wish to override this to read version information, author name, etc.
-
-\membersection{wxDiagram::OnHeaderSave}
-
-\func{bool}{OnHeaderSave}{\param{wxExprDatabase\&}{ database}, \param{wxExpr\&}{ expr}}
-
-Called to allow instantiation of the `diagram' header object. The default member writes no further information.
-You may wish to override this to include version information, author name, etc.
-
-\membersection{wxDiagram::OnShapeLoad}
-
-\func{bool}{OnShapeLoad}{\param{wxExprDatabase\&}{ database}, \param{wxShape\&}{ shape}, \param{wxExpr\&}{ expr}}
-
-Called to read the shape from the {\it expr}. You may override this, but call this function first.
-The default member calls ReadAttributes for the shape.
-
-\membersection{wxDiagram::OnShapeSave}
-
-\func{bool}{OnShapeSave}{\param{wxExprDatabase\&}{ database}, \param{wxShape\&}{ shape}, \param{wxExpr\&}{ expr}}
-
-Called to save the shape to the {\it expr} and {\it database}. You may override this, but call this function first.
-The default member calls WriteAttributes for the shape, appends the shape to the database, and of the shape
-is a composite, recursively calls OnShapeSave for its children.
-
-\membersection{wxDiagram::ReadContainerGeometry}
-
-\func{void}{ReadContainerGeometry}{\param{wxExprDatabase\&}{ database}}
-
-Reads container geometry from a wxExprDatabase, linking up nodes which
-are part of a composite. You probably won't need to redefine this.
-
-\membersection{wxDiagram::ReadLines}
-
-\func{void}{ReadLines}{\param{wxExprDatabase\&}{ database}}
-
-Reads lines from a wxExprDatabase. You probably won't need to redefine this.
-
-\membersection{wxDiagram::ReadNodes}
-
-\func{void}{ReadNodes}{\param{wxExprDatabase\&}{ database}}
-
-Reads nodes from a wxExprDatabase. You probably won't need to redefine this.
-
-\membersection{wxDiagram::RecentreAll}
-
-\func{void}{RecentreAll}{\param{wxDC\&}{ dc}}
-
-Make sure all text that should be centred, is centred.
-
-\membersection{wxDiagram::Redraw}
-
-\func{void}{Redraw}{\param{wxDC\&}{ dc}}
-
-Draws the shapes in the diagram on the specified device context.
-
-\membersection{wxDiagram::RemoveAllShapes}
-
-\func{void}{RemoveAllShapes}{\void}
-
-Removes all shapes from the diagram but does not delete the shapes.
-
-\membersection{wxDiagram::RemoveShape}
-
-\func{void}{RemoveShape}{\param{wxShape*}{ shape}}
-
-Removes the shape from the diagram (non-recursively) but does not delete it.
-
-\membersection{wxDiagram::SaveFile}
-
-\func{bool}{SaveFile}{\param{const wxString\& }{filename}}
-
-Saves the diagram in a file.
-
-\membersection{wxDiagram::SetCanvas}\label{wxdiagramsetcanvas}
-
-\func{void}{SetCanvas}{\param{wxShapeCanvas*}{ canvas}}
-
-Sets the canvas associated with this diagram.
-
-\membersection{wxDiagram::SetGridSpacing}
-
-\func{void}{SetGridSpacing}{\param{double}{ spacing}}
-
-Sets the grid spacing. The default is 5.
-
-\membersection{wxDiagram::SetMouseTolerance}
-
-\func{void}{SetMouseTolerance}{\param{int}{ tolerance}}
-
-Sets the tolerance within which a mouse move is ignored. The default is 3 pixels.
-
-\membersection{wxDiagram::SetQuickEditMode}
-
-\func{void}{SetQuickEditMode}{\param{bool}{ mode}}
-
-Sets quick-edit-mode on or off. In this mode, refreshes are minimized, but the
-diagram may need manual refreshing occasionally.
-
-\membersection{wxDiagram::SetSnapToGrid}
-
-\func{void}{SetSnapToGrid}{\param{bool}{ snap}}
-
-Sets snap-to-grid mode on or off. The default is on.
-
-\membersection{wxDiagram::ShowAll}
-
-\func{void}{ShowAll}{\param{bool}{ show}}
-
-Calls Show for each shape in the diagram.
-
-\membersection{wxDiagram::Snap}
-
-\func{void}{Snap}{\param{double *}{x}, \param{double *}{y}}
-
-`Snaps' the coordinate to the nearest grid position, if snap-to-grid is on.
-
-\section{\class{wxDrawnShape}}\label{wxdrawnshape}
-
-Draws a pseduo-metafile shape, which can be loaded from a simple Windows metafile.
-
-wxDrawnShape allows you to specify a different shape for each of four orientations (North, West,
-South and East). It also provides a set of drawing functions for programmatic drawing of a shape,
-so that during construction of the shape you can draw into it as if it were a device context.
-
-\wxheading{Derived from}
-
-\helpref{wxRectangleShape}{wxrectangleshape}
-
-See also \helpref{wxRectangleShape}{wxrectangleshape}.
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxDrawnShape::wxDrawnShape}
-
-\func{}{wxDrawnShape}{\void}
-
-Constructor.
-
-\membersection{wxDrawnShape::\destruct{wxDrawnShape}}
-
-\func{}{\destruct{wxDrawnShape}}{\void}
-
-Destructor.
-
-\membersection{wxDrawnShape::CalculateSize}
-
-\func{void}{CalculateSize}{\void}
-
-Calculates the wxDrawnShape size from the current metafile. Call this after you have drawn
-into the shape.
-
-\membersection{wxDrawnShape::DestroyClippingRect}\label{wxdrawnshapedestroyclippingrect}
-
-\func{void}{DestroyClippingRect}{\void}
-
-Destroys the clipping rectangle. See also \helpref{wxDrawnShape::SetClippingRect}{wxdrawnshapesetclippingrect}.
-
-\membersection{wxDrawnShape::DrawArc}\label{wxdrawnshapedrawarc}
-
-\func{void}{DrawArc}{\param{const wxPoint\&}{ centrePoint}, \param{const wxPoint\&}{ startPoint},
- \param{const wxPoint\&}{ endPoint}}
-
-Draws an arc (see wxWindows documentation for details).
-
-\membersection{wxDrawnShape::DrawAtAngle}\label{wxdrawnshapedrawatangle}
-
-\func{void}{DrawAtAngle}{\param{int}{ angle}}
-
-Sets the metafile for the given orientation, which can be one of:
-
-\begin{itemize}\itemsep=0pt
-\item oglDRAWN\_ANGLE\_0
-\item oglDRAWN\_ANGLE\_90
-\item oglDRAWN\_ANGLE\_180
-\item oglDRAWN\_ANGLE\_270
-\end{itemize}
-
-See also \helpref{wxDrawnShape::GetAngle}{wxdrawnshapegetangle}.
-
-\membersection{wxDrawnShape::DrawEllipticArc}\label{wxdrawnshapedrawellipticarc}
-
-\func{void}{DrawEllipticArc}{\param{const wxRect\&}{ rect}, \param{double}{ startAngle}, \param{double}{ endAngle}}
-
-Draws an elliptic arc (see wxWindows documentation for details).
-
-\membersection{wxDrawnShape::DrawLine}\label{wxdrawnshapedrawline}
-
-\func{void}{DrawLine}{\param{const wxPoint\&}{ point1}, \param{const wxPoint\&}{ point2}}
-
-Draws a line from {\it point1} to {\it point2}.
-
-\membersection{wxDrawnShape::DrawLines}\label{wxdrawnshapedrawlines}
-
-\func{void}{DrawLines}{\param{int}{ n}, \param{wxPoint\&}{ points[]}}
-
-Draws {\it n} lines.
-
-\membersection{wxDrawnShape::DrawPoint}\label{wxdrawnshapedrawpoint}
-
-\func{void}{DrawPoint}{\param{const wxPoint\&}{ point}}
-
-Draws a point.
-
-\membersection{wxDrawnShape::DrawPolygon}\label{wxdrawnshapedrawpolygon}
-
-\func{void}{DrawPolygon}{\param{int}{ n}, \param{wxPoint\&}{ points[]}, \param{int}{ flags = 0}}
-
-Draws a polygon. {\it flags} can be one or more of {\bf oglMETAFLAGS\_OUTLINE} (use this polygon for the drag outline)
-and {\bf oglMETAFLAGS\_ATTACHMENTS} (use the vertices of this polygon for attachments).
-
-\membersection{wxDrawnShape::DrawRectangle}\label{wxdrawnshapedrawrectangle}
-
-\func{void}{DrawRectangle}{\param{const wxRect\&}{ rect}}
-
-Draws a rectangle.
-
-\membersection{wxDrawnShape::DrawRoundedRectangle}\label{wxdrawnshapedrawroundedrectangle}
-
-\func{void}{DrawRoundedRectangle}{\param{const wxRect\&}{ rect}, \param{double}{ radius}}
-
-Draws a rounded rectangle. {\it radius} is the corner radius. If {\it radius} is negative,
-it expresses the radius as a proportion of the smallest dimension of the rectangle.
-
-\membersection{wxDrawnShape::DrawSpline}\label{wxdrawnshapedrawspline}
-
-\func{void}{DrawSpline}{\param{int}{ n}, \param{wxPoint\&}{ points[]}}
-
-Draws a spline curve.
-
-\membersection{wxDrawnShape::DrawText}\label{wxdrawnshapedrawtext}
-
-\func{void}{DrawText}{\param{const wxString\&}{ text}, \param{const wxPoint\&}{ point}}
-
-Draws text at the given point.
-
-\membersection{wxDrawnShape::GetAngle}\label{wxdrawnshapegetangle}
-
-\constfunc{int}{GetAngle}{\void}
-
-Returns the current orientation, which can be one of:
-
-\begin{itemize}\itemsep=0pt
-\item oglDRAWN\_ANGLE\_0
-\item oglDRAWN\_ANGLE\_90
-\item oglDRAWN\_ANGLE\_180
-\item oglDRAWN\_ANGLE\_270
-\end{itemize}
-
-See also \helpref{wxDrawnShape::DrawAtAngle}{wxdrawnshapedrawatangle}.
-
-\membersection{wxDrawnShape::GetMetaFile}
-
-\constfunc{wxPseudoMetaFile\& }{GetMetaFile}{\void}
-
-Returns a reference to the internal `pseudo-metafile'.
-
-\membersection{wxDrawnShape::GetRotation}\label{wxdrawnshapegetrotation}
-
-\constfunc{double}{GetRotation}{\void}
-
-Returns the current rotation of the shape in radians.
-
-\membersection{wxDrawnShape::LoadFromMetaFile}
-
-\func{bool}{LoadFromMetaFile}{\param{const wxString\& }{filename}}
-
-Loads a (very simple) Windows metafile, created for example by Top Draw, the Windows shareware graphics package.
-
-\membersection{wxDrawnShape::Rotate}
-
-\func{void}{Rotate}{\param{double }{x}, \param{double }{y}, \param{double }{theta}}
-
-Rotate about the given axis by the given amount in radians.
-
-\membersection{wxDrawnShape::SetClippingRect}\label{wxdrawnshapesetclippingrect}
-
-\func{void}{SetClippingRect}{\param{const wxRect\&}{ rect}}
-
-Sets the clipping rectangle. See also \helpref{wxDrawnShape::DestroyClippingRect}{wxdrawnshapedestroyclippingrect}.
-
-\membersection{wxDrawnShape::SetDrawnBackgroundColour}\label{wxdrawnshapesetdrawnbackgroundcolour}
-
-\func{void}{SetDrawnBackgroundColour}{\param{const wxColour\&}{ colour}}
-
-Sets the current background colour for the current metafile.
-
-\membersection{wxDrawnShape::SetDrawnBackgroundMode}\label{wxdrawnshapesetdrawnbackgroundmode}
-
-\func{void}{SetDrawnBackgroundMode}{\param{int}{ mode}}
-
-Sets the current background mode for the current metafile.
-
-\membersection{wxDrawnShape::SetDrawnBrush}\label{wxdrawnshapesetdrawnbrush}
-
-\func{void}{SetDrawnBrush}{\param{wxPen*}{ pen}, \param{bool}{ isOutline = FALSE}}
-
-Sets the pen for this metafile. If {\it isOutline} is TRUE, this pen is taken to indicate the outline
-(and if the outline pen is changed for the whole shape, the pen will be replaced with the outline pen).
-
-\membersection{wxDrawnShape::SetDrawnFont}\label{wxdrawnshapesetdrawnfont}
-
-\func{void}{SetDrawnFont}{\param{wxFont*}{ font}}
-
-Sets the current font for the current metafile.
-
-\membersection{wxDrawnShape::SetDrawnPen}\label{wxdrawnshapesetdrawnpen}
-
-\func{void}{SetDrawnPen}{\param{wxPen*}{ pen}, \param{bool}{ isOutline = FALSE}}
-
-Sets the pen for this metafile. If {\it isOutline} is TRUE, this pen is taken to indicate the outline
-(and if the outline pen is changed for the whole shape, the pen will be replaced with the outline pen).
-
-\membersection{wxDrawnShape::SetDrawnTextColour}\label{wxdrawnshapesetdrawntextcolour}
-
-\func{void}{SetDrawnTextColour}{\param{const wxColour\&}{ colour}}
-
-Sets the current text colour for the current metafile.
-
-\membersection{wxDrawnShape::Scale}
-
-\func{void}{Scale}{\param{double }{sx}, \param{double }{sy}}
-
-Scales the shape by the given amount.
-
-\membersection{wxDrawnShape::SetSaveToFile}
-
-\func{void}{SetSaveToFile}{\param{bool }{save}}
-
-If {\it save} is TRUE, the image will be saved along with the shape's other attributes. The reason
-why this might not be desirable is that if there are many shapes with the same image, it would be
-more efficient for the application to save one copy, and not duplicate the information for every
-shape. The default is TRUE.
-
-\membersection{wxDrawnShape::Translate}
-
-\func{void}{Translate}{\param{double }{x}, \param{double }{y}}
-
-Translates the shape by the given amount.
-
-\section{\class{wxCircleShape}}\label{wxcircleshape}
-
-An wxEllipseShape whose width and height are the same.
-
-\wxheading{Derived from}
-
-\helpref{wxEllipseShape}{wxellipseshape}.
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxCircleShape::wxCircleShape}
-
-\func{}{wxCircleShape}{\param{double}{ width = 0.0}}
-
-Constructor.
-
-\membersection{wxCircleShape::\destruct{wxCircleShape}}
-
-\func{}{\destruct{wxCircleShape}}{\void}
-
-Destructor.
-
-\section{\class{wxCompositeShape}}\label{wxcompositeshape}
-
-This is an object with a list of child objects, and a list of size
-and positioning constraints between the children.
-
-\wxheading{Derived from}
-
-\helpref{wxRectangleShape}{wxrectangleshape}
-
-\wxheading{See also}
-
-\helpref{wxCompositeShape overview}{compositeshapeoverview}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxCompositeShape::wxCompositeShape}
-
-\func{}{wxCompositeShape}{\void}
-
-Constructor.
-
-\membersection{wxCompositeShape::\destruct{wxCompositeShape}}
-
-\func{}{\destruct{wxCompositeShape}}{\void}
-
-Destructor.
-
-\membersection{wxCompositeShape::AddChild}\label{wxcompositeshapeaddchild}
-
-\func{void}{AddChild}{\param{wxShape *}{child}, \param{wxShape *}{addAfter = NULL}}
-
-Adds a child shape to the composite. If {\it addAfter} is non-NULL, the shape will be added
-after this shape.
-
-\membersection{wxCompositeShape::AddConstraint}\label{wxcompositeshapeaddconstraint}
-
-\func{wxOGLConstraint *}{AddConstraint}{\param{wxOGLConstraint *}{constraint}}
-
-\func{wxOGLConstraint *}{AddConstraint}{\param{int}{ type}, \param{wxShape *}{constraining}, \param{wxList\&}{constrained}}
-
-\func{wxOGLConstraint *}{AddConstraint}{\param{int}{ type}, \param{wxShape *}{constraining}, \param{wxShape *}{constrained}}
-
-Adds a constraint to the composite.
-
-\membersection{wxCompositeShape::CalculateSize}
-
-\func{void}{CalculateSize}{\void}
-
-Calculates the size and position of the composite based on child sizes and positions.
-
-\membersection{wxCompositeShape::ContainsDivision}
-
-\func{bool}{FindContainerImage}{\param{wxDivisionShape *}{division}}
-
-Returns TRUE if {\it division} is a descendant of this container.
-
-\membersection{wxCompositeShape::DeleteConstraint}
-
-\func{void}{DeleteConstraint}{\param{wxOGLConstraint *}{constraint}}
-
-Deletes constraint from composite.
-
-\membersection{wxCompositeShape::DeleteConstraintsInvolvingChild}
-
-\func{void}{DeleteConstraintsInvolvingChild}{\param{wxShape *}{child}}
-
-This function deletes constraints which mention the given child. Used when
-deleting a child from the composite.
-
-\membersection{wxCompositeShape::FindConstraint}
-
-\func{wxOGLConstraint *}{FindConstraint}{\param{long}{ id}, \param{wxCompositeShape **}{actualComposite}}
-
-Finds the constraint with the given id, also returning the actual composite the constraint was in,
-in case that composite was a descendant of this composite.
-
-\membersection{wxCompositeShape::FindContainerImage}
-
-\func{wxShape *}{FindContainerImage}{\void}
-
-Finds the image used to visualize a container. This is any child
-of the composite that is not in the divisions list.
-
-\membersection{wxCompositeShape::GetConstraints}
-
-\constfunc{wxList\&}{GetConstraints}{\void}
-
-Returns a reference to the list of constraints.
-
-\membersection{wxCompositeShape::GetDivisions}
-
-\constfunc{wxList\&}{GetDivisions}{\void}
-
-Returns a reference to the list of divisions.
-
-\membersection{wxCompositeShape::MakeContainer}\label{wxcompositeshapemakecontainer}
-
-\func{void}{MakeContainer}{\void}
-
-Makes this composite into a container by creating one child wxDivisionShape.
-
-\membersection{wxCompositeShape::OnCreateDivision}
-
-\func{wxDivisionShape *}{OnCreateDivision}{\void}
-
-Called when a new division shape is required. Can be overriden to allow an application
-to use a different class of division.
-
-\membersection{wxCompositeShape::Recompute}\label{wxcompositeshaperecompute}
-
-\func{bool}{Recompute}{\void}
-
-Recomputes any constraints associated with the object. If FALSE is returned,
-the constraints could not be satisfied (there was an inconsistency).
-
-\membersection{wxCompositeShape::RemoveChild}
-
-\func{void}{RemoveChild}{\param{wxShape *}{child}}
-
-Removes the child from the composite and any constraint relationships, but does not
-delete the child.
-
-\section{\class{wxDividedShape}}\label{wxdividedshape}
-
-A wxDividedShape is a rectangle with a number of vertical divisions. Each
-division may have its text formatted with independent characteristics, and
-the size of each division relative to the whole image may be specified.
-
-\wxheading{Derived from}
-
-\helpref{wxRectangleShape}{wxrectangleshape}
-
-\wxheading{See also}
-
-\helpref{wxDividedShape overview}{dividedshapeoverview}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxDividedShape::wxDividedShape}
-
-\func{}{wxDividedShape}{\param{double}{ width = 0.0}, \param{double}{ height = 0.0}}
-
-Constructor.
-
-\membersection{wxDividedShape::\destruct{wxDividedShape}}
-
-\func{}{\destruct{wxDividedShape}}{\void}
-
-Destructor.
-
-\membersection{wxDividedShape::EditRegions}
-
-\func{void}{EditRegions}{\void}
-
-Edit the region colours and styles.
-
-\membersection{wxDividedShape::SetRegionSizes}
-
-\func{void}{SetRegionSizes}{\void}
-
-Set all region sizes according to proportions and
-this object total size.
-
-\section{\class{wxDivisionShape}}\label{wxdivisionshape}
-
-A division shape is like a composite in that it can contain further objects, but is used exclusively to
-divide another shape into regions, or divisions. A wxDivisionShape is never free-standing.
-
-\wxheading{Derived from}
-
-\helpref{wxCompositeShape}{wxcompositeshape}
-
-\wxheading{See also}
-
-\helpref{wxCompositeShape overview}{compositeshapeoverview}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxDivisionShape::wxDivisionShape}
-
-\func{}{wxDivisionShape}{\void}
-
-Constructor.
-
-\membersection{wxDivisionShape::\destruct{wxDivisionShape}}
-
-\func{}{\destruct{wxDivisionShape}}{\void}
-
-Destructor.
-
-\membersection{wxDivisionShape::AdjustBottom}
-
-\func{void}{AdjustBottom}{\param{double}{ bottom}, \param{bool}{ test}}
-
-Adjust a side, returning FALSE if it's not physically possible to adjust it to this point.
-
-\membersection{wxDivisionShape::AdjustLeft}
-
-\func{void}{AdjustLeft}{\param{double}{ left}, \param{bool}{ test}}
-
-Adjust a side, returning FALSE if it's not physically possible to adjust it to this point.
-
-\membersection{wxDivisionShape::AdjustRight}
-
-\func{void}{AdjustRight}{\param{double}{ right}, \param{bool}{ test}}
-
-Adjust a side, returning FALSE if it's not physically possible to adjust it to this point.
-
-\membersection{wxDivisionShape::AdjustTop}
-
-\func{void}{AdjustTop}{\param{double}{ top}, \param{bool}{ test}}
-
-Adjust a side, returning FALSE if it's not physically possible to adjust it to this point.
-
-\membersection{wxDivisionShape::Divide}\label{wxdivisionshapedivide}
-
-\func{void}{Divide}{\param{int}{ direction}}
-
-Divide this division into two further divisions, horizontally ({\it direction} is wxHORIZONTAL) or
-vertically ({\it direction} is wxVERTICAL).
-
-\membersection{wxDivisionShape::EditEdge}
-
-\func{void}{EditEdge}{\param{int}{ side}}
-
-Interactively edit style of left or top side.
-
-\membersection{wxDivisionShape::GetBottomSide}
-
-\func{wxDivisionShape *}{GetBottomSide}{\void}
-
-Returns a pointer to the division on the bottom side of this division.
-
-\membersection{wxDivisionShape::GetHandleSide}
-
-\func{int}{GetHandleSide}{\void}
-
-Returns the side which the handle appears on (DIVISION\_SIDE\_LEFT or DIVISION\_SIDE\_TOP).
-
-\membersection{wxDivisionShape::GetLeftSide}
-
-\func{wxDivisionShape *}{GetLeftSide}{\void}
-
-Returns a pointer to the division on the left side of this division.
-
-\membersection{wxDivisionShape::GetLeftSideColour}
-
-\func{wxString}{GetLeftSideColour}{\void}
-
-Returns a pointer to the colour used for drawing the left side of the division.
-
-\membersection{wxDivisionShape::GetLeftSidePen}
-
-\func{wxPen *}{GetLeftSidePen}{\void}
-
-Returns a pointer to the pen used for drawing the left side of the division.
-
-\membersection{wxDivisionShape::GetRightSide}
-
-\func{wxDivisionShape *}{GetRightSide}{\void}
-
-Returns a pointer to the division on the right side of this division.
-
-\membersection{wxDivisionShape::GetTopSide}
-
-\func{wxDivisionShape *}{GetTopSide}{\void}
-
-Returns a pointer to the division on the top side of this division.
-
-\membersection{wxDivisionShape::GetTopSideColour}
-
-\func{wxString}{GetTopSideColour}{\void}
-
-Returns a pointer to the colour used for drawing the top side of the division.
-
-\membersection{wxDivisionShape::GetTopSidePen}
-
-\func{wxPen *}{GetTopSidePen}{\void}
-
-Returns a pointer to the pen used for drawing the left side of the division.
-
-\membersection{wxDivisionShape::ResizeAdjoining}
-
-\func{void}{ResizeAdjoining}{\param{int}{ side}, \param{double}{ newPos}, \param{bool}{ test}}
-
-Resize adjoining divisions at the given side. If {\it test} is TRUE,
-just see whether it's possible for each adjoining region,
-returning FALSE if it's not.
-
-{\it side} can be one of:
-
-\begin{itemize}\itemsep=0pt
-\item DIVISION\_SIDE\_NONE
-\item DIVISION\_SIDE\_LEFT
-\item DIVISION\_SIDE\_TOP
-\item DIVISION\_SIDE\_RIGHT
-\item DIVISION\_SIDE\_BOTTOM
-\end{itemize}
-
-\membersection{wxDivisionShape::PopupMenu}
-
-\func{void}{PopupMenu}{\param{double}{ x}, \param{double}{ y}}
-
-Popup the division menu.
-
-\membersection{wxDivisionShape::SetBottomSide}
-
-\func{void}{SetBottomSide}{\param{wxDivisionShape *}{shape}}
-
-Set the pointer to the division on the bottom side of this division.
-
-\membersection{wxDivisionShape::SetHandleSide}
-
-\func{int}{SetHandleSide}{\void}
-
-Sets the side which the handle appears on (DIVISION\_SIDE\_LEFT or DIVISION\_SIDE\_TOP).
-
-\membersection{wxDivisionShape::SetLeftSide}
-
-\func{void}{SetLeftSide}{\param{wxDivisionShape *}{shape}}
-
-Set the pointer to the division on the left side of this division.
-
-\membersection{wxDivisionShape::SetLeftSideColour}
-
-\func{void}{SetLeftSideColour}{\param{const wxString\& }{colour}}
-
-Sets the colour for drawing the left side of the division.
-
-\membersection{wxDivisionShape::SetLeftSidePen}
-
-\func{void}{SetLeftSidePen}{\param{wxPen *}{pen}}
-
-Sets the pen for drawing the left side of the division.
-
-\membersection{wxDivisionShape::SetRightSide}
-
-\func{void}{SetRightSide}{\param{wxDivisionShape *}{shape}}
-
-Set the pointer to the division on the right side of this division.
-
-\membersection{wxDivisionShape::SetTopSide}
-
-\func{void}{SetTopSide}{\param{wxDivisionShape *}{shape}}
-
-Set the pointer to the division on the top side of this division.
-
-\membersection{wxDivisionShape::SetTopSideColour}
-
-\func{void}{SetTopSideColour}{\param{const wxString\& }{colour}}
-
-Sets the colour for drawing the top side of the division.
-
-\membersection{wxDivisionShape::SetTopSidePen}
-
-\func{void}{SetTopSidePen}{\param{wxPen *}{pen}}
-
-Sets the pen for drawing the top side of the division.
-
-\section{\class{wxEllipseShape}}\label{wxellipseshape}
-
-The wxEllipseShape behaves similarly to the wxRectangleShape but is
-elliptical.
-
-\wxheading{Derived from}
-
-\helpref{wxShape}{wxshape}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxEllipseShape::wxEllipseShape}
-
-\func{}{wxEllipseShape}{\param{double}{ width = 0.0}, \param{double}{ height = 0.0}}
-
-Constructor.
-
-\membersection{wxEllipseShape::\destruct{wxEllipseShape}}
-
-\func{}{\destruct{wxEllipseShape}}{\void}
-
-Destructor.
-
-\section{\class{wxLineShape}}\label{wxlineshape}
-
-A wxLineShape may be attached to two nodes; it may be segmented, in which
-case a control point is drawn for each joint.
-
-A wxLineShape may have arrows at the beginning, end and centre.
-
-\wxheading{Derived from}
-
-\helpref{wxShape}{wxshape}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxLineShape::wxLineShape}
-
-\func{}{wxLineShape}{\void}
-
-Constructor.
-
-Usually you will call \helpref{wxLineShape::MakeLineControlPoints}{wxlineshapemakelinecontrolpoints} to
-specify the number of segments in the line.
-
-\membersection{wxLineShape::\destruct{wxLineShape}}
-
-\func{}{\destruct{wxLineShape}}{\void}
-
-Destructor.
-
-\membersection{wxLineShape::AddArrow}\label{wxlineshapeaddarrow}
-
-\func{void}{AddArrow}{\param{WXTYPE}{ type}, \param{bool}{ end = ARROW\_POSITION\_END}, \param{double}{ arrowSize = 10.0},
- \param{double}{ xOffset = 0.0}, \param{const wxString\& }{name = ""}, \param{wxPseudoMetaFile *}{mf = NULL}, \param{long}{ arrowId = -1}}
-
-Adds an arrow (or annotation) to the line.
-
-{\it type} may currently be one of:
-
-\begin{description}\itemsep=0pt
-\item[ARROW\_HOLLOW\_CIRCLE] Hollow circle.
-\item[ARROW\_FILLED\_CIRCLE] Filled circle.
-\item[ARROW\_ARROW] Conventional arrowhead.
-\item[ARROW\_SINGLE\_OBLIQUE] Single oblique stroke.
-\item[ARROW\_DOUBLE\_OBLIQUE] Double oblique stroke.
-\item[ARROW\_DOUBLE\_METAFILE] Custom arrowhead.
-\end{description}
-
-{\it end} may currently be one of:
-
-\begin{description}\itemsep=0pt
-\item[ARROW\_POSITION\_END] Arrow appears at the end.
-\item[ARROW\_POSITION\_START] Arrow appears at the start.
-\end{description}
-
-{\it arrowSize} specifies the length of the arrow.
-
-{\it xOffset} specifies the offset from the end of the line.
-
-{\it name} specifies a name for the arrow.
-
-{\it mf} can be a wxPseduoMetaFile, perhaps loaded from a simple Windows metafile.
-
-{\it arrowId} is the id for the arrow.
-
-\membersection{wxLineShape::AddArrowOrdered}
-
-\func{void}{AddArrowOrdered}{\param{wxArrowHead *}{arrow}, \param{wxList\&}{ referenceList}, \param{int}{ end}}
-
-Add an arrowhead in the position indicated by the reference
-list of arrowheads, which contains all legal arrowheads for this
-line, in the correct order.
-E.g.
-
-\begin{verbatim}
- Reference list: a b c d e
- Current line list: a d
-\end{verbatim}
-
-Add c, then line list is: a c d.
-
-If no legal arrowhead position, return FALSE. Assume reference list is
-for one end only, since it potentially defines the ordering for any one
-of the 3 positions. So we don't check the reference list for arrowhead
-position.
-
-\membersection{wxLineShape::ClearArrow}
-
-\func{bool}{ClearArrow}{\param{const wxString\& }{name}}
-
-Delete the arrow with the given name.
-
-\membersection{wxLineShape::ClearArrowsAtPosition}
-
-\func{void}{ClearArrowsAtPosition}{\param{int}{ position = -1}}
-
-Delete the arrows at the specified position, or at any position if {\it position} is -1.
-
-\membersection{wxLineShape::DrawArrow}
-
-\func{void}{DrawArrow}{\param{ArrowHead *}{arrow}, \param{double}{ xOffset}, \param{bool}{ proportionalOffset}}
-
-Draws the given arrowhead (or annotation).
-
-\membersection{wxLineShape::DeleteArrowHead}
-
-\func{bool}{DeleteArrowHead}{\param{long}{ arrowId}}
-
-\func{bool}{DeleteArrowHead}{\param{int}{ position}, \param{const wxString\& }{name}}
-
-Delete arrowhead by id or position and name.
-
-\membersection{wxLineShape::DeleteLineControlPoint}
-
-\func{bool}{DeleteLineControlPoint}{\void}
-
-Deletes an arbitary point on the line.
-
-\membersection{wxLineShape::DrawArrows}
-
-\func{void}{DrawArrows}{\param{wxDC\&}{ dc}}
-
-Draws all arrows.
-
-\membersection{wxLineShape::DrawRegion}
-
-\func{void}{DrawRegion}{\param{wxDC\&}{ dc}, \param{wxShapeRegion *}{region}, \param{double}{ x}, \param{double}{ y}}
-
-Format one region at this position.
-
-\membersection{wxLineShape::EraseRegion}
-
-\func{void}{EraseRegion}{\param{wxDC\&}{ dc}, \param{wxShapeRegion *}{region}, \param{double}{ x}, \param{double}{ y}}
-
-Format one region at this position.
-
-\membersection{wxLineShape::FindArrowHead}
-
-\func{wxArrowHead *}{FindArrowHead}{\param{long}{ arrowId}}
-
-\func{wxArrowHead *}{FindArrowHead}{\param{int}{ position}, \param{const wxString\& }{name}}
-
-Find arrowhead by id or position and name.
-
-\membersection{wxLineShape::FindLineEndPoints}
-
-\func{void}{FindLineEndPoints}{\param{double *}{fromX}, \param{double *}{fromY}, \param{double *}{toX}, \param{double *}{toY}}
-
-Finds the x, y points at the two ends of the line. This function can be
-used by e.g. line-routing routines to get the actual points on the two
-node images where the lines will be drawn to/from.
-
-\membersection{wxLineShape::FindLinePosition}
-
-\func{int}{FindLinePosition}{\param{double }{x}, \param{double }{y}}
-
-Find which position we're talking about at this x, y.
-Returns ARROW\_POSITION\_START, ARROW\_POSITION\_MIDDLE, ARROW\_POSITION\_END.
-
-\membersection{wxLineShape::FindMinimumWidth}
-
-\func{double}{FindMinimumWidth}{\void}
-
-Finds the horizontal width for drawing a line with arrows in minimum
-space. Assume arrows at end only.
-
-\membersection{wxLineShape::FindNth}
-
-\func{void}{FindNth}{\param{wxShape *}{image}, \param{int *}{nth}, \param{int *}{noArcs}, \param{bool}{ incoming}}
-
-Finds the position of the line on the given object. Specify whether incoming or outgoing lines are
-being considered with {\it incoming}.
-
-\membersection{wxLineShape::GetAttachmentFrom}
-
-\constfunc{int}{GetAttachmentFrom}{\void}
-
-Returns the attachment point on the `from' node.
-
-\membersection{wxLineShape::GetAttachmentTo}
-
-\constfunc{int}{GetAttachmentTo}{\void}
-
-Returns the attachment point on the `to' node.
-
-\membersection{wxLineShape::GetEnds}
-
-\func{void}{GetEnds}{\param{double *}{x1}, \param{double *}{y1}, \param{double *}{x2}, \param{double *}{y2}}
-
-Gets the visible endpoints of the lines for drawing between two objects.
-
-\membersection{wxLineShape::GetFrom}
-
-\constfunc{wxShape *}{GetFrom}{\void}
-
-Gets the `from' object.
-
-\membersection{wxLineShape::GetLabelPosition}
-
-\func{void}{GetLabelPosition}{\param{int}{ position}, \param{double *}{x}, \param{double *}{y}}
-
-Get the reference point for a label. Region x and y are offsets from this.
-position is 0 (middle), 1 (start), 2 (end).
-
-\membersection{wxLineShape::GetNextControlPoint}
-
-\func{wxPoint *}{GetNextControlPoint}{\param{wxShape *}{shape}}
-
-Find the next control point in the line after the start/end point,
-depending on whether the shape is at the start or end.
-
-\membersection{wxLineShape::GetTo}
-
-\func{wxShape *}{GetTo}{\void}
-
-Gets the `to' object.
-
-\membersection{wxLineShape::Initialise}
-
-\func{void}{Initialise}{\void}
-
-Initialises the line object.
-
-\membersection{wxLineShape::InsertLineControlPoint}
-
-\func{void}{InsertLineControlPoint}{\void}
-
-Inserts a control point at an arbitrary position.
-
-\membersection{wxLineShape::IsEnd}
-
-\func{bool}{IsEnd}{\param{wxShape *}{shape}}
-
-Returns TRUE if {\it shape} is at the end of the line.
-
-\membersection{wxLineShape::IsSpline}
-
-\func{bool}{IsSpline}{\void}
-
-Returns TRUE if a spline is drawn through the control points, and FALSE otherwise.
-
-\membersection{wxLineShape::MakeLineControlPoints}\label{wxlineshapemakelinecontrolpoints}
-
-\func{void}{MakeLineControlPoints}{\param{int}{ n}}
-
-Make a given number of control points (minimum of two).
-
-\membersection{wxLineShape::OnMoveLink}
-
-\func{void}{OnMoveLink}{\param{wxDC\&}{ dc}, \param{bool}{ moveControlPoints = TRUE}}
-
-Called when a connected object has moved, to move the link to
-correct position.
-
-\membersection{wxLineShape::SetAttachmentFrom}
-
-\func{void}{SetAttachmentTo}{\param{int}{ fromAttach}}
-
-Sets the `from' shape attachment.
-
-\membersection{wxLineShape::SetAttachments}
-
-\func{void}{SetAttachments}{\param{int}{ fromAttach}, \param{int}{ toAttach}}
-
-Specifies which object attachment points should be used at each end of the line.
-
-\membersection{wxLineShape::SetAttachmentTo}
-
-\func{void}{SetAttachmentTo}{\param{int}{ toAttach}}
-
-Sets the `to' shape attachment.
-
-\membersection{wxLineShape::SetEnds}
-
-\func{void}{SetEnds}{\param{double}{ x1}, \param{double}{ y1}, \param{double}{ x2}, \param{double}{ y2}}
-
-Sets the end positions of the line.
-
-\membersection{wxLineShape::SetFrom}
-
-\func{void}{SetFrom}{\param{wxShape *}{object}}
-
-Sets the `from' object for the line.
-
-\membersection{wxLineShape::SetIgnoreOffsets}
-
-\func{void}{SetIgnoreOffsets}{\param{bool}{ ignore}}
-
-Tells the shape whether to ignore offsets from the end of the line when drawing.
-
-\membersection{wxLineShape::SetSpline}
-
-\func{void}{SetSpline}{\param{bool}{ spline}}
-
-Specifies whether a spline is to be drawn through the control points (TRUE), or a line (FALSE).
-
-\membersection{wxLineShape::SetTo}
-
-\func{void}{SetTo}{\param{wxShape *}{object}}
-
-Sets the `to' object for the line.
-
-\membersection{wxLineShape::Straighten}
-
-\func{void}{Straighten}{\param{wxDC*}{ dc = NULL}}
-
-Straighten verticals and horizontals. {\it dc} is optional.
-
-\membersection{wxLineShape::Unlink}
-
-\func{void}{Unlink}{\void}
-
-Unlinks the line from the nodes at either end.
-
-\section{\class{wxPolygonShape}}\label{wxpolygonshape}
-
-A wxPolygonShape's shape is defined by a number of points passed to the object's
-constructor. It can be used to create new shapes such as diamonds and triangles.
-
-\wxheading{Derived from}
-
-\helpref{wxShape}{wxshape}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxPolygonShape::wxPolygonShape}
-
-\func{}{wxPolygonShape}{void}
-
-Constructor. Call \helpref{wxPolygonShape::Create}{wxpolygonshapecreate} to specify the polygon's vertices.
-
-\membersection{wxPolygonShape::\destruct{wxPolygonShape}}
-
-\func{}{\destruct{wxPolygonShape}}{\void}
-
-Destructor.
-
-\membersection{wxPolygonShape::Create}\label{wxpolygonshapecreate}
-
-\func{void}{Create}{\param{wxList*}{ points}}
-
-Takes a list of wxRealPoints; each point is an {\it offset} from the centre.
-The polygon's destructor will delete these points, so do not delete them yourself.
-
-\membersection{wxPolygonShape::AddPolygonPoint}
-
-\func{void}{AddPolygonPoint}{\param{int}{ pos = 0}}
-
-Add a control point after the given point.
-
-\membersection{wxPolygonShape::CalculatePolygonCentre}
-
-\func{void}{CalculatePolygonCentre}{\void}
-
-Recalculates the centre of the polygon.
-
-\membersection{wxPolygonShape::DeletePolygonPoint}
-
-\func{void}{DeletePolygonPoint}{\param{int}{ pos = 0}}
-
-Deletes a control point.
-
-\membersection{wxPolygonShape::GetPoints}
-
-\func{wxList *}{GetPoints}{\void}
-
-Returns a pointer to the internal list of polygon vertices (wxRealPoints).
-
-\membersection{wxPolygonShape::UpdateOriginalPoints}
-
-\func{void}{UpdateOriginalPoints}{\void}
-
-If we've changed the shape, must make the original
-points match the working points with this function.
-
-\section{\class{wxRectangleShape}}\label{wxrectangleshape}
-
-The wxRectangleShape has rounded or square corners.
-
-\wxheading{Derived from}
-
-\helpref{wxShape}{wxshape}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxRectangleShape::wxRectangleShape}
-
-\func{}{wxRectangleShape}{\param{double}{ width = 0.0}, \param{double}{ height = 0.0}}
-
-Constructor.
-
-\membersection{wxRectangleShape::\destruct{wxRectangleShape}}
-
-\func{}{\destruct{wxRectangleShape}}{\void}
-
-Destructor.
-
-\membersection{wxRectangleShape::SetCornerRadius}
-
-\func{void}{SetCornerRadius}{\param{double}{ radius}}
-
-Sets the radius of the rectangle's rounded corners. If the radius is zero, a non-rounded
-rectangle will be drawn. If the radius is negative, the value is the proportion of the
-smaller dimension of the rectangle.
-
-\section{\class{wxPseudoMetaFile}}\label{wxpseudometafile}
-
-A simple metafile-like class which can load data from a Windows metafile on all platforms.
-
-\wxheading{Derived from}
-
-wxObject
-
-\section{\class{wxShape}}\label{wxshape}
-
-The wxShape is the top-level, abstract object that all other
-objects are derived from. All common functionality is represented by
-wxShape's members, and overriden members that appear in derived
-classes and have behaviour as documented for wxShape, are not
-documented separately.
-
-\wxheading{Derived from}
-
-\helpref{wxShapeEvtHandler}{wxshapeevthandler}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxShape::wxShape}
-
-\func{}{wxShape}{\param{wxShapeCanvas*}{ canvas = NULL}}
-
-Constructs a new wxShape.
-
-\membersection{wxShape::\destruct{wxShape}}
-
-\func{}{\destruct{wxShape}}{\void}
-
-Destructor.
-
-\membersection{wxShape::AddLine}
-
-\func{void}{AddLine}{\param{wxLineShape*}{ line}, \param{wxShape*}{ other}, \param{int}{ attachFrom = 0}, \param{int}{ attachTo = 0},
- \param{int}{ positionFrom = -1}, \param{int}{ positionTo = -1}}
-
-Adds a line between the specified canvas shapes, at the specified attachment points.
-
-The position in the list of lines at each end can also be specified, so that the line will be drawn
-at a particular point on its attachment point.
-
-\membersection{wxShape::AddRegion}
-
-\func{void}{AddRegion}{\param{wxShapeRegion*}{ region}}
-
-Adds a region to the shape.
-
-\membersection{wxShape::AddText}
-
-\func{void}{AddText}{\param{const wxString\& }{string}}
-
-Adds a line of text to the shape's default text region.
-
-\membersection{wxShape::AddToCanvas}
-
-\func{void}{AddToCanvas}{\param{wxShapeCanvas*}{ theCanvas}, \param{wxShape*}{ addAfter=NULL}}
-
-Adds the shape to the canvas's shape list. If {\it addAfter} is
-non-NULL, will add the shape after this one.
-
-\membersection{wxShape::AncestorSelected}
-
-\constfunc{bool}{AncestorSelected}{\void}
-
-TRUE if the shape's ancestor is currently selected.
-
-\membersection{wxShape::ApplyAttachmentOrdering}\label{wxshapeapplyattachmentordering}
-
-\func{void}{ApplyAttachmentOrdering}{\param{wxList\&}{ linesToSort}}
-
-Applies the line ordering in {\it linesToSort} to the shape, to reorder the way lines are attached.
-
-\membersection{wxShape::AssignNewIds}
-
-\func{void}{AssignNewIds}{\void}
-
-Assigns new ids to this image and its children.
-
-\membersection{wxShape::Attach}\label{wxshapeattach}
-
-\func{void}{Attach}{\param{wxShapeCanvas*}{ can}}
-
-Sets the shape's internal canvas pointer to point to the given canvas.
-
-\membersection{wxShape::AttachmentIsValid}\label{wxshapeattachmentisvalid}
-
-\constfunc{bool}{AttachmentIsValid}{\param{int}{ attachment}}
-
-Returns TRUE if {\it attachment} is a valid attachment point.
-
-\membersection{wxShape::AttachmentSortTest}\label{wxshapeattachmentsorttest}
-
-\constfunc{bool}{AttachmentSortTest}{\param{int}{ attachment}, \param{const wxRealPoint\&}{ pt1},
- \param{const wxRealPoint\&}{ pt2}}
-
-Returns TRUE if {\it pt1} is less than or equal to {\it pt2}, in the sense
-that one point comes before another on an edge of the shape. {\it attachment} is
-the attachment point (side) in question.
-
-This function is used in \helpref{wxShape::MoveLineToNewAttachment}{wxshapemovelinetonewattachment} to
-determine the new line ordering.
-
-\membersection{wxShape::CalcSimpleAttachment}\label{wxshapecalcsimpleattachment}
-
-\func{wxRealPoint}{CalcSimpleAttachment}{\param{const wxRealPoint\&}{ pt1},
- \param{const wxRealPoint\&}{ pt2}, \param{int}{ nth}, \param{int}{ noArcs}, \param{wxLineShape*}{ line}}
-
-Assuming the attachment lies along a vertical or horizontal line,
-calculates the position on that point.
-
-\wxheading{Parameters}
-
-\docparam{pt1}{The first point of the line repesenting the edge of the shape.}
-
-\docparam{pt2}{The second point of the line representing the edge of the shape.}
-
-\docparam{nth}{The position on the edge (for example there may be 6 lines at this attachment point,
-and this may be the 2nd line.}
-
-\docparam{noArcs}{The number of lines at this edge.}
-
-\docparam{line}{The line shape.}
-
-\wxheading{Remarks}
-
-This function expects the line to be either vertical or horizontal, and determines which.
-
-\membersection{wxShape::CalculateSize}
-
-\func{void}{CalculateSize}{\void}
-
-Called to calculate the shape's size if dependent on children sizes.
-
-\membersection{wxShape::ClearAttachments}
-
-\func{void}{ClearAttachments}{\void}
-
-Clears internal custom attachment point shapes (of class wxAttachmentPoint).
-
-\membersection{wxShape::ClearRegions}
-
-\func{void}{ClearRegions}{\void}
-
-Clears the wxShapeRegions from the shape.
-
-\membersection{wxShape::ClearText}
-
-\func{void}{ClearText}{\param{int}{ regionId = 0}}
-
-Clears the text from the specified text region.
-
-\membersection{wxShape::Constrain}
-
-\func{bool}{Constrain}{\void}
-
-Calculates the shape's constraints (if any). Applicable
-only to wxCompositeShape, does nothing if the shape is of
-a different class.
-
-\membersection{wxShape::Copy}\label{wxshapecopy}
-
-\func{void}{Copy}{\param{wxShape\&}{ copy}}
-
-Copy this shape into {\it copy}. Every derived class must have one of these, and each Copy implementation
-must call the derived class's implementation to ensure everything is copied. See also \helpref{wxShape::CreateNewCopy}{wxshapecreatenewcopy}.
-
-\membersection{wxShape::CreateNewCopy}\label{wxshapecreatenewcopy}
-
-\func{wxShape* }{CreateNewCopy}{\param{bool}{ resetMapping = TRUE}, \param{bool}{ recompute = TRUE}}
-
-Creates and returns a new copy of this shape (calling \helpref{wxShape::Copy}{wxshapecopy}). Do not override this function.
-
-This function should always be used to create a new copy, since it must do special processing
-for copying constraints associated with constraints.
-
-If {\it resetMapping} is TRUE, a mapping table used for complex shapes is reset; this may not be desirable
-if the shape being copied is a child of a composite (and so the mapping table is in use).
-
-If {\it recompute} is TRUE, \helpref{wxShape::Recompute}{wxshaperecompute} is called for the new shape.
-
-\wxheading{Remarks}
-
-This function uses the wxWindows dynamic object creation system to create a new shape of the same
-type as `this', before calling Copy.
-
-If the event handler for this shape is not the same as the shape itself, the event handler is also copied
-using \helpref{wxShapeEvtHandler::CreateNewCopy}{wxshapeevthandlercreatenewcopy}.
-
-\membersection{wxShape::DeleteControlPoints}
-
-\func{void}{DeleteControlPoints}{\void}
-
-Deletes the control points (or handles) for the shape. Does not redraw
-the shape.
-
-\membersection{wxShape::Detach}
-
-\func{void}{Detach}{\void}
-
-Disassociates the shape from its canvas by setting the internal shape
-canvas pointer to NULL.
-
-\membersection{wxShape::Draggable}
-
-\func{bool}{Draggable}{\void}
-
-TRUE if the shape may be dragged by the user.
-
-\membersection{wxShape::Draw}
-
-\func{void}{Draw}{\param{wxDC\&}{ dc}}
-
-Draws the whole shape and any lines attached to it.
-
-Do not override this function: override OnDraw, which is called
-by this function.
-
-\membersection{wxShape::DrawContents}
-
-\func{void}{DrawContents}{\param{wxDC\&}{ dc}}
-
-Draws the internal graphic of the shape (such as
-text).
-
-Do not override this function: override OnDrawContents, which is called
-by this function.
-
-\membersection{wxShape::DrawLinks}
-
-\func{void}{DrawLinks}{\param{wxDC\&}{ dc}, \param{int}{ attachment = -1}}
-
-Draws any lines linked to this shape.
-
-\membersection{wxShape::Erase}
-
-\func{void}{Erase}{\param{wxDC\&}{ dc}}
-
-Erases the shape, but does not repair damage caused to other
-shapes.
-
-\membersection{wxShape::EraseContents}
-
-\func{void}{EraseContents}{\param{wxDC\&}{ dc}}
-
-Erases the shape contents, that is, the area within the shape's
-minimum bounding box.
-
-\membersection{wxShape::EraseLinks}
-
-\func{void}{EraseLinks}{\param{wxDC\&}{ dc}, \param{int}{ attachment = -1}}
-
-Erases links attached to this shape, but does not repair
-damage caused to other shapes.
-
-\membersection{wxShape::FindRegion}
-
-\func{wxShape *}{FindRegion}{\param{const wxString\& }{regionName}, \param{int *}{regionId}}
-
-Finds the actual image (`this' if non-composite) and region id for the given
-region name.
-
-\membersection{wxShape::FindRegionNames}
-
-\func{void}{FindRegionNames}{\param{wxStringList\&}{ list}}
-
-Finds all region names for this image (composite or simple).
-Supply an empty string list.
-
-\membersection{wxShape::Flash}
-
-\func{void}{Flash}{\void}
-
-Flashes the shape.
-
-\membersection{wxShape::FormatText}
-
-\func{void}{FormatText}{\param{const wxString\& }{s}, \param{int}{ i = 0}}
-
-Reformats the given text region; defaults to formatting the default region.
-
-\membersection{wxShape::GetAttachmentMode}
-
-\constfunc{bool}{GetAttachmentMode}{\void}
-
-Returns the attachment mode, which is TRUE if attachments are used, FALSE otherwise (in which case
-lines will be drawn as if to the centre of the shape). See \helpref{wxShape::SetAttachmentMode}{wxshapesetattachmentmode}.
-
-\membersection{wxShape::GetAttachmentPosition}\label{wxshapegetattachmentposition}
-
-\func{bool}{GetAttachmentPosition}{\param{int}{ attachment}, \param{double*}{ x}, \param{double*}{ y},
- \param{int}{ nth = 0}, \param{int}{ noArcs = 1}, \param{wxLineShape*}{ line = NULL}}
-
-Gets the position at which the given attachment point should be drawn.
-
-If {\it attachment} isn't found among the attachment points of the shape, returns FALSE.
-
-\membersection{wxShape::GetBoundingBoxMax}
-
-\func{void}{GetBoundingBoxMax}{\param{double *}{width}, \param{double *}{height}}
-
-Gets the maximum bounding box for the shape, taking into
-account external features such as shadows.
-
-\membersection{wxShape::GetBoundingBoxMin}
-
-\func{void}{GetBoundingBoxMin}{\param{double *}{width}, \param{double *}{height}}
-
-Gets the minimum bounding box for the shape, that defines
-the area available for drawing the contents (such as text).
-
-\membersection{wxShape::GetBrush}
-
-\constfunc{wxBrush*}{GetBrush}{\void}
-
-Returns the brush used for filling the shape.
-
-\membersection{wxShape::GetCanvas}
-
-\constfunc{wxShapeCanvas*}{GetCanvas}{\void}
-
-Gets the internal canvas pointer.
-
-\membersection{wxShape::GetCentreResize}
-
-\constfunc{bool}{GetCentreResize}{\void}
-
-Returns TRUE if the shape is to be resized from the centre (the centre
-stands still), or FALSE if from the corner or side being dragged (the
-other corner or side stands still).
-
-\membersection{wxShape::GetChildren}
-
-\constfunc{wxList\&}{GetChildren}{\void}
-
-Returns a reference to the list of children for this shape.
-
-\membersection{wxShape::GetClientData}
-
-\func{wxObject*}{GetClientData}{\void}
-
-Gets the client data associated with the shape (NULL if there is
-none).
-
-\membersection{wxShape::GetDisableLabel}
-
-\constfunc{bool}{GetDisableLabel}{\void}
-
-Returns TRUE if the default region will not be shown, FALSE otherwise.
-
-\membersection{wxShape::GetEventHandler}
-
-\constfunc{wxShapeEvtHandler*}{GetEventHandler}{\void}
-
-Returns the event handler for this shape.
-
-\membersection{wxShape::GetFixedHeight}
-
-\constfunc{bool}{GetFixedHeight}{\void}
-
-Returns TRUE if the shape cannot be resized in the vertical plane.
-
-\membersection{wxShape::GetFixedSize}
-
-\func{void}{GetFixedSize}{\param{bool *}{ x}, \param{bool *}{ y}}
-
-Returns flags indicating whether the shape is of fixed size in either direction.
-
-\membersection{wxShape::GetFixedWidth}
-
-\constfunc{bool}{GetFixedWidth}{\void}
-
-Returns TRUE if the shape cannot be resized in the horizontal plane.
-
-\membersection{wxShape::GetFont}
-
-\constfunc{wxFont*}{GetFont}{\param{int}{ regionId = 0}}
-
-Gets the font for the specified text region.
-
-\membersection{wxShape::GetFunctor}
-
-\constfunc{wxString}{GetFunctor}{\void}
-
-Gets a string representing the type of the shape, to be used when
-writing out shape descriptions to a file. This is overridden by
-each derived shape class to provide an appropriate type string. By default,
-"node\_image" is used for non-line shapes, and "arc\_image" for lines.
-
-\membersection{wxShape::GetId}
-
-\constfunc{long}{GetId}{\void}
-
-Returns the integer identifier for this shape.
-
-\membersection{wxShape::GetLinePosition}\label{wxshapegetlineposition}
-
-\func{int}{GetLinePosition}{\param{wxLineShape*}{ line}}
-
-Gets the zero-based position of {\it line} in the list of lines for this shape.
-
-\membersection{wxShape::GetLines}
-
-\constfunc{wxList\&}{GetLines}{\void}
-
-Returns a reference to the list of lines connected to this shape.
-
-\membersection{wxShape::GetMaintainAspectRatio}\label{wxshapegetmaintainaspectratio}
-
-\constfunc{bool}{GetMaintainAspectRatio}{\void}
-
-If returns TRUE, resizing the shape will not change the aspect ratio
-(width and height will be in the original proportion).
-
-\membersection{wxShape::GetNumberOfAttachments}\label{wxshapegetnumberofattachments}
-
-\constfunc{int}{GetNumberOfAttachments}{\void}
-
-Gets the number of attachment points for this shape.
-
-\membersection{wxShape::GetNumberOfTextRegions}
-
-\constfunc{int}{GetNumberOfTextRegions}{\void}
-
-Gets the number of text regions for this shape.
-
-\membersection{wxShape::GetParent}
-
-\constfunc{wxShape *}{GetParent}{\void}
-
-Returns the parent of this shape, if it is part of a composite.
-
-\membersection{wxShape::GetPen}
-
-\constfunc{wxPen*}{GetPen}{\void}
-
-Returns the pen used for drawing the shape's outline.
-
-\membersection{wxShape::GetPerimeterPoint}
-
-\func{bool}{GetPerimeterPoint}{\param{double}{ x1}, \param{double}{ y1}, \param{double}{ x2}, \param{double}{ y2}, \param{double *}{x3}, \param{double *}{y3}}
-
-Gets the point at which the line from (x1, y1) to (x2, y2) hits the shape. Returns TRUE if the
-line hits the perimeter.
-
-\membersection{wxShape::GetRegionId}\label{getregionid}
-
-\func{int}{GetRegionId}{\param{const wxString\& }{name}}
-
-Gets the region's identifier by name. This is {\it not} unique for within an entire composite, but
-is unique for the image.
-
-\membersection{wxShape::GetRegionName}\label{getregionname}
-
-\func{wxString}{GetRegionName}{\param{int}{ regionId = 0}}
-
-Gets the region's name. A region's name can be used to uniquely determine a region within
-an entire composite image hierarchy. See also \helpref{wxShape::SetRegionName}{wxshapesetregionname}.
-
-\membersection{wxShape::GetRegions}\label{getregions}
-
-\func{wxList\&}{GetRegions}{\void}
-
-Returns the list of wxShapeRegions.
-
-\membersection{wxShape::GetRotation}
-
-\constfunc{double}{GetRotatation}{\void}
-
-Returns the angle of rotation in radians.
-
-\membersection{wxShape::GetSensitivityFilter}
-
-\constfunc{void}{GetSensitivityFilter}{\void}
-
-Returns the sensitivity filter, a bitlist of values. See \helpref{wxShape::SetSensitivityFilter}{wxshapesetsensitivityfilter}.
-
-\membersection{wxShape::GetShadowMode}
-
-\constfunc{int}{SetShadowMode}{\void}
-
-Returns the shadow mode. See \helpref{wxShape::SetShadowMode}{wxshapesetshadowmode}.
-
-\membersection{wxShape::GetSpaceAttachments}
-
-\constfunc{bool}{GetSpaceAttachments}{\void}
-
-Indicates whether lines should be spaced out evenly at the point they touch the node (TRUE), or whether they
-should join at a single point (FALSE).
-
-\membersection{wxShape::GetTextColour}
-
-\constfunc{wxString}{GetTextColour}{\param{int}{ regionId = 0}}
-
-Gets the colour for the specified text region.
-
-\membersection{wxShape::GetTopAncestor}
-
-\constfunc{wxShape *}{GetTopAncestor}{\void}
-
-Returns the top-most ancestor of this shape (the root of the composite).
-
-\membersection{wxShape::GetX}
-
-\constfunc{double}{GetX}{\void}
-
-Gets the x position of the centre of the shape.
-
-\membersection{wxShape::GetY}
-
-\constfunc{double}{GetY}{\void}
-
-Gets the y position of the centre of the shape.
-
-\membersection{wxShape::HitTest}
-
-\func{bool}{HitTest}{\param{double}{ x}, \param{double}{ y}, \param{int*}{ attachment}, \param{double*}{ distance}}
-
-Given a point on a canvas, returns TRUE if the point was on the shape, and returns
-the nearest attachment point and distance from the given point and target.
-
-\membersection{wxShape::Insert}
-
-\func{void}{InsertInCanvas}{\param{wxShapeCanvas*}{ canvas}}
-
-Inserts the shape at the front of the shape list of {\it canvas}.
-
-\membersection{wxShape::IsHighlighted}
-
-\constfunc{bool}{IsHighlighted}{\void}
-
-Returns TRUE if the shape is highlighted. Shape highlighting is unimplemented.
-
-\membersection{wxShape::IsShown}
-
-\constfunc{bool}{IsShown}{\void}
-
-Returns TRUE if the shape is in a visible state, FALSE otherwise. Note
-that this has nothing to do with whether the window is hidden or the
-shape has scrolled off the canvas; it refers to the internal
-visibility flag.
-
-\membersection{wxShape::MakeControlPoints}
-
-\func{void}{MakeControlPoints}{\void}
-
-Make a list of control points (draggable handles) appropriate to the shape.
-
-\membersection{wxShape::MakeMandatoryControlPoints}
-
-\func{void}{MakeMandatoryControlPoints}{\void}
-
-Make the mandatory control points. For example, the control point on a dividing line should
-appear even if the divided rectangle shape's handles should not appear (because it is the child of
-a composite, and children are not resizable).
-
-\membersection{wxShape::Move}\label{wxshapemove}
-
-\func{void}{Move}{\param{wxDC\&}{ dc}, \param{double}{ x1}, \param{double}{ y1}, \param{bool}{ display = TRUE}}
-
-Move the shape to the given position, redrawing if {\it display} is TRUE.
-
-\membersection{wxShape::MoveLineToNewAttachment}\label{wxshapemovelinetonewattachment}
-
-\func{void}{MoveLineToNewAttachment}{\param{wxDC\&}{ dc}, \param{wxLineShape*}{ toMove}, \param{double}{ x}, \param{double}{ y}}
-
-Move the given line (which must already be attached to the shape) to
-a different attachment point on the shape, or a different order on the same attachment.
-
-Cals \helpref{wxShape::AttachmentSortTest}{wxshapeattachmentsorttest} and then \helpref{wxShapeEvtHandler::OnChangeAttachment}{wxshapeevthandleronchangeattachment}.
-
-\membersection{wxShape::MoveLinks}
-
-\func{void}{MoveLinks}{\param{wxDC\&}{ dc}}
-
-Redraw all the lines attached to the shape.
-
-\membersection{wxShape::NameRegions}
-
-\func{void}{NameRegions}{\param{const wxString\& }{parentName = ``"}}
-
-Make unique names for all the regions in a shape or composite shape.
-
-\membersection{wxShape::Rotate}
-
-\func{void}{Rotate}{\param{double }{x}, \param{double }{y}, \param{double }{theta}}
-
-Rotate about the given axis by the given amount in radians (does nothing
-for most shapes). But even non-rotating shapes should record their
-notional rotation in case it's important (e.g. in dog-leg code).
-
-\membersection{wxShape::ReadConstraints}
-
-\func{void}{ReadConstraints}{\param{wxExpr *}{clause}, \param{wxExprDatabase *}{database}}
-
-If the shape is a composite, it may have constraints that need to be read in in a separate pass.
-
-\membersection{wxShape::ReadAttributes}
-
-\func{void}{ReadAttributes}{\param{wxExpr*}{ clause}}
-
-Reads the attributes (data member values) from the given expression.
-
-\membersection{wxShape::ReadRegions}
-
-\func{void}{ReadRegions}{\param{wxExpr *}{clause}}
-
-Reads in the regions.
-
-\membersection{wxShape::Recentre}
-
-\func{void}{Recentre}{\void}
-
-Does recentring (or other formatting) for all the text regions for this shape.
-
-\membersection{wxShape::RemoveFromCanvas}
-
-\func{void}{RemoveFromCanvas}{\param{wxShapeCanvas*}{ canvas}}
-
-Removes the shape from the canvas.
-
-\membersection{wxShape::ResetControlPoints}
-
-\func{void}{ResetControlPoints}{\void}
-
-Resets the positions of the control points (for instance when the
-shape's shape has changed).
-
-\membersection{wxShape::ResetMandatoryControlPoints}
-
-\func{void}{ResetMandatoryControlPoints}{\void}
-
-Reset the mandatory control points. For example, the control point on a dividing line should
-appear even if the divided rectangle shape's handles should not appear (because it is the child of
-a composite, and children are not resizable).
-
-\membersection{wxShape::Recompute}\label{wxshaperecompute}
-
-\func{bool}{Recompute}{\void}
-
-Recomputes any constraints associated with the shape (normally
-applicable to wxCompositeShapes only, but harmless for other
-classes of shape).
-
-\membersection{wxShape::RemoveLine}
-
-\func{void}{RemoveLine}{\param{wxLineShape*}{ line}}
-
-Removes the given line from the shape's list of attached lines.
-
-\membersection{wxShape::Select}\label{wxshapeselect}
-
-\func{void}{Select}{\param{bool}{ select = TRUE}}
-
-Selects or deselects the given shape, drawing or erasing control points
-(handles) as necessary.
-
-\membersection{wxShape::Selected}\label{wxshapeselected}
-
-\constfunc{bool}{Selected}{\void}
-
-TRUE if the shape is currently selected.
-
-\membersection{wxShape::SetAttachmentMode}\label{wxshapesetattachmentmode}
-
-\func{void}{SetAttachmentMode}{\param{bool}{ flag}}
-
-Sets the attachment mode to TRUE or FALSE. If TRUE, attachment points
-will be significant when drawing lines to and from this shape.
-If FALSE, lines will be drawn as if to the centre of the shape.
-
-\membersection{wxShape::SetBrush}
-
-\func{void}{SetBrush}{\param{wxBrush *}{brush}}
-
-Sets the brush for filling the shape's shape.
-
-\membersection{wxShape::SetCanvas}\label{wxshapesetcanvas}
-
-\func{void}{SetCanvas}{\param{wxShapeCanvas*}{ theCanvas}}
-
-Identical to \helpref{wxShape::Attach}{wxshapesetcanvas}.
-
-\membersection{wxShape::SetCentreResize}
-
-\func{void}{SetCentreResize}{\param{bool}{ cr}}
-
-Specify whether the shape is to be resized from the centre (the centre stands still) or from the corner or side
-being dragged (the other corner or side stands still).
-
-\membersection{wxShape::SetClientData}
-
-\func{void}{SetClientData}{\param{wxObject *}{clientData}}
-
-Sets the client data.
-
-\membersection{wxShape::SetDefaultRegionSize}\label{setdefaultregionsize}
-
-\func{void}{SetDefaultRegionSize}{\void}
-
-Set the default region to be consistent with the shape size.
-
-\membersection{wxShape::SetDisableLabel}
-
-\func{void}{SetDisableLabel}{\param{bool}{ flag}}
-
-Set {\it flag} to TRUE to stop the default region being shown, FALSE otherwise.
-
-\membersection{wxShape::SetDraggable}
-
-\func{void}{SetDraggable}{\param{bool}{ drag}, \param{bool}{ recursive = FALSE}}
-
-Sets the shape to be draggable or not draggable.
-
-\membersection{wxShape::SetDrawHandles}
-
-\func{void}{SetDrawHandles}{\param{bool}{ drawH}}
-
-Sets the {\it drawHandles} flag for this shape and all descendants. If {\it drawH} is TRUE (the default),
-any handles (control points) will be drawn. Otherwise, the handles will not be drawn.
-
-\membersection{wxShape::SetEventHandler}
-
-\func{void}{GetEventHandler}{\param{wxShapeEvtHandler *}{handler}}
-
-Sets the event handler for this shape.
-
-\membersection{wxShape::SetFixedSize}
-
-\func{void}{SetFixedSize}{\param{bool}{ x}, \param{bool}{ y}}
-
-Sets the shape to be of the given, fixed size.
-
-\membersection{wxShape::SetFont}
-
-\func{void}{SetFont}{\param{wxFont *}{font}, \param{int}{ regionId = 0}}
-
-Sets the font for the specified text region.
-
-\membersection{wxShape::SetFormatMode}\label{setformatmode}
-
-\func{void}{SetFormatMode}{\param{int}{ mode}, \param{int}{ regionId = 0}}
-
-Sets the format mode of the default text region. The argument can be a bit list
-of the following:
-
-\begin{description}\itemsep=0pt
-\item[FORMAT\_NONE] No formatting.
-\item[FORMAT\_CENTRE\_HORIZ] Horizontal centring.
-\item[FORMAT\_CENTRE\_VERT] Vertical centring.
-\end{description}
-
-\membersection{wxShape::SetHighlight}
-
-\func{void}{SetHighlight}{\param{bool}{ hi}, \param{bool}{ recurse = FALSE}}
-
-Sets the highlight for a shape. Shape highlighting is unimplemented.
-
-\membersection{wxShape::SetId}
-
-\func{void}{SetId}{\param{long}{ id}}
-
-Set the integer identifier for this shape.
-
-\membersection{wxShape::SetMaintainAspectRatio}\label{wxshapesetmaintainaspectratio}
-
-\func{void}{SetMaintainAspectRatio}{\param{bool}{ flag}}
-
-If the argument is TRUE, tells the shape that resizes should not change the aspect ratio
-(width and height should be in the original proportion).
-
-\membersection{wxShape::SetPen}
-
-\func{void}{SetPen}{\param{wxPen *}{pen}}
-
-Sets the pen for drawing the shape's outline.
-
-\membersection{wxShape::SetRegionName}\label{wxshapesetregionname}
-
-\func{void}{SetRegionName}{\param{const wxString\& }{name}, \param{int}{ regionId = 0}}
-
-Sets the name for this region. The name for a region is unique within the scope of the whole
-composite, whereas a region id is unique only for a single image.
-
-\membersection{wxShape::SetSensitivityFilter}\label{wxshapesetsensitivityfilter}
-
-\func{void}{SetSensitivityFilter}{\param{int}{ sens=OP\_ALL}, \param{bool}{ recursive = FALSE}}
-
-Sets the shape to be sensitive or insensitive to specific mouse operations.
-
-{\it sens} is a bitlist of the following:
-
-\begin{itemize}\itemsep=0pt
-\item OP\_CLICK\_LEFT
-\item OP\_CLICK\_RIGHT
-\item OP\_DRAG\_LEFT
-\item OP\_DRAG\_RIGHT
-\item OP\_ALL (equivalent to a combination of all the above).
-\end{itemize}
-
-\membersection{wxShape::SetShadowMode}\label{wxshapesetshadowmode}
-
-\func{void}{SetShadowMode}{\param{int}{ mode}, \param{bool}{ redraw = FALSE}}
-
-Sets the shadow mode (whether a shadow is drawn or not). {\it mode} can be one of
-the following:
-
-\begin{description}\itemsep=0pt
-\item[SHADOW\_NONE] No shadow (the default).
-\item[SHADOW\_LEFT] Shadow on the left side.
-\item[SHADOW\_RIGHT] Shadow on the right side.
-\end{description}
-
-\membersection{wxShape::SetSize}
-
-\func{void}{SetSize}{\param{double}{ x}, \param{double}{ y}, \param{bool}{ recursive = TRUE}}
-
-Sets the shape's size.
-
-\membersection{wxShape::SetSpaceAttachments}
-
-\func{void}{SetSpaceAttachments}{\param{bool}{ sp}}
-
-Indicate whether lines should be spaced out evenly at the point they touch the node (TRUE), or whether they
-should join at a single point (FALSE).
-
-\membersection{wxShape::SetTextColour}
-
-\func{void}{SetTextColour}{\param{const wxString\& }{colour}, \param{int}{ regionId = 0}}
-
-Sets the colour for the specified text region.
-
-\membersection{wxShape::SetX}
-
-\func{void}{SetX}{\param{double}{ x}}
-
-Sets the {\it x} position of the shape.
-
-\membersection{wxShape::SetX}
-
-\func{void}{SetY}{\param{double}{ y}}
-
-Sets the {\it y} position of the shape.
-
-\membersection{wxShape::SpaceAttachments}
-
-\func{void}{SpaceAttachments}{\param{bool}{ sp}}
-
-Sets the spacing mode: if TRUE, lines at the same attachment point will be
-spaced evenly across that side of the shape. If false, all lines at the
-same attachment point will emanate from the same point.
-
-\membersection{wxShape::Show}
-
-\func{void}{Show}{\param{bool}{ show}}
-
-Sets a flag indicating whether the shape should be drawn.
-
-\membersection{wxShape::Unlink}
-
-\func{void}{Unlink}{\void}
-
-If the shape is a line, unlinks the nodes attached to the shape, removing itself from the list of
-lines for each of the `to' and `from' nodes.
-
-\membersection{wxShape::WriteAttributes}
-
-\func{void}{WriteAttributes}{\param{wxExpr *}{clause}}
-
-Writes the shape's attributes (data member values) into the given expression.
-
-\membersection{wxShape::WriteRegions}
-
-\func{void}{WriteRegions}{\param{wxExpr *}{clause}}
-
-Writes the regions.
-
-\section{\class{wxShapeCanvas}}\label{wxshapecanvas}
-
-A canvas for drawing diagrams on.
-
-\wxheading{Derived from}
-
-wxScrolledWindow
-
-\wxheading{See also}
-
-\helpref{wxDiagram}{wxdiagram}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxShapeCanvas::wxShapeCanvas}
-
-\func{}{wxShapeCanvas}{\param{wxWindow*}{ parent = NULL}, \param{wxWindowID}{ id = -1},
- \param{const wxPoint\&}{ pos = wxDefaultPosition}, \param{const wxSize\&}{ size = wxDefaultSize},
- \param{long}{ style = wxBORDER}}
-
-Constructor.
-
-\membersection{wxShapeCanvas::\destruct{wxShapeCanvas}}
-
-\func{}{\destruct{wxShapeCanvas}}{\void}
-
-Destructor.
-
-\membersection{wxShapeCanvas::AddShape}
-
-\func{void}{AddShape}{\param{wxShape *}{shape}, \param{wxShape *}{addAfter = NULL}}
-
-Adds a shape to the diagram. If {\it addAfter} is non-NULL, the shape will be added after this
-one.
-
-\membersection{wxShapeCanvas::FindShape}
-
-\func{wxShape *}{FindShape}{\param{double}{ x1}, \param{double}{ y}, \param{int *}{attachment}, \param{wxClassInfo *}{info = NULL},
- \param{wxShape *}{notImage = NULL}}
-
-Find a shape under this mouse click. Returns the shape (or NULL), and the nearest attachment point.
-
-If {\it info} is non-NULL, a shape whose class which is a descendant of the desired class is found.
-
-If {\it notImage} is non-NULL, shapes which are descendants of {\it notImage} are ignored.
-
-\membersection{wxShapeCanvas::FindFirstSensitiveShape}
-
-\func{wxShape *}{FindFirstSensitiveShape}{\param{double}{ x1}, \param{double}{ y}, \param{int *}{attachment}, \param{int}{ op}}
-
-Finds the first sensitive shape whose sensitivity filter matches {\it op}, working up the hierarchy of composites until
-one (or none) is found.
-
-\membersection{wxShapeCanvas::GetDiagram}
-
-\constfunc{wxDiagram*}{GetDiagram}{\void}
-
-Returns the canvas associated with this diagram.
-
-\membersection{wxShapeCanvas::GetGridSpacing}
-
-\constfunc{double}{GetGridSpacing}{\void}
-
-Returns the grid spacing.
-
-\membersection{wxShapeCanvas::GetMouseTolerance}
-
-\constfunc{int}{GetMouseTolerance}{\void}
-
-Returns the tolerance within which a mouse move is ignored.
-
-\membersection{wxShapeCanvas::GetShapeList}
-
-\constfunc{wxList*}{GetShapeList}{\void}
-
-Returns a pointer to the internal shape list.
-
-\membersection{wxShapeCanvas::GetQuickEditMode}
-
-\constfunc{bool}{GetQuickEditMode}{\void}
-
-Returns quick edit mode for the associated diagram.
-
-\membersection{wxShapeCanvas::InsertShape}
-
-\func{void}{InsertShape}{\param{wxShape*}{ shape}}
-
-Inserts a shape at the front of the shape list.
-
-\membersection{wxShapeCanvas::OnBeginDragLeft}\label{wxshapecanvasonbegindragleft}
-
-\func{void}{OnBeginDragLeft}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
-
-Called when the start of a left-button drag event on the canvas background is detected by OnEvent. You may override this member;
-by default it does nothing.
-
-{\it keys} is a bit list of the following:
-
-\begin{itemize}\itemsep=0pt
-\item KEY\_SHIFT
-\item KEY\_CTRL
-\end{itemize}
-
-See also \helpref{wxShapeCanvas::OnDragLeft}{wxshapecanvasondragleft}, \helpref{wxShapeCanvas::OnEndDragLeft}{wxshapecanvasonenddragleft}.
-
-\membersection{wxShapeCanvas::OnBeginDragRight}\label{wxshapecanvasonbegindragright}
-
-\func{void}{OnBeginDragRight}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
-
-Called when the start of a right-button drag event on the canvas background is detected by OnEvent. You may override this member;
-by default it does nothing.
-
-{\it keys} is a bit list of the following:
-
-\begin{itemize}\itemsep=0pt
-\item KEY\_SHIFT
-\item KEY\_CTRL
-\end{itemize}
-
-See also \helpref{wxShapeCanvas::OnDragRight}{wxshapecanvasondragright}, \helpref{wxShapeCanvas::OnEndDragRight}{wxshapecanvasonenddragright}.
-
-\membersection{wxShapeCanvas::OnEndDragLeft}\label{wxshapecanvasonenddragleft}
-
-\func{void}{OnEndDragLeft}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
-
-Called when the end of a left-button drag event on the canvas background is detected by OnEvent. You may override this member;
-by default it does nothing.
-
-{\it keys} is a bit list of the following:
-
-\begin{itemize}\itemsep=0pt
-\item KEY\_SHIFT
-\item KEY\_CTRL
-\end{itemize}
-
-See also \helpref{wxShapeCanvas::OnDragLeft}{wxshapecanvasondragleft}, \helpref{wxShapeCanvas::OnBeginDragLeft}{wxshapecanvasonbegindragleft}.
-
-\membersection{wxShapeCanvas::OnEndDragRight}\label{wxshapecanvasonenddragright}
-
-\func{void}{OnEndDragRight}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
-
-Called when the end of a right-button drag event on the canvas background is detected by OnEvent. You may override this member;
-by default it does nothing.
-
-{\it keys} is a bit list of the following:
-
-\begin{itemize}\itemsep=0pt
-\item KEY\_SHIFT
-\item KEY\_CTRL
-\end{itemize}
-
-See also \helpref{wxShapeCanvas::OnDragRight}{wxshapecanvasondragright}, \helpref{wxShapeCanvas::OnBeginDragRight}{wxshapecanvasonbegindragright}.
-
-\membersection{wxShapeCanvas::OnDragLeft}\label{wxshapecanvasondragleft}
-
-\func{void}{OnDragLeft}{\param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
-
-Called when a left-button drag event on the canvas background is detected by OnEvent. You may override this member;
-by default it does nothing.
-
-{\it draw} is alternately TRUE and FALSE, to assist drawing and erasing.
-
-{\it keys} is a bit list of the following:
-
-\begin{itemize}\itemsep=0pt
-\item KEY\_SHIFT
-\item KEY\_CTRL
-\end{itemize}
-
-See also \helpref{wxShapeCanvas::OnBeginDragLeft}{wxshapecanvasonbegindragleft}, \helpref{wxShapeCanvas::OnEndDragLeft}{wxshapecanvasonenddragleft}.
-
-\membersection{wxShapeCanvas::OnDragRight}\label{wxshapecanvasondragright}
-
-\func{void}{OnDragRight}{\param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
-
-Called when a right-button drag event on the canvas background is detected by OnEvent. You may override this member;
-by default it does nothing.
-
-{\it draw} is alternately TRUE and FALSE, to assist drawing and erasing.
-
-{\it keys} is a bit list of the following:
-
-\begin{itemize}\itemsep=0pt
-\item KEY\_SHIFT
-\item KEY\_CTRL
-\end{itemize}
-
-See also \helpref{wxShapeCanvas::OnBeginDragRight}{wxshapecanvasonbegindragright}, \helpref{wxShapeCanvas::OnEndDragRight}{wxshapecanvasonenddragright}.
-
-\membersection{wxShapeCanvas::OnLeftClick}\label{wxshapecanvasonleftclick}
-
-\func{void}{OnLeftClick}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
-
-Called when a left click event on the canvas background is detected by OnEvent. You may override this member;
-by default it does nothing.
-
-{\it keys} is a bit list of the following:
-
-\begin{itemize}\itemsep=0pt
-\item KEY\_SHIFT
-\item KEY\_CTRL
-\end{itemize}
-
-\membersection{wxShapeCanvas::OnRightClick}\label{wxshapecanvasonrightclick}
-
-\func{void}{OnRightClick}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
-
-Called when a right click event on the canvas background is detected by OnEvent. You may override this member;
-by default it does nothing.
-
-{\it keys} is a bit list of the following:
-
-\begin{itemize}\itemsep=0pt
-\item KEY\_SHIFT
-\item KEY\_CTRL
-\end{itemize}
-
-\membersection{wxShapeCanvas::Redraw}
-
-\func{void}{Redraw}{\void}
-
-Calls wxDiagram::Redraw.
-
-\membersection{wxShapeCanvas::RemoveShape}
-
-\func{void}{RemoveShape}{\param{wxShape *}{shape}}
-
-Calls wxDiagram::RemoveShape.
-
-\membersection{wxShapeCanvas::SetDiagram}
-
-\func{void}{SetDiagram}{\param{wxDiagram *}{diagram}}
-
-Sets the diagram associated with this diagram.
-
-\membersection{wxShapeCanvas::Snap}
-
-\func{void}{Snap}{\param{double *}{x}, \param{double *}{y}}
-
-Calls wxDiagram::Snap.
-
-
-
-\section{\class{wxShapeEvtHandler}}\label{wxshapeevthandler}
-
-wxShapeEvtHandler is a class from which wxShape (and therefore all shape classes) are derived.
-A wxShape also contains a pointer to its current wxShapeEvtHandler. Event handlers
-can be swapped in and out, altering the behaviour of a shape. This allows, for example,
-a range of behaviours to be redefined in one class, rather than requiring
-each shape class to be subclassed.
-
-\wxheading{Derived from}
-
-wxObject
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxShapeEvtHandler::m\_handlerShape}
-
-\member{wxShape*}{m\_handlerShape}
-
-Pointer to the shape associated with this handler.
-
-\membersection{wxShapeEvtHandler::m\_previousHandler}
-
-\member{wxShapeEvtHandler*}{m\_previousHandler}
-
-Pointer to the previous handler.
-
-\membersection{wxShapeEvtHandler::wxShapeEvtHandler}
-
-\func{void}{wxShapeEvtHandler}{\param{wxShapeEvtHandler *}{previous = NULL}, \param{wxShape *}{shape = NULL}}
-
-Constructs a new event handler.
-
-\membersection{wxShapeEvtHandler::\destruct{wxShapeEvtHandler}}
-
-\func{void}{\destruct{wxShapeEvtHandler}}{\void}
-
-Destructor.
-
-\membersection{wxShapeEvtHandler::CopyData}\label{wxshapeevthandlercopydata}
-
-\func{void}{CopyData}{\param{wxShapeEvtHandler\&}{ handler}}
-
-A virtual function to copy the data from this object to {\it handler}. Override if you
-derive from wxShapeEvtHandler and have data to copy.
-
-\membersection{wxShapeEvtHandler::CreateNewCopy}\label{wxshapeevthandlercreatenewcopy}
-
-\func{wxShapeEvtHandler*}{CreateNewCopy}{\void}
-
-Creates a new event handler object of the same class as this object, and then
-calls \helpref{wxShapeEvtHandler::CopyData}{wxshapeevthandlercopydata}.
-
-\membersection{wxShapeEvtHandler::GetPreviousHandler}\label{wxshapeevthandlergetprevioushandler}
-
-\constfunc{wxShapeEvtHandler*}{GetPreviousHandler}{\void}
-
-Returns the previous handler.
-
-\membersection{wxShapeEvtHandler::GetShape}\label{wxshapeevthandlergetshape}
-
-\constfunc{wxShape*}{GetShape}{\void}
-
-Returns the shape associated with this handler.
-
-\membersection{wxShapeEvtHandler::OnBeginDragLeft}
-
-\func{void}{OnBeginDragLeft}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
-
-Called when the user is beginning to drag using the left mouse button.
-
-\membersection{wxShapeEvtHandler::OnBeginDragRight}
-
-\func{void}{OnBeginDragRight}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
-
-Called when the user is beginning to drag using the right mouse button.
-
-\membersection{wxShapeEvtHandler::OnBeginSize}
-
-\func{void}{OnBeginSize}{\param{double}{ width}, \param{double}{ height}}
-
-Called when a shape starts to be resized.
-
-\membersection{wxShapeEvtHandler::OnChangeAttachment}\label{wxshapeevthandleronchangeattachment}
-
-\func{void}{OnChangeAttachment}{\param{int}{ attachment}, \param{wxLineShape*}{ line}, \param{wxList\&}{ ordering}}
-
-Override this to prevent or intercept line reordering. wxShape's implementation of this function
-calls \helpref{wxShape::ApplyAttachmentOrdering}{wxshapeapplyattachmentordering} to apply
-the new ordering.
-
-\membersection{wxShapeEvtHandler::OnDragLeft}
-
-\func{void}{OnDragLeft}{\param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
-
-Called twice when the shape is being dragged, once to allow erasing the old
-image, and again to allow drawing at the new position.
-
-\membersection{wxShapeEvtHandler::OnDragRight}
-
-\func{void}{OnDragRight}{\param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
-
-Called twice when the shape is being dragged, once to allow erasing the old
-image, and again to allow drawing at the new position.
-
-\membersection{wxShapeEvtHandler::OnDraw}
-
-\func{void}{OnDraw}{\param{wxDC\&}{ dc}}
-
-Defined for each class to draw the main graphic, but
-not the contents.
-
-\membersection{wxShapeEvtHandler::OnDrawContents}
-
-\func{void}{OnDrawContents}{\param{wxDC\&}{ dc}}
-
-Defined for each class to draw the contents of the
-shape, such as text.
-
-\membersection{wxShapeEvtHandler::OnDrawControlPoints}
-
-\func{void}{OnDrawControlPoints}{\param{wxDC\&}{ dc}}
-
-Called when the shape's control points (handles) should
-be drawn.
-
-\membersection{wxShapeEvtHandler::OnDrawOutline}
-
-\func{void}{OnDrawOutline}{\param{wxDC\&}{ dc}}
-
-Called when the outline of the shape should be drawn.
-
-\membersection{wxShapeEvtHandler::OnEndDragLeft}
-
-\func{void}{OnEndDragLeft}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
-
-Called when the user is stopping dragging using the left mouse button.
-
-\membersection{wxShapeEvtHandler::OnEndDragRight}
-
-\func{void}{OnEndDragRight}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
-
-Called when the user is stopping dragging using the right mouse button.
-
-\membersection{wxShapeEvtHandler::OnEndSize}
-
-\func{void}{OnEndSize}{\param{double}{ width}, \param{double}{ height}}
-
-Called after a shape is resized.
-
-\membersection{wxShapeEvtHandler::OnErase}
-
-\func{void}{OnErase}{\param{wxDC\&}{ dc}}
-
-Called when the whole shape should be erased.
-
-\membersection{wxShapeEvtHandler::OnEraseContents}
-
-\func{void}{OnEraseContents}{\param{wxDC\&}{ dc}}
-
-Called when the contents should be erased.
-
-\membersection{wxShapeEvtHandler::OnEraseControlPoints}
-
-\func{void}{OnEraseControlPoints}{\param{wxDC\&}{ dc}}
-
-Called when the shape's control points (handles) should
-be erased.
-
-\membersection{wxShapeEvtHandler::OnHighlight}
-
-\func{void}{OnHighlight}{\param{wxDC\&}{ dc}}
-
-Called when the shape should be highlighted.
-
-\membersection{wxShapeEvtHandler::OnLeftClick}
-
-\func{void}{OnLeftClick}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys =0}, \param{int}{ attachment = 0}}
-
-Called when the shape receives a left mouse click event.
-
-\membersection{wxShapeEvtHandler::OnMoveLink}
-
-\func{void}{OnMoveLink}{\param{wxDC\&}{ dc}, \param{bool}{ moveControlPoints=TRUE}}
-
-Called when the line attached to an shape need to be repositioned,
-because the shape has moved.
-
-\membersection{wxShapeEvtHandler::OnMoveLinks}
-
-\func{void}{OnMoveLinks}{\param{wxDC\&}{ dc}}
-
-Called when the lines attached to an shape need to be repositioned,
-because the shape has moved.
-
-\membersection{wxShapeEvtHandler::OnMovePost}
-
-\func{bool}{OnMovePost}{\param{wxDC\&}{ dc}, \param{double}{ x}, \param{double}{ y}, \param{double}{ oldX}, \param{double}{ oldY}, \param{bool}{ display = TRUE}}
-
-Called just after the shape receives a move request.
-
-\membersection{wxShapeEvtHandler::OnMovePre}
-
-\func{bool}{OnMovePre}{\param{wxDC\&}{ dc}, \param{double}{ x}, \param{double}{ y}, \param{double}{ oldX}, \param{double}{ oldY}, \param{bool}{ display = TRUE}}
-
-Called just before the shape receives a move request. Returning TRUE
-allows the move to be processed; returning FALSE vetoes the move.
-
-\membersection{wxShapeEvtHandler::OnRightClick}
-
-\func{void}{OnRightClick}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}, \param{int}{ attachment = 0}}
-
-Called when the shape receives a mouse mouse click event.
-
-\membersection{wxShapeEvtHandler::OnSize}
-
-\func{void}{OnSize}{\param{double}{ x}, \param{double}{ y}}
-
-Called when the shape receives a resize request.
-
-\membersection{wxShapeEvtHandler::OnSizingBeginDragLeft}
-
-\func{void}{OnSizingBeginDragLeft}{\param{wxControlPoint*}{ pt}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
-
-Called when a sizing drag is beginning.
-
-\membersection{wxShapeEvtHandler::OnSizingDragLeft}
-
-\func{void}{OnSizingDragLeft}{\param{wxControlPoint*}{ pt}, \param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
-
-Called when a sizing drag is occurring.
-
-\membersection{wxShapeEvtHandler::OnSizingEndDragLeft}
-
-\func{void}{OnSizingEndDragLeft}{\param{wxControlPoint*}{ pt}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
-
-Called when a sizing drag is ending.
-
-\membersection{wxShapeEvtHandler::SetPreviousHandler}\label{wxshapeevthandlersetprevioushandler}
-
-\func{void}{SetPreviousHandler}{\param{wxShapeEvtHandler*}{ handler}}
-
-Sets the previous handler.
-
-\membersection{wxShapeEvtHandler::SetShape}\label{wxshapeevthandlersetshape}
-
-\func{void}{SetShape}{\param{wxShape*}{ shape}}
-
-Sets the shape for this handler.
-
-\section{\class{wxTextShape}}\label{wxtextshape}
-
-As wxRectangleShape, but only the text is displayed.
-
-\wxheading{Derived from}
-
-\helpref{wxRectangleShape}{wxrectangleshape}
-
-\latexignore{\rtfignore{\wxheading{Members}}}
-
-\membersection{wxTextShape::wxTextShape}
-
-\func{void}{wxTextShape}{\param{double}{ width = 0.0}, \param{double}{ height = 0.0}}
-
-Constructor.
-
-\membersection{wxTextShape::\destruct{wxTextShape}}
-
-\func{void}{\destruct{wxTextShape}}{\void}
-
-Destructor.
-
-\section{Functions}\label{functions}
-
-These are the OGL functions.
-
-\membersection{::wxOGLInitialize}
-
-\func{void}{wxOGLInitialize}{\void}
-
-Initializes OGL.
-
-\membersection{::wxOGLCleanUp}
-
-\func{void}{wxOGLCleanUp}{\void}
-
-Cleans up OGL.
-