]> git.saurik.com Git - wxWidgets.git/blob - utils/ogl/docs/classes.tex
Changes for next snapshot.
[wxWidgets.git] / utils / ogl / docs / classes.tex
1 \chapter{Class reference}\label{classref}
2 \setheader{{\it CHAPTER \thechapter}}{}{}{}{}{{\it CHAPTER \thechapter}}%
3 \setfooter{\thepage}{}{}{}{}{\thepage}
4
5 These are the main \ogl\ classes.
6
7 \section{\class{wxOGLConstraint}}\label{wxoglconstraint}
8
9 \overview{wxCompositeShape overview}{compositeshapeoverview}
10
11 An wxOGLConstraint object helps specify how child shapes are laid out with respect
12 to siblings and parents.
13
14 \wxheading{Derived from}
15
16 wxObject
17
18 \wxheading{See also}
19
20 \helpref{wxCompositeShape}{wxcompositeshape}
21
22 \latexignore{\rtfignore{\wxheading{Members}}}
23
24 \membersection{wxOGLConstraint::wxOGLConstraint}\label{wxoglconstraintconstr}
25
26 \func{}{wxOGLConstraint}{\void}
27
28 Default constructor.
29
30 \func{}{wxOGLConstraint}{\param{int}{ type}, \param{wxShape *}{constraining}, \param{wxList\& }{constrained}}
31
32 Constructor.
33
34 \wxheading{Parameters}
35
36 \docparam{constraining}{The shape which is used as the reference for positioning the {\it constrained} objects.}
37
38 \docparam{constrained}{Contains a list of wxShapes which are to be constrained (with respect
39 to {\it constraining}) using {\it type}.}
40
41 \docparam{type}{Can be one of:
42
43 \begin{itemize}\itemsep=0pt
44 \item {\bf gyCONSTRAINT\_CENTRED\_VERTICALLY}: the Y co-ordinates of the centres of the
45 bounding boxes of the constrained objects and the constraining object
46 will be the same
47 \item {\bf gyCONSTRAINT\_CENTRED\_HORIZONTALLY}: the X co-ordinates of the centres of the
48 bounding boxes of the constrained objects and the constraining object
49 will be the same
50 \item {\bf gyCONSTRAINT\_CENTRED\_BOTH}: the co-ordinates of the centres of the bounding boxes
51 of the constrained objects and the constraining object will be the same
52 \item {\bf gyCONSTRAINT\_LEFT\_OF}: the X co-ordinates of the right hand vertical edges
53 of the bounding boxes of the constrained objects will be less than
54 the X co-ordinate of the left hand vertical edge of the bounding box
55 of the constraining object
56 \item {\bf gyCONSTRAINT\_RIGHT\_OF}: the X co-ordinates of the left hand vertical edges
57 of the bounding boxes of the constrained objects will be greater than
58 the X co-ordinate of the right hand vertical edge of the bounding box
59 of the constraining object
60 \item {\bf gyCONSTRAINT\_ABOVE}: the Y co-ordinates of the bottom horizontal edges of the
61 bounding boxes of the constrained objects will be less than the
62 Y co-ordinate of the top horizontal edge of the bounding box of the
63 constraining object
64 \item {\bf gyCONSTRAINT\_BELOW}: the Y co-ordinates of the top horizontal edges of the
65 bounding boxes of the constrained objects will be greater than
66 the X co-ordinate of the bottom horizontal edge of the bounding box
67 of the constraining object
68 \item {\bf gyCONSTRAINT\_ALIGNED\_TOP}: the Y co-ordinates of the top horizontal edges of the
69 bounding boxes of the constrained objects will be the same as the
70 Y co-ordinate of the top horizontal edge of the bounding box of the
71 constraining object
72 \item {\bf gyCONSTRAINT\_ALIGNED\_BOTTOM}: the Y co-ordinates of the bottom horizontal edges
73 of the bounding boxes of the constrained objects will be the same as
74 the Y co-ordinate of the bottom horizontal edge of the bounding box
75 of the constraining object
76 \item {\bf gyCONSTRAINT\_ALIGNED\_LEFT}: the X co-ordinates of the left hand vertical edges
77 of the bounding boxes of the constrained objects will be the same as
78 the X co-ordinate of the left hand vertical edge of the bounding box
79 of the constraining object
80 \item {\bf gyCONSTRAINT\_ALIGNED\_RIGHT}: the X co-ordinates of the right hand vertical edges
81 of the bounding boxes of the constrained objects will be the same as
82 the X co-ordinate of the right hand vertical edge of the bounding box
83 of the constraining object
84 \item {\bf gyCONSTRAINT\_MIDALIGNED\_TOP}: the Y co-ordinates of the centres of
85 the bounding boxes of the constrained objects will be the same
86 as the Y co-ordinate of the top horizontal edge of
87 the bounding box of the constraining object
88 \item {\bf gyCONSTRAINT\_MIDALIGNED\_BOTTOM}: the Y co-ordinates of the centres of
89 the bounding boxes of the constrained objects will be the same
90 as the Y co-ordinate of the bottom horizontal edge of
91 the bounding box of the constraining object
92 \item {\bf gyCONSTRAINT\_MIDALIGNED\_LEFT}: the X co-ordinates of the centres of
93 the bounding boxes of the constrained objects will be the same
94 as the X co-ordinate of the left hand vertical edge of
95 the bounding box of the constraining object
96 \item {\bf gyCONSTRAINT\_MIDALIGNED\_RIGHT}: the X co-ordinates of the centres of
97 the bounding boxes of the constrained objects will be the same as
98 the X co-ordinate of the right hand vertical edge of
99 the bounding box of the constraining object
100 \end{itemize}
101 }
102
103 \membersection{wxOGLConstraint::\destruct{wxOGLConstraint}}
104
105 \func{}{\destruct{wxOGLConstraint}}{\void}
106
107 Destructor.
108
109 \membersection{wxOGLConstraint::Equals}
110
111 \func{bool}{Equals}{\param{double}{ x}, \param{double}{ y}}
112
113 Returns TRUE if {\it x} and {\it y} are approximately equal (for the purposes
114 of evaluating the constraint).
115
116 \membersection{wxOGLConstraint::Evaluate}
117
118 \func{bool}{Evaluate}{\void}
119
120 Evaluates this constraint, returning TRUE if anything changed.
121
122 \membersection{wxOGLConstraint::SetSpacing}\label{wxoglconstraintsetspacing}
123
124 \func{void}{SetSpacing}{\param{double}{ x}, \param{double}{ y}}
125
126 Sets the horizontal and vertical spacing for the constraint.
127
128 \section{\class{wxBitmapShape}}\label{wxbitmapshape}
129
130 Draws a bitmap (non-resizable).
131
132 \wxheading{Derived from}
133
134 \helpref{wxRectangleShape}{wxrectangleshape}
135
136 \latexignore{\rtfignore{\wxheading{Members}}}
137
138 \membersection{wxBitmapShape::wxBitmapShape}
139
140 \func{}{wxBitmapShape}{\void}
141
142 Constructor.
143
144 \membersection{wxBitmapShape::\destruct{wxBitmapShape}}
145
146 \func{}{\destruct{wxBitmapShape}}{\void}
147
148 Destructor.
149
150 \membersection{wxBitmapShape::GetBitmap}
151
152 \constfunc{wxBitmap\&}{GetBitmap}{\void}
153
154 Returns a reference to the bitmap associated with this shape.
155
156 \membersection{wxBitmapShape::GetFilename}
157
158 \constfunc{wxString}{GetFilename}{\void}
159
160 Returns the bitmap filename.
161
162 \membersection{wxBitmapShape::SetBitmap}
163
164 \func{void}{SetBitmap}{\param{const wxBitmap\&}{ bitmap}}
165
166 Sets the bitmap associated with this shape. You can delete the bitmap
167 from the calling application, since reference counting will take care of
168 holding on to the internal bitmap data.
169
170 \membersection{wxBitmapShape::SetFilename}
171
172 \func{void}{SetFilename}{\param{const wxString\& }{filename}}
173
174 Sets the bitmap filename.
175
176 \section{\class{wxDiagram}}\label{wxdiagram}
177
178 Encapsulates an entire diagram, with methods for reading/writing and drawing.
179 A diagram has an associated wxShapeCanvas.
180
181 \wxheading{Derived from}
182
183 wxObject
184
185 \wxheading{See also}
186
187 \helpref{wxShapeCanvas}{wxshapecanvas}
188
189 \latexignore{\rtfignore{\wxheading{Members}}}
190
191 \membersection{wxDiagram::wxDiagram}
192
193 \func{}{wxDiagram}{\void}
194
195 Constructor.
196
197 \membersection{wxDiagram::\destruct{wxDiagram}}
198
199 \func{}{\destruct{wxDiagram}}{\void}
200
201 Destructor.
202
203 \membersection{wxDiagram::AddShape}
204
205 \func{void}{AddShape}{\param{wxShape*}{shape}, \param{wxShape *}{addAfter = NULL}}
206
207 Adds a shape to the diagram. If {\it addAfter} is non-NULL, the shape will be added after this
208 one.
209
210 \membersection{wxDiagram::Clear}
211
212 \func{void}{Clear}{\param{wxDC\&}{ dc}}
213
214 Clears the specified device context.
215
216 \membersection{wxDiagram::DeleteAllShapes}
217
218 \func{void}{DeletesAllShapes}{\void}
219
220 Removes and deletes all shapes in the diagram.
221
222 \membersection{wxDiagram::DrawOutline}
223
224 \func{void}{DrawOutline}{\param{wxDC\&}{ dc}, \param{double}{ x1}, \param{double}{ y1}, \param{double}{ x2}, \param{double}{ y2}}
225
226 Draws an outline rectangle on the current device context.
227
228 \membersection{wxDiagram::FindShape}\label{wxdiagramfindshape}
229
230 \constfunc{wxShape*}{FindShape}{\param{long}{ id}}
231
232 Returns the shape for the given identifier.
233
234 \membersection{wxDiagram::GetCanvas}
235
236 \constfunc{wxShapeCanvas*}{GetCanvas}{\void}
237
238 Returns the shape canvas associated with this diagram.
239
240 \membersection{wxDiagram::GetCount}\label{wxdiagramgetcount}
241
242 \constfunc{int}{GetCount}{\void}
243
244 Returns the number of shapes in the diagram.
245
246 \membersection{wxDiagram::GetGridSpacing}
247
248 \constfunc{double}{GetGridSpacing}{\void}
249
250 Returns the grid spacing.
251
252 \membersection{wxDiagram::GetMouseTolerance}
253
254 \func{int}{GetMouseTolerance}{\void}
255
256 Returns the tolerance within which a mouse move is ignored.
257
258 \membersection{wxDiagram::GetShapeList}
259
260 \constfunc{wxList*}{GetShapeList}{\void}
261
262 Returns a pointer to the internal shape list.
263
264 \membersection{wxDiagram::GetQuickEditMode}
265
266 \constfunc{bool}{GetQuickEditMode}{\void}
267
268 Returns quick edit mode.
269
270 \membersection{wxDiagram::GetSnapToGrid}
271
272 \constfunc{bool}{GetSnapToGrid}{\void}
273
274 Returns snap-to-grid mode.
275
276 \membersection{wxDiagram::InsertShape}
277
278 \func{void}{InsertShape}{\param{wxShape *}{shape}}
279
280 Inserts a shape at the front of the shape list.
281
282 \membersection{wxDiagram::LoadFile}
283
284 \func{bool}{LoadFile}{\param{const wxString\& }{filename}}
285
286 Loads the diagram from a file.
287
288 \membersection{wxDiagram::OnDatabaseLoad}
289
290 \func{void}{OnDatabaseLoad}{\param{wxExprDatabase\&}{ database}}
291
292 Called just after the nodes and lines have been read from the wxExprDatabase. You may override this;
293 the default member does nothing.
294
295 \membersection{wxDiagram::OnDatabaseSave}
296
297 \func{void}{OnDatabaseSave}{\param{wxExprDatabase\&}{ database}}
298
299 Called just after the nodes and lines have been written to the wxExprDatabase. You may override this;
300 the default member does nothing.
301
302 \membersection{wxDiagram::OnHeaderLoad}
303
304 \func{bool}{OnHeaderLoad}{\param{wxExprDatabase\&}{ database}, \param{wxExpr\&}{ expr}}
305
306 Called to allow the `diagram' header object to be read. The default member reads no further information.
307 You may wish to override this to read version information, author name, etc.
308
309 \membersection{wxDiagram::OnHeaderSave}
310
311 \func{bool}{OnHeaderSave}{\param{wxExprDatabase\&}{ database}, \param{wxExpr\&}{ expr}}
312
313 Called to allow instantiation of the `diagram' header object. The default member writes no further information.
314 You may wish to override this to include version information, author name, etc.
315
316 \membersection{wxDiagram::OnShapeLoad}
317
318 \func{bool}{OnShapeLoad}{\param{wxExprDatabase\&}{ database}, \param{wxShape\&}{ shape}, \param{wxExpr\&}{ expr}}
319
320 Called to read the shape from the {\it expr}. You may override this, but call this function first.
321 The default member calls ReadAttributes for the shape.
322
323 \membersection{wxDiagram::OnShapeSave}
324
325 \func{bool}{OnShapeSave}{\param{wxExprDatabase\&}{ database}, \param{wxShape\&}{ shape}, \param{wxExpr\&}{ expr}}
326
327 Called to save the shape to the {\it expr} and {\it database}. You may override this, but call this function first.
328 The default member calls WriteAttributes for the shape, appends the shape to the database, and of the shape
329 is a composite, recursively calls OnShapeSave for its children.
330
331 \membersection{wxDiagram::ReadContainerGeometry}
332
333 \func{void}{ReadContainerGeometry}{\param{wxExprDatabase\&}{ database}}
334
335 Reads container geometry from a wxExprDatabase, linking up nodes which
336 are part of a composite. You probably won't need to redefine this.
337
338 \membersection{wxDiagram::ReadLines}
339
340 \func{void}{ReadLines}{\param{wxExprDatabase\&}{ database}}
341
342 Reads lines from a wxExprDatabase. You probably won't need to redefine this.
343
344 \membersection{wxDiagram::ReadNodes}
345
346 \func{void}{ReadNodes}{\param{wxExprDatabase\&}{ database}}
347
348 Reads nodes from a wxExprDatabase. You probably won't need to redefine this.
349
350 \membersection{wxDiagram::RecentreAll}
351
352 \func{void}{RecentreAll}{\param{wxDC\&}{ dc}}
353
354 Make sure all text that should be centred, is centred.
355
356 \membersection{wxDiagram::Redraw}
357
358 \func{void}{Redraw}{\param{wxDC\&}{ dc}}
359
360 Draws the shapes in the diagram on the specified device context.
361
362 \membersection{wxDiagram::RemoveAllShapes}
363
364 \func{void}{RemoveAllShapes}{\void}
365
366 Removes all shapes from the diagram but does not delete the shapes.
367
368 \membersection{wxDiagram::RemoveShape}
369
370 \func{void}{RemoveShape}{\param{wxShape*}{ shape}}
371
372 Removes the shape from the diagram (non-recursively) but does not delete it.
373
374 \membersection{wxDiagram::SaveFile}
375
376 \func{bool}{SaveFile}{\param{const wxString\& }{filename}}
377
378 Saves the diagram in a file.
379
380 \membersection{wxDiagram::SetCanvas}\label{wxdiagramsetcanvas}
381
382 \func{void}{SetCanvas}{\param{wxShapeCanvas*}{ canvas}}
383
384 Sets the canvas associated with this diagram.
385
386 \membersection{wxDiagram::SetGridSpacing}
387
388 \func{void}{SetGridSpacing}{\param{double}{ spacing}}
389
390 Sets the grid spacing. The default is 5.
391
392 \membersection{wxDiagram::SetMouseTolerance}
393
394 \func{void}{SetMouseTolerance}{\param{int}{ tolerance}}
395
396 Sets the tolerance within which a mouse move is ignored. The default is 3 pixels.
397
398 \membersection{wxDiagram::SetQuickEditMode}
399
400 \func{void}{SetQuickEditMode}{\param{bool}{ mode}}
401
402 Sets quick-edit-mode on or off. In this mode, refreshes are minimized, but the
403 diagram may need manual refreshing occasionally.
404
405 \membersection{wxDiagram::SetSnapToGrid}
406
407 \func{void}{SetSnapToGrid}{\param{bool}{ snap}}
408
409 Sets snap-to-grid mode on or off. The default is on.
410
411 \membersection{wxDiagram::ShowAll}
412
413 \func{void}{ShowAll}{\param{bool}{ show}}
414
415 Calls Show for each shape in the diagram.
416
417 \membersection{wxDiagram::Snap}
418
419 \func{void}{Snap}{\param{double *}{x}, \param{double *}{y}}
420
421 `Snaps' the coordinate to the nearest grid position, if snap-to-grid is on.
422
423 \section{\class{wxDrawnShape}}\label{wxdrawnshape}
424
425 Draws a pseduo-metafile shape, which can be loaded from a simple Windows metafile.
426
427 wxDrawnShape allows you to specify a different shape for each of four orientations (North, West,
428 South and East). It also provides a set of drawing functions for programmatic drawing of a shape,
429 so that during construction of the shape you can draw into it as if it were a device context.
430
431 \wxheading{Derived from}
432
433 \helpref{wxRectangleShape}{wxrectangleshape}
434
435 See also \helpref{wxRectangleShape}{wxrectangleshape}.
436
437 \latexignore{\rtfignore{\wxheading{Members}}}
438
439 \membersection{wxDrawnShape::wxDrawnShape}
440
441 \func{}{wxDrawnShape}{\void}
442
443 Constructor.
444
445 \membersection{wxDrawnShape::\destruct{wxDrawnShape}}
446
447 \func{}{\destruct{wxDrawnShape}}{\void}
448
449 Destructor.
450
451 \membersection{wxDrawnShape::CalculateSize}
452
453 \func{void}{CalculateSize}{\void}
454
455 Calculates the wxDrawnShape size from the current metafile. Call this after you have drawn
456 into the shape.
457
458 \membersection{wxDrawnShape::DestroyClippingRect}\label{wxdrawnshapedestroyclippingrect}
459
460 \func{void}{DestroyClippingRect}{\void}
461
462 Destroys the clipping rectangle. See also \helpref{wxDrawnShape::SetClippingRect}{wxdrawnshapesetclippingrect}.
463
464 \membersection{wxDrawnShape::DrawArc}\label{wxdrawnshapedrawarc}
465
466 \func{void}{DrawArc}{\param{const wxPoint\&}{ centrePoint}, \param{const wxPoint\&}{ startPoint},
467 \param{const wxPoint\&}{ endPoint}}
468
469 Draws an arc (see wxWindows documentation for details).
470
471 \membersection{wxDrawnShape::DrawAtAngle}\label{wxdrawnshapedrawatangle}
472
473 \func{void}{DrawAtAngle}{\param{int}{ angle}}
474
475 Sets the metafile for the given orientation, which can be one of:
476
477 \begin{itemize}\itemsep=0pt
478 \item oglDRAWN\_ANGLE\_0
479 \item oglDRAWN\_ANGLE\_90
480 \item oglDRAWN\_ANGLE\_180
481 \item oglDRAWN\_ANGLE\_270
482 \end{itemize}
483
484 See also \helpref{wxDrawnShape::GetAngle}{wxdrawnshapegetangle}.
485
486 \membersection{wxDrawnShape::DrawEllipticArc}\label{wxdrawnshapedrawellipticarc}
487
488 \func{void}{DrawEllipticArc}{\param{const wxRect\&}{ rect}, \param{double}{ startAngle}, \param{double}{ endAngle}}
489
490 Draws an elliptic arc (see wxWindows documentation for details).
491
492 \membersection{wxDrawnShape::DrawLine}\label{wxdrawnshapedrawline}
493
494 \func{void}{DrawLine}{\param{const wxPoint\&}{ point1}, \param{const wxPoint\&}{ point2}}
495
496 Draws a line from {\it point1} to {\it point2}.
497
498 \membersection{wxDrawnShape::DrawLines}\label{wxdrawnshapedrawlines}
499
500 \func{void}{DrawLines}{\param{int}{ n}, \param{wxPoint\&}{ points[]}}
501
502 Draws {\it n} lines.
503
504 \membersection{wxDrawnShape::DrawPoint}\label{wxdrawnshapedrawpoint}
505
506 \func{void}{DrawPoint}{\param{const wxPoint\&}{ point}}
507
508 Draws a point.
509
510 \membersection{wxDrawnShape::DrawPolygon}\label{wxdrawnshapedrawpolygon}
511
512 \func{void}{DrawPolygon}{\param{int}{ n}, \param{wxPoint\&}{ points[]}, \param{int}{ flags = 0}}
513
514 Draws a polygon. {\it flags} can be one or more of {\bf oglMETAFLAGS\_OUTLINE} (use this polygon for the drag outline)
515 and {\bf oglMETAFLAGS\_ATTACHMENTS} (use the vertices of this polygon for attachments).
516
517 \membersection{wxDrawnShape::DrawRectangle}\label{wxdrawnshapedrawrectangle}
518
519 \func{void}{DrawRectangle}{\param{const wxRect\&}{ rect}}
520
521 Draws a rectangle.
522
523 \membersection{wxDrawnShape::DrawRoundedRectangle}\label{wxdrawnshapedrawroundedrectangle}
524
525 \func{void}{DrawRoundedRectangle}{\param{const wxRect\&}{ rect}, \param{double}{ radius}}
526
527 Draws a rounded rectangle. {\it radius} is the corner radius. If {\it radius} is negative,
528 it expresses the radius as a proportion of the smallest dimension of the rectangle.
529
530 \membersection{wxDrawnShape::DrawSpline}\label{wxdrawnshapedrawspline}
531
532 \func{void}{DrawSpline}{\param{int}{ n}, \param{wxPoint\&}{ points[]}}
533
534 Draws a spline curve.
535
536 \membersection{wxDrawnShape::DrawText}\label{wxdrawnshapedrawtext}
537
538 \func{void}{DrawText}{\param{const wxString\&}{ text}, \param{const wxPoint\&}{ point}}
539
540 Draws text at the given point.
541
542 \membersection{wxDrawnShape::GetAngle}\label{wxdrawnshapegetangle}
543
544 \constfunc{int}{GetAngle}{\void}
545
546 Returns the current orientation, which can be one of:
547
548 \begin{itemize}\itemsep=0pt
549 \item oglDRAWN\_ANGLE\_0
550 \item oglDRAWN\_ANGLE\_90
551 \item oglDRAWN\_ANGLE\_180
552 \item oglDRAWN\_ANGLE\_270
553 \end{itemize}
554
555 See also \helpref{wxDrawnShape::DrawAtAngle}{wxdrawnshapedrawatangle}.
556
557 \membersection{wxDrawnShape::GetMetaFile}
558
559 \constfunc{wxPseudoMetaFile\& }{GetMetaFile}{\void}
560
561 Returns a reference to the internal `pseudo-metafile'.
562
563 \membersection{wxDrawnShape::GetRotation}\label{wxdrawnshapegetrotation}
564
565 \constfunc{double}{GetRotation}{\void}
566
567 Returns the current rotation of the shape in radians.
568
569 \membersection{wxDrawnShape::LoadFromMetaFile}
570
571 \func{bool}{LoadFromMetaFile}{\param{const wxString\& }{filename}}
572
573 Loads a (very simple) Windows metafile, created for example by Top Draw, the Windows shareware graphics package.
574
575 \membersection{wxDrawnShape::Rotate}
576
577 \func{void}{Rotate}{\param{double }{x}, \param{double }{y}, \param{double }{theta}}
578
579 Rotate about the given axis by the given amount in radians.
580
581 \membersection{wxDrawnShape::SetClippingRect}\label{wxdrawnshapesetclippingrect}
582
583 \func{void}{SetClippingRect}{\param{const wxRect\&}{ rect}}
584
585 Sets the clipping rectangle. See also \helpref{wxDrawnShape::DestroyClippingRect}{wxdrawnshapedestroyclippingrect}.
586
587 \membersection{wxDrawnShape::SetDrawnBackgroundColour}\label{wxdrawnshapesetdrawnbackgroundcolour}
588
589 \func{void}{SetDrawnBackgroundColour}{\param{const wxColour\&}{ colour}}
590
591 Sets the current background colour for the current metafile.
592
593 \membersection{wxDrawnShape::SetDrawnBackgroundMode}\label{wxdrawnshapesetdrawnbackgroundmode}
594
595 \func{void}{SetDrawnBackgroundMode}{\param{int}{ mode}}
596
597 Sets the current background mode for the current metafile.
598
599 \membersection{wxDrawnShape::SetDrawnBrush}\label{wxdrawnshapesetdrawnbrush}
600
601 \func{void}{SetDrawnBrush}{\param{wxPen*}{ pen}, \param{bool}{ isOutline = FALSE}}
602
603 Sets the pen for this metafile. If {\it isOutline} is TRUE, this pen is taken to indicate the outline
604 (and if the outline pen is changed for the whole shape, the pen will be replaced with the outline pen).
605
606 \membersection{wxDrawnShape::SetDrawnFont}\label{wxdrawnshapesetdrawnfont}
607
608 \func{void}{SetDrawnFont}{\param{wxFont*}{ font}}
609
610 Sets the current font for the current metafile.
611
612 \membersection{wxDrawnShape::SetDrawnPen}\label{wxdrawnshapesetdrawnpen}
613
614 \func{void}{SetDrawnPen}{\param{wxPen*}{ pen}, \param{bool}{ isOutline = FALSE}}
615
616 Sets the pen for this metafile. If {\it isOutline} is TRUE, this pen is taken to indicate the outline
617 (and if the outline pen is changed for the whole shape, the pen will be replaced with the outline pen).
618
619 \membersection{wxDrawnShape::SetDrawnTextColour}\label{wxdrawnshapesetdrawntextcolour}
620
621 \func{void}{SetDrawnTextColour}{\param{const wxColour\&}{ colour}}
622
623 Sets the current text colour for the current metafile.
624
625 \membersection{wxDrawnShape::Scale}
626
627 \func{void}{Scale}{\param{double }{sx}, \param{double }{sy}}
628
629 Scales the shape by the given amount.
630
631 \membersection{wxDrawnShape::SetSaveToFile}
632
633 \func{void}{SetSaveToFile}{\param{bool }{save}}
634
635 If {\it save} is TRUE, the image will be saved along with the shape's other attributes. The reason
636 why this might not be desirable is that if there are many shapes with the same image, it would be
637 more efficient for the application to save one copy, and not duplicate the information for every
638 shape. The default is TRUE.
639
640 \membersection{wxDrawnShape::Translate}
641
642 \func{void}{Translate}{\param{double }{x}, \param{double }{y}}
643
644 Translates the shape by the given amount.
645
646 \section{\class{wxCircleShape}}\label{wxcircleshape}
647
648 An wxEllipseShape whose width and height are the same.
649
650 \wxheading{Derived from}
651
652 \helpref{wxEllipseShape}{wxellipseshape}.
653
654 \latexignore{\rtfignore{\wxheading{Members}}}
655
656 \membersection{wxCircleShape::wxCircleShape}
657
658 \func{}{wxCircleShape}{\param{double}{ width = 0.0}}
659
660 Constructor.
661
662 \membersection{wxCircleShape::\destruct{wxCircleShape}}
663
664 \func{}{\destruct{wxCircleShape}}{\void}
665
666 Destructor.
667
668 \section{\class{wxCompositeShape}}\label{wxcompositeshape}
669
670 This is an object with a list of child objects, and a list of size
671 and positioning constraints between the children.
672
673 \wxheading{Derived from}
674
675 \helpref{wxRectangleShape}{wxrectangleshape}
676
677 \wxheading{See also}
678
679 \helpref{wxCompositeShape overview}{compositeshapeoverview}
680
681 \latexignore{\rtfignore{\wxheading{Members}}}
682
683 \membersection{wxCompositeShape::wxCompositeShape}
684
685 \func{}{wxCompositeShape}{\void}
686
687 Constructor.
688
689 \membersection{wxCompositeShape::\destruct{wxCompositeShape}}
690
691 \func{}{\destruct{wxCompositeShape}}{\void}
692
693 Destructor.
694
695 \membersection{wxCompositeShape::AddChild}\label{wxcompositeshapeaddchild}
696
697 \func{void}{AddChild}{\param{wxShape *}{child}, \param{wxShape *}{addAfter = NULL}}
698
699 Adds a child shape to the composite. If {\it addAfter} is non-NULL, the shape will be added
700 after this shape.
701
702 \membersection{wxCompositeShape::AddConstraint}\label{wxcompositeshapeaddconstraint}
703
704 \func{wxOGLConstraint *}{AddConstraint}{\param{wxOGLConstraint *}{constraint}}
705
706 \func{wxOGLConstraint *}{AddConstraint}{\param{int}{ type}, \param{wxShape *}{constraining}, \param{wxList\&}{constrained}}
707
708 \func{wxOGLConstraint *}{AddConstraint}{\param{int}{ type}, \param{wxShape *}{constraining}, \param{wxShape *}{constrained}}
709
710 Adds a constraint to the composite.
711
712 \membersection{wxCompositeShape::CalculateSize}
713
714 \func{void}{CalculateSize}{\void}
715
716 Calculates the size and position of the composite based on child sizes and positions.
717
718 \membersection{wxCompositeShape::ContainsDivision}
719
720 \func{bool}{FindContainerImage}{\param{wxDivisionShape *}{division}}
721
722 Returns TRUE if {\it division} is a descendant of this container.
723
724 \membersection{wxCompositeShape::DeleteConstraint}
725
726 \func{void}{DeleteConstraint}{\param{wxOGLConstraint *}{constraint}}
727
728 Deletes constraint from composite.
729
730 \membersection{wxCompositeShape::DeleteConstraintsInvolvingChild}
731
732 \func{void}{DeleteConstraintsInvolvingChild}{\param{wxShape *}{child}}
733
734 This function deletes constraints which mention the given child. Used when
735 deleting a child from the composite.
736
737 \membersection{wxCompositeShape::FindConstraint}
738
739 \func{wxOGLConstraint *}{FindConstraint}{\param{long}{ id}, \param{wxCompositeShape **}{actualComposite}}
740
741 Finds the constraint with the given id, also returning the actual composite the constraint was in,
742 in case that composite was a descendant of this composite.
743
744 \membersection{wxCompositeShape::FindContainerImage}
745
746 \func{wxShape *}{FindContainerImage}{\void}
747
748 Finds the image used to visualize a container. This is any child
749 of the composite that is not in the divisions list.
750
751 \membersection{wxCompositeShape::GetConstraints}
752
753 \constfunc{wxList\&}{GetConstraints}{\void}
754
755 Returns a reference to the list of constraints.
756
757 \membersection{wxCompositeShape::GetDivisions}
758
759 \constfunc{wxList\&}{GetDivisions}{\void}
760
761 Returns a reference to the list of divisions.
762
763 \membersection{wxCompositeShape::MakeContainer}\label{wxcompositeshapemakecontainer}
764
765 \func{void}{MakeContainer}{\void}
766
767 Makes this composite into a container by creating one child wxDivisionShape.
768
769 \membersection{wxCompositeShape::OnCreateDivision}
770
771 \func{wxDivisionShape *}{OnCreateDivision}{\void}
772
773 Called when a new division shape is required. Can be overriden to allow an application
774 to use a different class of division.
775
776 \membersection{wxCompositeShape::Recompute}\label{wxcompositeshaperecompute}
777
778 \func{bool}{Recompute}{\void}
779
780 Recomputes any constraints associated with the object. If FALSE is returned,
781 the constraints could not be satisfied (there was an inconsistency).
782
783 \membersection{wxCompositeShape::RemoveChild}
784
785 \func{void}{RemoveChild}{\param{wxShape *}{child}}
786
787 Removes the child from the composite and any constraint relationships, but does not
788 delete the child.
789
790 \section{\class{wxDividedShape}}\label{wxdividedshape}
791
792 A wxDividedShape is a rectangle with a number of vertical divisions. Each
793 division may have its text formatted with independent characteristics, and
794 the size of each division relative to the whole image may be specified.
795
796 \wxheading{Derived from}
797
798 \helpref{wxRectangleShape}{wxrectangleshape}
799
800 \wxheading{See also}
801
802 \helpref{wxDividedShape overview}{dividedshapeoverview}
803
804 \latexignore{\rtfignore{\wxheading{Members}}}
805
806 \membersection{wxDividedShape::wxDividedShape}
807
808 \func{}{wxDividedShape}{\param{double}{ width = 0.0}, \param{double}{ height = 0.0}}
809
810 Constructor.
811
812 \membersection{wxDividedShape::\destruct{wxDividedShape}}
813
814 \func{}{\destruct{wxDividedShape}}{\void}
815
816 Destructor.
817
818 \membersection{wxDividedShape::EditRegions}
819
820 \func{void}{EditRegions}{\void}
821
822 Edit the region colours and styles.
823
824 \membersection{wxDividedShape::SetRegionSizes}
825
826 \func{void}{SetRegionSizes}{\void}
827
828 Set all region sizes according to proportions and
829 this object total size.
830
831 \section{\class{wxDivisionShape}}\label{wxdivisionshape}
832
833 A division shape is like a composite in that it can contain further objects, but is used exclusively to
834 divide another shape into regions, or divisions. A wxDivisionShape is never free-standing.
835
836 \wxheading{Derived from}
837
838 \helpref{wxCompositeShape}{wxcompositeshape}
839
840 \wxheading{See also}
841
842 \helpref{wxCompositeShape overview}{compositeshapeoverview}
843
844 \latexignore{\rtfignore{\wxheading{Members}}}
845
846 \membersection{wxDivisionShape::wxDivisionShape}
847
848 \func{}{wxDivisionShape}{\void}
849
850 Constructor.
851
852 \membersection{wxDivisionShape::\destruct{wxDivisionShape}}
853
854 \func{}{\destruct{wxDivisionShape}}{\void}
855
856 Destructor.
857
858 \membersection{wxDivisionShape::AdjustBottom}
859
860 \func{void}{AdjustBottom}{\param{double}{ bottom}, \param{bool}{ test}}
861
862 Adjust a side, returning FALSE if it's not physically possible to adjust it to this point.
863
864 \membersection{wxDivisionShape::AdjustLeft}
865
866 \func{void}{AdjustLeft}{\param{double}{ left}, \param{bool}{ test}}
867
868 Adjust a side, returning FALSE if it's not physically possible to adjust it to this point.
869
870 \membersection{wxDivisionShape::AdjustRight}
871
872 \func{void}{AdjustRight}{\param{double}{ right}, \param{bool}{ test}}
873
874 Adjust a side, returning FALSE if it's not physically possible to adjust it to this point.
875
876 \membersection{wxDivisionShape::AdjustTop}
877
878 \func{void}{AdjustTop}{\param{double}{ top}, \param{bool}{ test}}
879
880 Adjust a side, returning FALSE if it's not physically possible to adjust it to this point.
881
882 \membersection{wxDivisionShape::Divide}\label{wxdivisionshapedivide}
883
884 \func{void}{Divide}{\param{int}{ direction}}
885
886 Divide this division into two further divisions, horizontally ({\it direction} is wxHORIZONTAL) or
887 vertically ({\it direction} is wxVERTICAL).
888
889 \membersection{wxDivisionShape::EditEdge}
890
891 \func{void}{EditEdge}{\param{int}{ side}}
892
893 Interactively edit style of left or top side.
894
895 \membersection{wxDivisionShape::GetBottomSide}
896
897 \func{wxDivisionShape *}{GetBottomSide}{\void}
898
899 Returns a pointer to the division on the bottom side of this division.
900
901 \membersection{wxDivisionShape::GetHandleSide}
902
903 \func{int}{GetHandleSide}{\void}
904
905 Returns the side which the handle appears on (DIVISION\_SIDE\_LEFT or DIVISION\_SIDE\_TOP).
906
907 \membersection{wxDivisionShape::GetLeftSide}
908
909 \func{wxDivisionShape *}{GetLeftSide}{\void}
910
911 Returns a pointer to the division on the left side of this division.
912
913 \membersection{wxDivisionShape::GetLeftSideColour}
914
915 \func{wxString}{GetLeftSideColour}{\void}
916
917 Returns a pointer to the colour used for drawing the left side of the division.
918
919 \membersection{wxDivisionShape::GetLeftSidePen}
920
921 \func{wxPen *}{GetLeftSidePen}{\void}
922
923 Returns a pointer to the pen used for drawing the left side of the division.
924
925 \membersection{wxDivisionShape::GetRightSide}
926
927 \func{wxDivisionShape *}{GetRightSide}{\void}
928
929 Returns a pointer to the division on the right side of this division.
930
931 \membersection{wxDivisionShape::GetTopSide}
932
933 \func{wxDivisionShape *}{GetTopSide}{\void}
934
935 Returns a pointer to the division on the top side of this division.
936
937 \membersection{wxDivisionShape::GetTopSideColour}
938
939 \func{wxString}{GetTopSideColour}{\void}
940
941 Returns a pointer to the colour used for drawing the top side of the division.
942
943 \membersection{wxDivisionShape::GetTopSidePen}
944
945 \func{wxPen *}{GetTopSidePen}{\void}
946
947 Returns a pointer to the pen used for drawing the left side of the division.
948
949 \membersection{wxDivisionShape::ResizeAdjoining}
950
951 \func{void}{ResizeAdjoining}{\param{int}{ side}, \param{double}{ newPos}, \param{bool}{ test}}
952
953 Resize adjoining divisions at the given side. If {\it test} is TRUE,
954 just see whether it's possible for each adjoining region,
955 returning FALSE if it's not.
956
957 {\it side} can be one of:
958
959 \begin{itemize}\itemsep=0pt
960 \item DIVISION\_SIDE\_NONE
961 \item DIVISION\_SIDE\_LEFT
962 \item DIVISION\_SIDE\_TOP
963 \item DIVISION\_SIDE\_RIGHT
964 \item DIVISION\_SIDE\_BOTTOM
965 \end{itemize}
966
967 \membersection{wxDivisionShape::PopupMenu}
968
969 \func{void}{PopupMenu}{\param{double}{ x}, \param{double}{ y}}
970
971 Popup the division menu.
972
973 \membersection{wxDivisionShape::SetBottomSide}
974
975 \func{void}{SetBottomSide}{\param{wxDivisionShape *}{shape}}
976
977 Set the pointer to the division on the bottom side of this division.
978
979 \membersection{wxDivisionShape::SetHandleSide}
980
981 \func{int}{SetHandleSide}{\void}
982
983 Sets the side which the handle appears on (DIVISION\_SIDE\_LEFT or DIVISION\_SIDE\_TOP).
984
985 \membersection{wxDivisionShape::SetLeftSide}
986
987 \func{void}{SetLeftSide}{\param{wxDivisionShape *}{shape}}
988
989 Set the pointer to the division on the left side of this division.
990
991 \membersection{wxDivisionShape::SetLeftSideColour}
992
993 \func{void}{SetLeftSideColour}{\param{const wxString\& }{colour}}
994
995 Sets the colour for drawing the left side of the division.
996
997 \membersection{wxDivisionShape::SetLeftSidePen}
998
999 \func{void}{SetLeftSidePen}{\param{wxPen *}{pen}}
1000
1001 Sets the pen for drawing the left side of the division.
1002
1003 \membersection{wxDivisionShape::SetRightSide}
1004
1005 \func{void}{SetRightSide}{\param{wxDivisionShape *}{shape}}
1006
1007 Set the pointer to the division on the right side of this division.
1008
1009 \membersection{wxDivisionShape::SetTopSide}
1010
1011 \func{void}{SetTopSide}{\param{wxDivisionShape *}{shape}}
1012
1013 Set the pointer to the division on the top side of this division.
1014
1015 \membersection{wxDivisionShape::SetTopSideColour}
1016
1017 \func{void}{SetTopSideColour}{\param{const wxString\& }{colour}}
1018
1019 Sets the colour for drawing the top side of the division.
1020
1021 \membersection{wxDivisionShape::SetTopSidePen}
1022
1023 \func{void}{SetTopSidePen}{\param{wxPen *}{pen}}
1024
1025 Sets the pen for drawing the top side of the division.
1026
1027 \section{\class{wxEllipseShape}}\label{wxellipseshape}
1028
1029 The wxEllipseShape behaves similarly to the wxRectangleShape but is
1030 elliptical.
1031
1032 \wxheading{Derived from}
1033
1034 \helpref{wxShape}{wxshape}
1035
1036 \latexignore{\rtfignore{\wxheading{Members}}}
1037
1038 \membersection{wxEllipseShape::wxEllipseShape}
1039
1040 \func{}{wxEllipseShape}{\param{double}{ width = 0.0}, \param{double}{ height = 0.0}}
1041
1042 Constructor.
1043
1044 \membersection{wxEllipseShape::\destruct{wxEllipseShape}}
1045
1046 \func{}{\destruct{wxEllipseShape}}{\void}
1047
1048 Destructor.
1049
1050 \section{\class{wxLineShape}}\label{wxlineshape}
1051
1052 A wxLineShape may be attached to two nodes; it may be segmented, in which
1053 case a control point is drawn for each joint.
1054
1055 A wxLineShape may have arrows at the beginning, end and centre.
1056
1057 \wxheading{Derived from}
1058
1059 \helpref{wxShape}{wxshape}
1060
1061 \latexignore{\rtfignore{\wxheading{Members}}}
1062
1063 \membersection{wxLineShape::wxLineShape}
1064
1065 \func{}{wxLineShape}{\void}
1066
1067 Constructor.
1068
1069 Usually you will call \helpref{wxLineShape::MakeLineControlPoints}{wxlineshapemakelinecontrolpoints} to
1070 specify the number of segments in the line.
1071
1072 \membersection{wxLineShape::\destruct{wxLineShape}}
1073
1074 \func{}{\destruct{wxLineShape}}{\void}
1075
1076 Destructor.
1077
1078 \membersection{wxLineShape::AddArrow}\label{wxlineshapeaddarrow}
1079
1080 \func{void}{AddArrow}{\param{WXTYPE}{ type}, \param{bool}{ end = ARROW\_POSITION\_END}, \param{double}{ arrowSize = 10.0},
1081 \param{double}{ xOffset = 0.0}, \param{const wxString\& }{name = ""}, \param{wxPseudoMetaFile *}{mf = NULL}, \param{long}{ arrowId = -1}}
1082
1083 Adds an arrow (or annotation) to the line.
1084
1085 {\it type} may currently be one of:
1086
1087 \begin{description}\itemsep=0pt
1088 \item[ARROW\_HOLLOW\_CIRCLE] Hollow circle.
1089 \item[ARROW\_FILLED\_CIRCLE] Filled circle.
1090 \item[ARROW\_ARROW] Conventional arrowhead.
1091 \item[ARROW\_SINGLE\_OBLIQUE] Single oblique stroke.
1092 \item[ARROW\_DOUBLE\_OBLIQUE] Double oblique stroke.
1093 \item[ARROW\_DOUBLE\_METAFILE] Custom arrowhead.
1094 \end{description}
1095
1096 {\it end} may currently be one of:
1097
1098 \begin{description}\itemsep=0pt
1099 \item[ARROW\_POSITION\_END] Arrow appears at the end.
1100 \item[ARROW\_POSITION\_START] Arrow appears at the start.
1101 \end{description}
1102
1103 {\it arrowSize} specifies the length of the arrow.
1104
1105 {\it xOffset} specifies the offset from the end of the line.
1106
1107 {\it name} specifies a name for the arrow.
1108
1109 {\it mf} can be a wxPseduoMetaFile, perhaps loaded from a simple Windows metafile.
1110
1111 {\it arrowId} is the id for the arrow.
1112
1113 \membersection{wxLineShape::AddArrowOrdered}
1114
1115 \func{void}{AddArrowOrdered}{\param{wxArrowHead *}{arrow}, \param{wxList\&}{ referenceList}, \param{int}{ end}}
1116
1117 Add an arrowhead in the position indicated by the reference
1118 list of arrowheads, which contains all legal arrowheads for this
1119 line, in the correct order.
1120 E.g.
1121
1122 \begin{verbatim}
1123 Reference list: a b c d e
1124 Current line list: a d
1125 \end{verbatim}
1126
1127 Add c, then line list is: a c d.
1128
1129 If no legal arrowhead position, return FALSE. Assume reference list is
1130 for one end only, since it potentially defines the ordering for any one
1131 of the 3 positions. So we don't check the reference list for arrowhead
1132 position.
1133
1134 \membersection{wxLineShape::ClearArrow}
1135
1136 \func{bool}{ClearArrow}{\param{const wxString\& }{name}}
1137
1138 Delete the arrow with the given name.
1139
1140 \membersection{wxLineShape::ClearArrowsAtPosition}
1141
1142 \func{void}{ClearArrowsAtPosition}{\param{int}{ position = -1}}
1143
1144 Delete the arrows at the specified position, or at any position if {\it position} is -1.
1145
1146 \membersection{wxLineShape::DrawArrow}
1147
1148 \func{void}{DrawArrow}{\param{ArrowHead *}{arrow}, \param{double}{ xOffset}, \param{bool}{ proportionalOffset}}
1149
1150 Draws the given arrowhead (or annotation).
1151
1152 \membersection{wxLineShape::DeleteArrowHead}
1153
1154 \func{bool}{DeleteArrowHead}{\param{long}{ arrowId}}
1155
1156 \func{bool}{DeleteArrowHead}{\param{int}{ position}, \param{const wxString\& }{name}}
1157
1158 Delete arrowhead by id or position and name.
1159
1160 \membersection{wxLineShape::DeleteLineControlPoint}
1161
1162 \func{bool}{DeleteLineControlPoint}{\void}
1163
1164 Deletes an arbitary point on the line.
1165
1166 \membersection{wxLineShape::DrawArrows}
1167
1168 \func{void}{DrawArrows}{\param{wxDC\&}{ dc}}
1169
1170 Draws all arrows.
1171
1172 \membersection{wxLineShape::DrawRegion}
1173
1174 \func{void}{DrawRegion}{\param{wxDC\&}{ dc}, \param{wxShapeRegion *}{region}, \param{double}{ x}, \param{double}{ y}}
1175
1176 Format one region at this position.
1177
1178 \membersection{wxLineShape::EraseRegion}
1179
1180 \func{void}{EraseRegion}{\param{wxDC\&}{ dc}, \param{wxShapeRegion *}{region}, \param{double}{ x}, \param{double}{ y}}
1181
1182 Format one region at this position.
1183
1184 \membersection{wxLineShape::FindArrowHead}
1185
1186 \func{wxArrowHead *}{FindArrowHead}{\param{long}{ arrowId}}
1187
1188 \func{wxArrowHead *}{FindArrowHead}{\param{int}{ position}, \param{const wxString\& }{name}}
1189
1190 Find arrowhead by id or position and name.
1191
1192 \membersection{wxLineShape::FindLineEndPoints}
1193
1194 \func{void}{FindLineEndPoints}{\param{double *}{fromX}, \param{double *}{fromY}, \param{double *}{toX}, \param{double *}{toY}}
1195
1196 Finds the x, y points at the two ends of the line. This function can be
1197 used by e.g. line-routing routines to get the actual points on the two
1198 node images where the lines will be drawn to/from.
1199
1200 \membersection{wxLineShape::FindLinePosition}
1201
1202 \func{int}{FindLinePosition}{\param{double }{x}, \param{double }{y}}
1203
1204 Find which position we're talking about at this x, y.
1205 Returns ARROW\_POSITION\_START, ARROW\_POSITION\_MIDDLE, ARROW\_POSITION\_END.
1206
1207 \membersection{wxLineShape::FindMinimumWidth}
1208
1209 \func{double}{FindMinimumWidth}{\void}
1210
1211 Finds the horizontal width for drawing a line with arrows in minimum
1212 space. Assume arrows at end only.
1213
1214 \membersection{wxLineShape::FindNth}
1215
1216 \func{void}{FindNth}{\param{wxShape *}{image}, \param{int *}{nth}, \param{int *}{noArcs}, \param{bool}{ incoming}}
1217
1218 Finds the position of the line on the given object. Specify whether incoming or outgoing lines are
1219 being considered with {\it incoming}.
1220
1221 \membersection{wxLineShape::GetAttachmentFrom}
1222
1223 \constfunc{int}{GetAttachmentFrom}{\void}
1224
1225 Returns the attachment point on the `from' node.
1226
1227 \membersection{wxLineShape::GetAttachmentTo}
1228
1229 \constfunc{int}{GetAttachmentTo}{\void}
1230
1231 Returns the attachment point on the `to' node.
1232
1233 \membersection{wxLineShape::GetEnds}
1234
1235 \func{void}{GetEnds}{\param{double *}{x1}, \param{double *}{y1}, \param{double *}{x2}, \param{double *}{y2}}
1236
1237 Gets the visible endpoints of the lines for drawing between two objects.
1238
1239 \membersection{wxLineShape::GetFrom}
1240
1241 \constfunc{wxShape *}{GetFrom}{\void}
1242
1243 Gets the `from' object.
1244
1245 \membersection{wxLineShape::GetLabelPosition}
1246
1247 \func{void}{GetLabelPosition}{\param{int}{ position}, \param{double *}{x}, \param{double *}{y}}
1248
1249 Get the reference point for a label. Region x and y are offsets from this.
1250 position is 0 (middle), 1 (start), 2 (end).
1251
1252 \membersection{wxLineShape::GetNextControlPoint}
1253
1254 \func{wxPoint *}{GetNextControlPoint}{\param{wxShape *}{shape}}
1255
1256 Find the next control point in the line after the start/end point,
1257 depending on whether the shape is at the start or end.
1258
1259 \membersection{wxLineShape::GetTo}
1260
1261 \func{wxShape *}{GetTo}{\void}
1262
1263 Gets the `to' object.
1264
1265 \membersection{wxLineShape::Initialise}
1266
1267 \func{void}{Initialise}{\void}
1268
1269 Initialises the line object.
1270
1271 \membersection{wxLineShape::InsertLineControlPoint}
1272
1273 \func{void}{InsertLineControlPoint}{\void}
1274
1275 Inserts a control point at an arbitrary position.
1276
1277 \membersection{wxLineShape::IsEnd}
1278
1279 \func{bool}{IsEnd}{\param{wxShape *}{shape}}
1280
1281 Returns TRUE if {\it shape} is at the end of the line.
1282
1283 \membersection{wxLineShape::IsSpline}
1284
1285 \func{bool}{IsSpline}{\void}
1286
1287 Returns TRUE if a spline is drawn through the control points, and FALSE otherwise.
1288
1289 \membersection{wxLineShape::MakeLineControlPoints}\label{wxlineshapemakelinecontrolpoints}
1290
1291 \func{void}{MakeLineControlPoints}{\param{int}{ n}}
1292
1293 Make a given number of control points (minimum of two).
1294
1295 \membersection{wxLineShape::OnMoveLink}
1296
1297 \func{void}{OnMoveLink}{\param{wxDC\&}{ dc}, \param{bool}{ moveControlPoints = TRUE}}
1298
1299 Called when a connected object has moved, to move the link to
1300 correct position.
1301
1302 \membersection{wxLineShape::SetAttachmentFrom}
1303
1304 \func{void}{SetAttachmentTo}{\param{int}{ fromAttach}}
1305
1306 Sets the `from' shape attachment.
1307
1308 \membersection{wxLineShape::SetAttachments}
1309
1310 \func{void}{SetAttachments}{\param{int}{ fromAttach}, \param{int}{ toAttach}}
1311
1312 Specifies which object attachment points should be used at each end of the line.
1313
1314 \membersection{wxLineShape::SetAttachmentTo}
1315
1316 \func{void}{SetAttachmentTo}{\param{int}{ toAttach}}
1317
1318 Sets the `to' shape attachment.
1319
1320 \membersection{wxLineShape::SetEnds}
1321
1322 \func{void}{SetEnds}{\param{double}{ x1}, \param{double}{ y1}, \param{double}{ x2}, \param{double}{ y2}}
1323
1324 Sets the end positions of the line.
1325
1326 \membersection{wxLineShape::SetFrom}
1327
1328 \func{void}{SetFrom}{\param{wxShape *}{object}}
1329
1330 Sets the `from' object for the line.
1331
1332 \membersection{wxLineShape::SetIgnoreOffsets}
1333
1334 \func{void}{SetIgnoreOffsets}{\param{bool}{ ignore}}
1335
1336 Tells the shape whether to ignore offsets from the end of the line when drawing.
1337
1338 \membersection{wxLineShape::SetSpline}
1339
1340 \func{void}{SetSpline}{\param{bool}{ spline}}
1341
1342 Specifies whether a spline is to be drawn through the control points (TRUE), or a line (FALSE).
1343
1344 \membersection{wxLineShape::SetTo}
1345
1346 \func{void}{SetTo}{\param{wxShape *}{object}}
1347
1348 Sets the `to' object for the line.
1349
1350 \membersection{wxLineShape::Straighten}
1351
1352 \func{void}{Straighten}{\param{wxDC*}{ dc = NULL}}
1353
1354 Straighten verticals and horizontals. {\it dc} is optional.
1355
1356 \membersection{wxLineShape::Unlink}
1357
1358 \func{void}{Unlink}{\void}
1359
1360 Unlinks the line from the nodes at either end.
1361
1362 \section{\class{wxPolygonShape}}\label{wxpolygonshape}
1363
1364 A wxPolygonShape's shape is defined by a number of points passed to the object's
1365 constructor. It can be used to create new shapes such as diamonds and triangles.
1366
1367 \wxheading{Derived from}
1368
1369 \helpref{wxShape}{wxshape}
1370
1371 \latexignore{\rtfignore{\wxheading{Members}}}
1372
1373 \membersection{wxPolygonShape::wxPolygonShape}
1374
1375 \func{}{wxPolygonShape}{void}
1376
1377 Constructor. Call \helpref{wxPolygonShape::Create}{wxpolygonshapecreate} to specify the polygon's vertices.
1378
1379 \membersection{wxPolygonShape::\destruct{wxPolygonShape}}
1380
1381 \func{}{\destruct{wxPolygonShape}}{\void}
1382
1383 Destructor.
1384
1385 \membersection{wxPolygonShape::Create}\label{wxpolygonshapecreate}
1386
1387 \func{void}{Create}{\param{wxList*}{ points}}
1388
1389 Takes a list of wxRealPoints; each point is an {\it offset} from the centre.
1390 The polygon's destructor will delete these points, so do not delete them yourself.
1391
1392 \membersection{wxPolygonShape::AddPolygonPoint}
1393
1394 \func{void}{AddPolygonPoint}{\param{int}{ pos = 0}}
1395
1396 Add a control point after the given point.
1397
1398 \membersection{wxPolygonShape::CalculatePolygonCentre}
1399
1400 \func{void}{CalculatePolygonCentre}{\void}
1401
1402 Recalculates the centre of the polygon.
1403
1404 \membersection{wxPolygonShape::DeletePolygonPoint}
1405
1406 \func{void}{DeletePolygonPoint}{\param{int}{ pos = 0}}
1407
1408 Deletes a control point.
1409
1410 \membersection{wxPolygonShape::GetPoints}
1411
1412 \func{wxList *}{GetPoints}{\void}
1413
1414 Returns a pointer to the internal list of polygon vertices (wxRealPoints).
1415
1416 \membersection{wxPolygonShape::UpdateOriginalPoints}
1417
1418 \func{void}{UpdateOriginalPoints}{\void}
1419
1420 If we've changed the shape, must make the original
1421 points match the working points with this function.
1422
1423 \section{\class{wxRectangleShape}}\label{wxrectangleshape}
1424
1425 The wxRectangleShape has rounded or square corners.
1426
1427 \wxheading{Derived from}
1428
1429 \helpref{wxShape}{wxshape}
1430
1431 \latexignore{\rtfignore{\wxheading{Members}}}
1432
1433 \membersection{wxRectangleShape::wxRectangleShape}
1434
1435 \func{}{wxRectangleShape}{\param{double}{ width = 0.0}, \param{double}{ height = 0.0}}
1436
1437 Constructor.
1438
1439 \membersection{wxRectangleShape::\destruct{wxRectangleShape}}
1440
1441 \func{}{\destruct{wxRectangleShape}}{\void}
1442
1443 Destructor.
1444
1445 \membersection{wxRectangleShape::SetCornerRadius}
1446
1447 \func{void}{SetCornerRadius}{\param{double}{ radius}}
1448
1449 Sets the radius of the rectangle's rounded corners. If the radius is zero, a non-rounded
1450 rectangle will be drawn. If the radius is negative, the value is the proportion of the
1451 smaller dimension of the rectangle.
1452
1453 \section{\class{wxPseudoMetaFile}}\label{wxpseudometafile}
1454
1455 A simple metafile-like class which can load data from a Windows metafile on all platforms.
1456
1457 \wxheading{Derived from}
1458
1459 wxObject
1460
1461 \section{\class{wxShape}}\label{wxshape}
1462
1463 The wxShape is the top-level, abstract object that all other
1464 objects are derived from. All common functionality is represented by
1465 wxShape's members, and overriden members that appear in derived
1466 classes and have behaviour as documented for wxShape, are not
1467 documented separately.
1468
1469 \wxheading{Derived from}
1470
1471 \helpref{wxShapeEvtHandler}{wxshapeevthandler}
1472
1473 \latexignore{\rtfignore{\wxheading{Members}}}
1474
1475 \membersection{wxShape::wxShape}
1476
1477 \func{}{wxShape}{\param{wxShapeCanvas*}{ canvas = NULL}}
1478
1479 Constructs a new wxShape.
1480
1481 \membersection{wxShape::\destruct{wxShape}}
1482
1483 \func{}{\destruct{wxShape}}{\void}
1484
1485 Destructor.
1486
1487 \membersection{wxShape::AddLine}
1488
1489 \func{void}{AddLine}{\param{wxLineShape*}{ line}, \param{wxShape*}{ other}, \param{int}{ attachFrom = 0}, \param{int}{ attachTo = 0},
1490 \param{int}{ positionFrom = -1}, \param{int}{ positionTo = -1}}
1491
1492 Adds a line between the specified canvas shapes, at the specified attachment points.
1493
1494 The position in the list of lines at each end can also be specified, so that the line will be drawn
1495 at a particular point on its attachment point.
1496
1497 \membersection{wxShape::AddRegion}
1498
1499 \func{void}{AddRegion}{\param{wxShapeRegion*}{ region}}
1500
1501 Adds a region to the shape.
1502
1503 \membersection{wxShape::AddText}
1504
1505 \func{void}{AddText}{\param{const wxString\& }{string}}
1506
1507 Adds a line of text to the shape's default text region.
1508
1509 \membersection{wxShape::AddToCanvas}
1510
1511 \func{void}{AddToCanvas}{\param{wxShapeCanvas*}{ theCanvas}, \param{wxShape*}{ addAfter=NULL}}
1512
1513 Adds the shape to the canvas's shape list. If {\it addAfter} is
1514 non-NULL, will add the shape after this one.
1515
1516 \membersection{wxShape::AncestorSelected}
1517
1518 \constfunc{bool}{AncestorSelected}{\void}
1519
1520 TRUE if the shape's ancestor is currently selected.
1521
1522 \membersection{wxShape::ApplyAttachmentOrdering}\label{wxshapeapplyattachmentordering}
1523
1524 \func{void}{ApplyAttachmentOrdering}{\param{wxList\&}{ linesToSort}}
1525
1526 Applies the line ordering in {\it linesToSort} to the shape, to reorder the way lines are attached.
1527
1528 \membersection{wxShape::AssignNewIds}
1529
1530 \func{void}{AssignNewIds}{\void}
1531
1532 Assigns new ids to this image and its children.
1533
1534 \membersection{wxShape::Attach}\label{wxshapeattach}
1535
1536 \func{void}{Attach}{\param{wxShapeCanvas*}{ can}}
1537
1538 Sets the shape's internal canvas pointer to point to the given canvas.
1539
1540 \membersection{wxShape::AttachmentIsValid}\label{wxshapeattachmentisvalid}
1541
1542 \constfunc{bool}{AttachmentIsValid}{\param{int}{ attachment}}
1543
1544 Returns TRUE if {\it attachment} is a valid attachment point.
1545
1546 \membersection{wxShape::AttachmentSortTest}\label{wxshapeattachmentsorttest}
1547
1548 \constfunc{bool}{AttachmentSortTest}{\param{int}{ attachment}, \param{const wxRealPoint\&}{ pt1},
1549 \param{const wxRealPoint\&}{ pt2}}
1550
1551 Returns TRUE if {\it pt1} is less than or equal to {\it pt2}, in the sense
1552 that one point comes before another on an edge of the shape. {\it attachment} is
1553 the attachment point (side) in question.
1554
1555 This function is used in \helpref{wxShape::MoveLineToNewAttachment}{wxshapemovelinetonewattachment} to
1556 determine the new line ordering.
1557
1558 \membersection{wxShape::CalcSimpleAttachment}\label{wxshapecalcsimpleattachment}
1559
1560 \func{wxRealPoint}{CalcSimpleAttachment}{\param{const wxRealPoint\&}{ pt1},
1561 \param{const wxRealPoint\&}{ pt2}, \param{int}{ nth}, \param{int}{ noArcs}, \param{wxLineShape*}{ line}}
1562
1563 Assuming the attachment lies along a vertical or horizontal line,
1564 calculates the position on that point.
1565
1566 \wxheading{Parameters}
1567
1568 \docparam{pt1}{The first point of the line repesenting the edge of the shape.}
1569
1570 \docparam{pt2}{The second point of the line representing the edge of the shape.}
1571
1572 \docparam{nth}{The position on the edge (for example there may be 6 lines at this attachment point,
1573 and this may be the 2nd line.}
1574
1575 \docparam{noArcs}{The number of lines at this edge.}
1576
1577 \docparam{line}{The line shape.}
1578
1579 \wxheading{Remarks}
1580
1581 This function expects the line to be either vertical or horizontal, and determines which.
1582
1583 \membersection{wxShape::CalculateSize}
1584
1585 \func{void}{CalculateSize}{\void}
1586
1587 Called to calculate the shape's size if dependent on children sizes.
1588
1589 \membersection{wxShape::ClearAttachments}
1590
1591 \func{void}{ClearAttachments}{\void}
1592
1593 Clears internal custom attachment point shapes (of class wxAttachmentPoint).
1594
1595 \membersection{wxShape::ClearRegions}
1596
1597 \func{void}{ClearRegions}{\void}
1598
1599 Clears the wxShapeRegions from the shape.
1600
1601 \membersection{wxShape::ClearText}
1602
1603 \func{void}{ClearText}{\param{int}{ regionId = 0}}
1604
1605 Clears the text from the specified text region.
1606
1607 \membersection{wxShape::Constrain}
1608
1609 \func{bool}{Constrain}{\void}
1610
1611 Calculates the shape's constraints (if any). Applicable
1612 only to wxCompositeShape, does nothing if the shape is of
1613 a different class.
1614
1615 \membersection{wxShape::Copy}\label{wxshapecopy}
1616
1617 \func{void}{Copy}{\param{wxShape\&}{ copy}}
1618
1619 Copy this shape into {\it copy}. Every derived class must have one of these, and each Copy implementation
1620 must call the derived class's implementation to ensure everything is copied. See also \helpref{wxShape::CreateNewCopy}{wxshapecreatenewcopy}.
1621
1622 \membersection{wxShape::CreateNewCopy}\label{wxshapecreatenewcopy}
1623
1624 \func{wxShape* }{CreateNewCopy}{\param{bool}{ resetMapping = TRUE}, \param{bool}{ recompute = TRUE}}
1625
1626 Creates and returns a new copy of this shape (calling \helpref{wxShape::Copy}{wxshapecopy}). Do not override this function.
1627
1628 This function should always be used to create a new copy, since it must do special processing
1629 for copying constraints associated with constraints.
1630
1631 If {\it resetMapping} is TRUE, a mapping table used for complex shapes is reset; this may not be desirable
1632 if the shape being copied is a child of a composite (and so the mapping table is in use).
1633
1634 If {\it recompute} is TRUE, \helpref{wxShape::Recompute}{wxshaperecompute} is called for the new shape.
1635
1636 \wxheading{Remarks}
1637
1638 This function uses the wxWindows dynamic object creation system to create a new shape of the same
1639 type as `this', before calling Copy.
1640
1641 If the event handler for this shape is not the same as the shape itself, the event handler is also copied
1642 using \helpref{wxShapeEvtHandler::CreateNewCopy}{wxshapeevthandlercreatenewcopy}.
1643
1644 \membersection{wxShape::DeleteControlPoints}
1645
1646 \func{void}{DeleteControlPoints}{\void}
1647
1648 Deletes the control points (or handles) for the shape. Does not redraw
1649 the shape.
1650
1651 \membersection{wxShape::Detach}
1652
1653 \func{void}{Detach}{\void}
1654
1655 Disassociates the shape from its canvas by setting the internal shape
1656 canvas pointer to NULL.
1657
1658 \membersection{wxShape::Draggable}
1659
1660 \func{bool}{Draggable}{\void}
1661
1662 TRUE if the shape may be dragged by the user.
1663
1664 \membersection{wxShape::Draw}
1665
1666 \func{void}{Draw}{\param{wxDC\&}{ dc}}
1667
1668 Draws the whole shape and any lines attached to it.
1669
1670 Do not override this function: override OnDraw, which is called
1671 by this function.
1672
1673 \membersection{wxShape::DrawContents}
1674
1675 \func{void}{DrawContents}{\param{wxDC\&}{ dc}}
1676
1677 Draws the internal graphic of the shape (such as
1678 text).
1679
1680 Do not override this function: override OnDrawContents, which is called
1681 by this function.
1682
1683 \membersection{wxShape::DrawLinks}
1684
1685 \func{void}{DrawLinks}{\param{wxDC\&}{ dc}, \param{int}{ attachment = -1}}
1686
1687 Draws any lines linked to this shape.
1688
1689 \membersection{wxShape::Erase}
1690
1691 \func{void}{Erase}{\param{wxDC\&}{ dc}}
1692
1693 Erases the shape, but does not repair damage caused to other
1694 shapes.
1695
1696 \membersection{wxShape::EraseContents}
1697
1698 \func{void}{EraseContents}{\param{wxDC\&}{ dc}}
1699
1700 Erases the shape contents, that is, the area within the shape's
1701 minimum bounding box.
1702
1703 \membersection{wxShape::EraseLinks}
1704
1705 \func{void}{EraseLinks}{\param{wxDC\&}{ dc}, \param{int}{ attachment = -1}}
1706
1707 Erases links attached to this shape, but does not repair
1708 damage caused to other shapes.
1709
1710 \membersection{wxShape::FindRegion}
1711
1712 \func{wxShape *}{FindRegion}{\param{const wxString\& }{regionName}, \param{int *}{regionId}}
1713
1714 Finds the actual image (`this' if non-composite) and region id for the given
1715 region name.
1716
1717 \membersection{wxShape::FindRegionNames}
1718
1719 \func{void}{FindRegionNames}{\param{wxStringList\&}{ list}}
1720
1721 Finds all region names for this image (composite or simple).
1722 Supply an empty string list.
1723
1724 \membersection{wxShape::Flash}
1725
1726 \func{void}{Flash}{\void}
1727
1728 Flashes the shape.
1729
1730 \membersection{wxShape::FormatText}
1731
1732 \func{void}{FormatText}{\param{const wxString\& }{s}, \param{int}{ i = 0}}
1733
1734 Reformats the given text region; defaults to formatting the default region.
1735
1736 \membersection{wxShape::GetAttachmentMode}
1737
1738 \constfunc{bool}{GetAttachmentMode}{\void}
1739
1740 Returns the attachment mode, which is TRUE if attachments are used, FALSE otherwise (in which case
1741 lines will be drawn as if to the centre of the shape). See \helpref{wxShape::SetAttachmentMode}{wxshapesetattachmentmode}.
1742
1743 \membersection{wxShape::GetAttachmentPosition}\label{wxshapegetattachmentposition}
1744
1745 \func{bool}{GetAttachmentPosition}{\param{int}{ attachment}, \param{double*}{ x}, \param{double*}{ y},
1746 \param{int}{ nth = 0}, \param{int}{ noArcs = 1}, \param{wxLineShape*}{ line = NULL}}
1747
1748 Gets the position at which the given attachment point should be drawn.
1749
1750 If {\it attachment} isn't found among the attachment points of the shape, returns FALSE.
1751
1752 \membersection{wxShape::GetBoundingBoxMax}
1753
1754 \func{void}{GetBoundingBoxMax}{\param{double *}{width}, \param{double *}{height}}
1755
1756 Gets the maximum bounding box for the shape, taking into
1757 account external features such as shadows.
1758
1759 \membersection{wxShape::GetBoundingBoxMin}
1760
1761 \func{void}{GetBoundingBoxMin}{\param{double *}{width}, \param{double *}{height}}
1762
1763 Gets the minimum bounding box for the shape, that defines
1764 the area available for drawing the contents (such as text).
1765
1766 \membersection{wxShape::GetBrush}
1767
1768 \constfunc{wxBrush*}{GetBrush}{\void}
1769
1770 Returns the brush used for filling the shape.
1771
1772 \membersection{wxShape::GetCanvas}
1773
1774 \constfunc{wxShapeCanvas*}{GetCanvas}{\void}
1775
1776 Gets the internal canvas pointer.
1777
1778 \membersection{wxShape::GetCentreResize}
1779
1780 \constfunc{bool}{GetCentreResize}{\void}
1781
1782 Returns TRUE if the shape is to be resized from the centre (the centre
1783 stands still), or FALSE if from the corner or side being dragged (the
1784 other corner or side stands still).
1785
1786 \membersection{wxShape::GetChildren}
1787
1788 \constfunc{wxList\&}{GetChildren}{\void}
1789
1790 Returns a reference to the list of children for this shape.
1791
1792 \membersection{wxShape::GetClientData}
1793
1794 \func{wxObject*}{GetClientData}{\void}
1795
1796 Gets the client data associated with the shape (NULL if there is
1797 none).
1798
1799 \membersection{wxShape::GetDisableLabel}
1800
1801 \constfunc{bool}{GetDisableLabel}{\void}
1802
1803 Returns TRUE if the default region will not be shown, FALSE otherwise.
1804
1805 \membersection{wxShape::GetEventHandler}
1806
1807 \constfunc{wxShapeEvtHandler*}{GetEventHandler}{\void}
1808
1809 Returns the event handler for this shape.
1810
1811 \membersection{wxShape::GetFixedHeight}
1812
1813 \constfunc{bool}{GetFixedHeight}{\void}
1814
1815 Returns TRUE if the shape cannot be resized in the vertical plane.
1816
1817 \membersection{wxShape::GetFixedSize}
1818
1819 \func{void}{GetFixedSize}{\param{bool *}{ x}, \param{bool *}{ y}}
1820
1821 Returns flags indicating whether the shape is of fixed size in either direction.
1822
1823 \membersection{wxShape::GetFixedWidth}
1824
1825 \constfunc{bool}{GetFixedWidth}{\void}
1826
1827 Returns TRUE if the shape cannot be resized in the horizontal plane.
1828
1829 \membersection{wxShape::GetFont}
1830
1831 \constfunc{wxFont*}{GetFont}{\param{int}{ regionId = 0}}
1832
1833 Gets the font for the specified text region.
1834
1835 \membersection{wxShape::GetFunctor}
1836
1837 \constfunc{wxString}{GetFunctor}{\void}
1838
1839 Gets a string representing the type of the shape, to be used when
1840 writing out shape descriptions to a file. This is overridden by
1841 each derived shape class to provide an appropriate type string. By default,
1842 "node\_image" is used for non-line shapes, and "arc\_image" for lines.
1843
1844 \membersection{wxShape::GetId}
1845
1846 \constfunc{long}{GetId}{\void}
1847
1848 Returns the integer identifier for this shape.
1849
1850 \membersection{wxShape::GetLinePosition}\label{wxshapegetlineposition}
1851
1852 \func{int}{GetLinePosition}{\param{wxLineShape*}{ line}}
1853
1854 Gets the zero-based position of {\it line} in the list of lines for this shape.
1855
1856 \membersection{wxShape::GetLines}
1857
1858 \constfunc{wxList\&}{GetLines}{\void}
1859
1860 Returns a reference to the list of lines connected to this shape.
1861
1862 \membersection{wxShape::GetMaintainAspectRatio}\label{wxshapegetmaintainaspectratio}
1863
1864 \constfunc{bool}{GetMaintainAspectRatio}{\void}
1865
1866 If returns TRUE, resizing the shape will not change the aspect ratio
1867 (width and height will be in the original proportion).
1868
1869 \membersection{wxShape::GetNumberOfAttachments}\label{wxshapegetnumberofattachments}
1870
1871 \constfunc{int}{GetNumberOfAttachments}{\void}
1872
1873 Gets the number of attachment points for this shape.
1874
1875 \membersection{wxShape::GetNumberOfTextRegions}
1876
1877 \constfunc{int}{GetNumberOfTextRegions}{\void}
1878
1879 Gets the number of text regions for this shape.
1880
1881 \membersection{wxShape::GetParent}
1882
1883 \constfunc{wxShape *}{GetParent}{\void}
1884
1885 Returns the parent of this shape, if it is part of a composite.
1886
1887 \membersection{wxShape::GetPen}
1888
1889 \constfunc{wxPen*}{GetPen}{\void}
1890
1891 Returns the pen used for drawing the shape's outline.
1892
1893 \membersection{wxShape::GetPerimeterPoint}
1894
1895 \func{bool}{GetPerimeterPoint}{\param{double}{ x1}, \param{double}{ y1}, \param{double}{ x2}, \param{double}{ y2}, \param{double *}{x3}, \param{double *}{y3}}
1896
1897 Gets the point at which the line from (x1, y1) to (x2, y2) hits the shape. Returns TRUE if the
1898 line hits the perimeter.
1899
1900 \membersection{wxShape::GetRegionId}\label{getregionid}
1901
1902 \func{int}{GetRegionId}{\param{const wxString\& }{name}}
1903
1904 Gets the region's identifier by name. This is {\it not} unique for within an entire composite, but
1905 is unique for the image.
1906
1907 \membersection{wxShape::GetRegionName}\label{getregionname}
1908
1909 \func{wxString}{GetRegionName}{\param{int}{ regionId = 0}}
1910
1911 Gets the region's name. A region's name can be used to uniquely determine a region within
1912 an entire composite image hierarchy. See also \helpref{wxShape::SetRegionName}{wxshapesetregionname}.
1913
1914 \membersection{wxShape::GetRegions}\label{getregions}
1915
1916 \func{wxList\&}{GetRegions}{\void}
1917
1918 Returns the list of wxShapeRegions.
1919
1920 \membersection{wxShape::GetRotation}
1921
1922 \constfunc{double}{GetRotatation}{\void}
1923
1924 Returns the angle of rotation in radians.
1925
1926 \membersection{wxShape::GetSensitivityFilter}
1927
1928 \constfunc{void}{GetSensitivityFilter}{\void}
1929
1930 Returns the sensitivity filter, a bitlist of values. See \helpref{wxShape::SetSensitivityFilter}{wxshapesetsensitivityfilter}.
1931
1932 \membersection{wxShape::GetShadowMode}
1933
1934 \constfunc{int}{SetShadowMode}{\void}
1935
1936 Returns the shadow mode. See \helpref{wxShape::SetShadowMode}{wxshapesetshadowmode}.
1937
1938 \membersection{wxShape::GetSpaceAttachments}
1939
1940 \constfunc{bool}{GetSpaceAttachments}{\void}
1941
1942 Indicates whether lines should be spaced out evenly at the point they touch the node (TRUE), or whether they
1943 should join at a single point (FALSE).
1944
1945 \membersection{wxShape::GetTextColour}
1946
1947 \constfunc{wxString}{GetTextColour}{\param{int}{ regionId = 0}}
1948
1949 Gets the colour for the specified text region.
1950
1951 \membersection{wxShape::GetTopAncestor}
1952
1953 \constfunc{wxShape *}{GetTopAncestor}{\void}
1954
1955 Returns the top-most ancestor of this shape (the root of the composite).
1956
1957 \membersection{wxShape::GetX}
1958
1959 \constfunc{double}{GetX}{\void}
1960
1961 Gets the x position of the centre of the shape.
1962
1963 \membersection{wxShape::GetY}
1964
1965 \constfunc{double}{GetY}{\void}
1966
1967 Gets the y position of the centre of the shape.
1968
1969 \membersection{wxShape::HitTest}
1970
1971 \func{bool}{HitTest}{\param{double}{ x}, \param{double}{ y}, \param{int*}{ attachment}, \param{double*}{ distance}}
1972
1973 Given a point on a canvas, returns TRUE if the point was on the shape, and returns
1974 the nearest attachment point and distance from the given point and target.
1975
1976 \membersection{wxShape::Insert}
1977
1978 \func{void}{InsertInCanvas}{\param{wxShapeCanvas*}{ canvas}}
1979
1980 Inserts the shape at the front of the shape list of {\it canvas}.
1981
1982 \membersection{wxShape::IsHighlighted}
1983
1984 \constfunc{bool}{IsHighlighted}{\void}
1985
1986 Returns TRUE if the shape is highlighted. Shape highlighting is unimplemented.
1987
1988 \membersection{wxShape::IsShown}
1989
1990 \constfunc{bool}{IsShown}{\void}
1991
1992 Returns TRUE if the shape is in a visible state, FALSE otherwise. Note
1993 that this has nothing to do with whether the window is hidden or the
1994 shape has scrolled off the canvas; it refers to the internal
1995 visibility flag.
1996
1997 \membersection{wxShape::MakeControlPoints}
1998
1999 \func{void}{MakeControlPoints}{\void}
2000
2001 Make a list of control points (draggable handles) appropriate to the shape.
2002
2003 \membersection{wxShape::MakeMandatoryControlPoints}
2004
2005 \func{void}{MakeMandatoryControlPoints}{\void}
2006
2007 Make the mandatory control points. For example, the control point on a dividing line should
2008 appear even if the divided rectangle shape's handles should not appear (because it is the child of
2009 a composite, and children are not resizable).
2010
2011 \membersection{wxShape::Move}\label{wxshapemove}
2012
2013 \func{void}{Move}{\param{wxDC\&}{ dc}, \param{double}{ x1}, \param{double}{ y1}, \param{bool}{ display = TRUE}}
2014
2015 Move the shape to the given position, redrawing if {\it display} is TRUE.
2016
2017 \membersection{wxShape::MoveLineToNewAttachment}\label{wxshapemovelinetonewattachment}
2018
2019 \func{void}{MoveLineToNewAttachment}{\param{wxDC\&}{ dc}, \param{wxLineShape*}{ toMove}, \param{double}{ x}, \param{double}{ y}}
2020
2021 Move the given line (which must already be attached to the shape) to
2022 a different attachment point on the shape, or a different order on the same attachment.
2023
2024 Cals \helpref{wxShape::AttachmentSortTest}{wxshapeattachmentsorttest} and then \helpref{wxShapeEvtHandler::OnChangeAttachment}{wxshapeevthandleronchangeattachment}.
2025
2026 \membersection{wxShape::MoveLinks}
2027
2028 \func{void}{MoveLinks}{\param{wxDC\&}{ dc}}
2029
2030 Redraw all the lines attached to the shape.
2031
2032 \membersection{wxShape::NameRegions}
2033
2034 \func{void}{NameRegions}{\param{const wxString\& }{parentName = ``"}}
2035
2036 Make unique names for all the regions in a shape or composite shape.
2037
2038 \membersection{wxShape::Rotate}
2039
2040 \func{void}{Rotate}{\param{double }{x}, \param{double }{y}, \param{double }{theta}}
2041
2042 Rotate about the given axis by the given amount in radians (does nothing
2043 for most shapes). But even non-rotating shapes should record their
2044 notional rotation in case it's important (e.g. in dog-leg code).
2045
2046 \membersection{wxShape::ReadConstraints}
2047
2048 \func{void}{ReadConstraints}{\param{wxExpr *}{clause}, \param{wxExprDatabase *}{database}}
2049
2050 If the shape is a composite, it may have constraints that need to be read in in a separate pass.
2051
2052 \membersection{wxShape::ReadAttributes}
2053
2054 \func{void}{ReadAttributes}{\param{wxExpr*}{ clause}}
2055
2056 Reads the attributes (data member values) from the given expression.
2057
2058 \membersection{wxShape::ReadRegions}
2059
2060 \func{void}{ReadRegions}{\param{wxExpr *}{clause}}
2061
2062 Reads in the regions.
2063
2064 \membersection{wxShape::Recentre}
2065
2066 \func{void}{Recentre}{\void}
2067
2068 Does recentring (or other formatting) for all the text regions for this shape.
2069
2070 \membersection{wxShape::RemoveFromCanvas}
2071
2072 \func{void}{RemoveFromCanvas}{\param{wxShapeCanvas*}{ canvas}}
2073
2074 Removes the shape from the canvas.
2075
2076 \membersection{wxShape::ResetControlPoints}
2077
2078 \func{void}{ResetControlPoints}{\void}
2079
2080 Resets the positions of the control points (for instance when the
2081 shape's shape has changed).
2082
2083 \membersection{wxShape::ResetMandatoryControlPoints}
2084
2085 \func{void}{ResetMandatoryControlPoints}{\void}
2086
2087 Reset the mandatory control points. For example, the control point on a dividing line should
2088 appear even if the divided rectangle shape's handles should not appear (because it is the child of
2089 a composite, and children are not resizable).
2090
2091 \membersection{wxShape::Recompute}\label{wxshaperecompute}
2092
2093 \func{bool}{Recompute}{\void}
2094
2095 Recomputes any constraints associated with the shape (normally
2096 applicable to wxCompositeShapes only, but harmless for other
2097 classes of shape).
2098
2099 \membersection{wxShape::RemoveLine}
2100
2101 \func{void}{RemoveLine}{\param{wxLineShape*}{ line}}
2102
2103 Removes the given line from the shape's list of attached lines.
2104
2105 \membersection{wxShape::Select}\label{wxshapeselect}
2106
2107 \func{void}{Select}{\param{bool}{ select = TRUE}}
2108
2109 Selects or deselects the given shape, drawing or erasing control points
2110 (handles) as necessary.
2111
2112 \membersection{wxShape::Selected}\label{wxshapeselected}
2113
2114 \constfunc{bool}{Selected}{\void}
2115
2116 TRUE if the shape is currently selected.
2117
2118 \membersection{wxShape::SetAttachmentMode}\label{wxshapesetattachmentmode}
2119
2120 \func{void}{SetAttachmentMode}{\param{bool}{ flag}}
2121
2122 Sets the attachment mode to TRUE or FALSE. If TRUE, attachment points
2123 will be significant when drawing lines to and from this shape.
2124 If FALSE, lines will be drawn as if to the centre of the shape.
2125
2126 \membersection{wxShape::SetBrush}
2127
2128 \func{void}{SetBrush}{\param{wxBrush *}{brush}}
2129
2130 Sets the brush for filling the shape's shape.
2131
2132 \membersection{wxShape::SetCanvas}\label{wxshapesetcanvas}
2133
2134 \func{void}{SetCanvas}{\param{wxShapeCanvas*}{ theCanvas}}
2135
2136 Identical to \helpref{wxShape::Attach}{wxshapesetcanvas}.
2137
2138 \membersection{wxShape::SetCentreResize}
2139
2140 \func{void}{SetCentreResize}{\param{bool}{ cr}}
2141
2142 Specify whether the shape is to be resized from the centre (the centre stands still) or from the corner or side
2143 being dragged (the other corner or side stands still).
2144
2145 \membersection{wxShape::SetClientData}
2146
2147 \func{void}{SetClientData}{\param{wxObject *}{clientData}}
2148
2149 Sets the client data.
2150
2151 \membersection{wxShape::SetDefaultRegionSize}\label{setdefaultregionsize}
2152
2153 \func{void}{SetDefaultRegionSize}{\void}
2154
2155 Set the default region to be consistent with the shape size.
2156
2157 \membersection{wxShape::SetDisableLabel}
2158
2159 \func{void}{SetDisableLabel}{\param{bool}{ flag}}
2160
2161 Set {\it flag} to TRUE to stop the default region being shown, FALSE otherwise.
2162
2163 \membersection{wxShape::SetDraggable}
2164
2165 \func{void}{SetDraggable}{\param{bool}{ drag}, \param{bool}{ recursive = FALSE}}
2166
2167 Sets the shape to be draggable or not draggable.
2168
2169 \membersection{wxShape::SetDrawHandles}
2170
2171 \func{void}{SetDrawHandles}{\param{bool}{ drawH}}
2172
2173 Sets the {\it drawHandles} flag for this shape and all descendants. If {\it drawH} is TRUE (the default),
2174 any handles (control points) will be drawn. Otherwise, the handles will not be drawn.
2175
2176 \membersection{wxShape::SetEventHandler}
2177
2178 \func{void}{GetEventHandler}{\param{wxShapeEvtHandler *}{handler}}
2179
2180 Sets the event handler for this shape.
2181
2182 \membersection{wxShape::SetFixedSize}
2183
2184 \func{void}{SetFixedSize}{\param{bool}{ x}, \param{bool}{ y}}
2185
2186 Sets the shape to be of the given, fixed size.
2187
2188 \membersection{wxShape::SetFont}
2189
2190 \func{void}{SetFont}{\param{wxFont *}{font}, \param{int}{ regionId = 0}}
2191
2192 Sets the font for the specified text region.
2193
2194 \membersection{wxShape::SetFormatMode}\label{setformatmode}
2195
2196 \func{void}{SetFormatMode}{\param{int}{ mode}, \param{int}{ regionId = 0}}
2197
2198 Sets the format mode of the default text region. The argument can be a bit list
2199 of the following:
2200
2201 \begin{description}\itemsep=0pt
2202 \item[FORMAT\_NONE] No formatting.
2203 \item[FORMAT\_CENTRE\_HORIZ] Horizontal centring.
2204 \item[FORMAT\_CENTRE\_VERT] Vertical centring.
2205 \end{description}
2206
2207 \membersection{wxShape::SetHighlight}
2208
2209 \func{void}{SetHighlight}{\param{bool}{ hi}, \param{bool}{ recurse = FALSE}}
2210
2211 Sets the highlight for a shape. Shape highlighting is unimplemented.
2212
2213 \membersection{wxShape::SetId}
2214
2215 \func{void}{SetId}{\param{long}{ id}}
2216
2217 Set the integer identifier for this shape.
2218
2219 \membersection{wxShape::SetMaintainAspectRatio}\label{wxshapesetmaintainaspectratio}
2220
2221 \func{void}{SetMaintainAspectRatio}{\param{bool}{ flag}}
2222
2223 If the argument is TRUE, tells the shape that resizes should not change the aspect ratio
2224 (width and height should be in the original proportion).
2225
2226 \membersection{wxShape::SetPen}
2227
2228 \func{void}{SetPen}{\param{wxPen *}{pen}}
2229
2230 Sets the pen for drawing the shape's outline.
2231
2232 \membersection{wxShape::SetRegionName}\label{wxshapesetregionname}
2233
2234 \func{void}{SetRegionName}{\param{const wxString\& }{name}, \param{int}{ regionId = 0}}
2235
2236 Sets the name for this region. The name for a region is unique within the scope of the whole
2237 composite, whereas a region id is unique only for a single image.
2238
2239 \membersection{wxShape::SetSensitivityFilter}\label{wxshapesetsensitivityfilter}
2240
2241 \func{void}{SetSensitivityFilter}{\param{int}{ sens=OP\_ALL}, \param{bool}{ recursive = FALSE}}
2242
2243 Sets the shape to be sensitive or insensitive to specific mouse operations.
2244
2245 {\it sens} is a bitlist of the following:
2246
2247 \begin{itemize}\itemsep=0pt
2248 \item OP\_CLICK\_LEFT
2249 \item OP\_CLICK\_RIGHT
2250 \item OP\_DRAG\_LEFT
2251 \item OP\_DRAG\_RIGHT
2252 \item OP\_ALL (equivalent to a combination of all the above).
2253 \end{itemize}
2254
2255 \membersection{wxShape::SetShadowMode}\label{wxshapesetshadowmode}
2256
2257 \func{void}{SetShadowMode}{\param{int}{ mode}, \param{bool}{ redraw = FALSE}}
2258
2259 Sets the shadow mode (whether a shadow is drawn or not). {\it mode} can be one of
2260 the following:
2261
2262 \begin{description}\itemsep=0pt
2263 \item[SHADOW\_NONE] No shadow (the default).
2264 \item[SHADOW\_LEFT] Shadow on the left side.
2265 \item[SHADOW\_RIGHT] Shadow on the right side.
2266 \end{description}
2267
2268 \membersection{wxShape::SetSize}
2269
2270 \func{void}{SetSize}{\param{double}{ x}, \param{double}{ y}, \param{bool}{ recursive = TRUE}}
2271
2272 Sets the shape's size.
2273
2274 \membersection{wxShape::SetSpaceAttachments}
2275
2276 \func{void}{SetSpaceAttachments}{\param{bool}{ sp}}
2277
2278 Indicate whether lines should be spaced out evenly at the point they touch the node (TRUE), or whether they
2279 should join at a single point (FALSE).
2280
2281 \membersection{wxShape::SetTextColour}
2282
2283 \func{void}{SetTextColour}{\param{const wxString\& }{colour}, \param{int}{ regionId = 0}}
2284
2285 Sets the colour for the specified text region.
2286
2287 \membersection{wxShape::SetX}
2288
2289 \func{void}{SetX}{\param{double}{ x}}
2290
2291 Sets the {\it x} position of the shape.
2292
2293 \membersection{wxShape::SetX}
2294
2295 \func{void}{SetY}{\param{double}{ y}}
2296
2297 Sets the {\it y} position of the shape.
2298
2299 \membersection{wxShape::SpaceAttachments}
2300
2301 \func{void}{SpaceAttachments}{\param{bool}{ sp}}
2302
2303 Sets the spacing mode: if TRUE, lines at the same attachment point will be
2304 spaced evenly across that side of the shape. If false, all lines at the
2305 same attachment point will emanate from the same point.
2306
2307 \membersection{wxShape::Show}
2308
2309 \func{void}{Show}{\param{bool}{ show}}
2310
2311 Sets a flag indicating whether the shape should be drawn.
2312
2313 \membersection{wxShape::Unlink}
2314
2315 \func{void}{Unlink}{\void}
2316
2317 If the shape is a line, unlinks the nodes attached to the shape, removing itself from the list of
2318 lines for each of the `to' and `from' nodes.
2319
2320 \membersection{wxShape::WriteAttributes}
2321
2322 \func{void}{WriteAttributes}{\param{wxExpr *}{clause}}
2323
2324 Writes the shape's attributes (data member values) into the given expression.
2325
2326 \membersection{wxShape::WriteRegions}
2327
2328 \func{void}{WriteRegions}{\param{wxExpr *}{clause}}
2329
2330 Writes the regions.
2331
2332 \section{\class{wxShapeCanvas}}\label{wxshapecanvas}
2333
2334 A canvas for drawing diagrams on.
2335
2336 \wxheading{Derived from}
2337
2338 wxScrolledWindow
2339
2340 \wxheading{See also}
2341
2342 \helpref{wxDiagram}{wxdiagram}
2343
2344 \latexignore{\rtfignore{\wxheading{Members}}}
2345
2346 \membersection{wxShapeCanvas::wxShapeCanvas}
2347
2348 \func{}{wxShapeCanvas}{\param{wxWindow*}{ parent = NULL}, \param{wxWindowID}{ id = -1},
2349 \param{const wxPoint\&}{ pos = wxDefaultPosition}, \param{const wxSize\&}{ size = wxDefaultSize},
2350 \param{long}{ style = wxBORDER}}
2351
2352 Constructor.
2353
2354 \membersection{wxShapeCanvas::\destruct{wxShapeCanvas}}
2355
2356 \func{}{\destruct{wxShapeCanvas}}{\void}
2357
2358 Destructor.
2359
2360 \membersection{wxShapeCanvas::AddShape}
2361
2362 \func{void}{AddShape}{\param{wxShape *}{shape}, \param{wxShape *}{addAfter = NULL}}
2363
2364 Adds a shape to the diagram. If {\it addAfter} is non-NULL, the shape will be added after this
2365 one.
2366
2367 \membersection{wxShapeCanvas::FindShape}
2368
2369 \func{wxShape *}{FindShape}{\param{double}{ x1}, \param{double}{ y}, \param{int *}{attachment}, \param{wxClassInfo *}{info = NULL},
2370 \param{wxShape *}{notImage = NULL}}
2371
2372 Find a shape under this mouse click. Returns the shape (or NULL), and the nearest attachment point.
2373
2374 If {\it info} is non-NULL, a shape whose class which is a descendant of the desired class is found.
2375
2376 If {\it notImage} is non-NULL, shapes which are descendants of {\it notImage} are ignored.
2377
2378 \membersection{wxShapeCanvas::FindFirstSensitiveShape}
2379
2380 \func{wxShape *}{FindFirstSensitiveShape}{\param{double}{ x1}, \param{double}{ y}, \param{int *}{attachment}, \param{int}{ op}}
2381
2382 Finds the first sensitive shape whose sensitivity filter matches {\it op}, working up the hierarchy of composites until
2383 one (or none) is found.
2384
2385 \membersection{wxShapeCanvas::GetDiagram}
2386
2387 \constfunc{wxDiagram*}{GetDiagram}{\void}
2388
2389 Returns the canvas associated with this diagram.
2390
2391 \membersection{wxShapeCanvas::GetGridSpacing}
2392
2393 \constfunc{double}{GetGridSpacing}{\void}
2394
2395 Returns the grid spacing.
2396
2397 \membersection{wxShapeCanvas::GetMouseTolerance}
2398
2399 \constfunc{int}{GetMouseTolerance}{\void}
2400
2401 Returns the tolerance within which a mouse move is ignored.
2402
2403 \membersection{wxShapeCanvas::GetShapeList}
2404
2405 \constfunc{wxList*}{GetShapeList}{\void}
2406
2407 Returns a pointer to the internal shape list.
2408
2409 \membersection{wxShapeCanvas::GetQuickEditMode}
2410
2411 \constfunc{bool}{GetQuickEditMode}{\void}
2412
2413 Returns quick edit mode for the associated diagram.
2414
2415 \membersection{wxShapeCanvas::InsertShape}
2416
2417 \func{void}{InsertShape}{\param{wxShape*}{ shape}}
2418
2419 Inserts a shape at the front of the shape list.
2420
2421 \membersection{wxShapeCanvas::OnBeginDragLeft}\label{wxshapecanvasonbegindragleft}
2422
2423 \func{void}{OnBeginDragLeft}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
2424
2425 Called when the start of a left-button drag event on the canvas background is detected by OnEvent. You may override this member;
2426 by default it does nothing.
2427
2428 {\it keys} is a bit list of the following:
2429
2430 \begin{itemize}\itemsep=0pt
2431 \item KEY\_SHIFT
2432 \item KEY\_CTRL
2433 \end{itemize}
2434
2435 See also \helpref{wxShapeCanvas::OnDragLeft}{wxshapecanvasondragleft}, \helpref{wxShapeCanvas::OnEndDragLeft}{wxshapecanvasonenddragleft}.
2436
2437 \membersection{wxShapeCanvas::OnBeginDragRight}\label{wxshapecanvasonbegindragright}
2438
2439 \func{void}{OnBeginDragRight}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
2440
2441 Called when the start of a right-button drag event on the canvas background is detected by OnEvent. You may override this member;
2442 by default it does nothing.
2443
2444 {\it keys} is a bit list of the following:
2445
2446 \begin{itemize}\itemsep=0pt
2447 \item KEY\_SHIFT
2448 \item KEY\_CTRL
2449 \end{itemize}
2450
2451 See also \helpref{wxShapeCanvas::OnDragRight}{wxshapecanvasondragright}, \helpref{wxShapeCanvas::OnEndDragRight}{wxshapecanvasonenddragright}.
2452
2453 \membersection{wxShapeCanvas::OnEndDragLeft}\label{wxshapecanvasonenddragleft}
2454
2455 \func{void}{OnEndDragLeft}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
2456
2457 Called when the end of a left-button drag event on the canvas background is detected by OnEvent. You may override this member;
2458 by default it does nothing.
2459
2460 {\it keys} is a bit list of the following:
2461
2462 \begin{itemize}\itemsep=0pt
2463 \item KEY\_SHIFT
2464 \item KEY\_CTRL
2465 \end{itemize}
2466
2467 See also \helpref{wxShapeCanvas::OnDragLeft}{wxshapecanvasondragleft}, \helpref{wxShapeCanvas::OnBeginDragLeft}{wxshapecanvasonbegindragleft}.
2468
2469 \membersection{wxShapeCanvas::OnEndDragRight}\label{wxshapecanvasonenddragright}
2470
2471 \func{void}{OnEndDragRight}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
2472
2473 Called when the end of a right-button drag event on the canvas background is detected by OnEvent. You may override this member;
2474 by default it does nothing.
2475
2476 {\it keys} is a bit list of the following:
2477
2478 \begin{itemize}\itemsep=0pt
2479 \item KEY\_SHIFT
2480 \item KEY\_CTRL
2481 \end{itemize}
2482
2483 See also \helpref{wxShapeCanvas::OnDragRight}{wxshapecanvasondragright}, \helpref{wxShapeCanvas::OnBeginDragRight}{wxshapecanvasonbegindragright}.
2484
2485 \membersection{wxShapeCanvas::OnDragLeft}\label{wxshapecanvasondragleft}
2486
2487 \func{void}{OnDragLeft}{\param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
2488
2489 Called when a left-button drag event on the canvas background is detected by OnEvent. You may override this member;
2490 by default it does nothing.
2491
2492 {\it draw} is alternately TRUE and FALSE, to assist drawing and erasing.
2493
2494 {\it keys} is a bit list of the following:
2495
2496 \begin{itemize}\itemsep=0pt
2497 \item KEY\_SHIFT
2498 \item KEY\_CTRL
2499 \end{itemize}
2500
2501 See also \helpref{wxShapeCanvas::OnBeginDragLeft}{wxshapecanvasonbegindragleft}, \helpref{wxShapeCanvas::OnEndDragLeft}{wxshapecanvasonenddragleft}.
2502
2503 \membersection{wxShapeCanvas::OnDragRight}\label{wxshapecanvasondragright}
2504
2505 \func{void}{OnDragRight}{\param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
2506
2507 Called when a right-button drag event on the canvas background is detected by OnEvent. You may override this member;
2508 by default it does nothing.
2509
2510 {\it draw} is alternately TRUE and FALSE, to assist drawing and erasing.
2511
2512 {\it keys} is a bit list of the following:
2513
2514 \begin{itemize}\itemsep=0pt
2515 \item KEY\_SHIFT
2516 \item KEY\_CTRL
2517 \end{itemize}
2518
2519 See also \helpref{wxShapeCanvas::OnBeginDragRight}{wxshapecanvasonbegindragright}, \helpref{wxShapeCanvas::OnEndDragRight}{wxshapecanvasonenddragright}.
2520
2521 \membersection{wxShapeCanvas::OnLeftClick}\label{wxshapecanvasonleftclick}
2522
2523 \func{void}{OnLeftClick}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
2524
2525 Called when a left click event on the canvas background is detected by OnEvent. You may override this member;
2526 by default it does nothing.
2527
2528 {\it keys} is a bit list of the following:
2529
2530 \begin{itemize}\itemsep=0pt
2531 \item KEY\_SHIFT
2532 \item KEY\_CTRL
2533 \end{itemize}
2534
2535 \membersection{wxShapeCanvas::OnRightClick}\label{wxshapecanvasonrightclick}
2536
2537 \func{void}{OnRightClick}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}}
2538
2539 Called when a right click event on the canvas background is detected by OnEvent. You may override this member;
2540 by default it does nothing.
2541
2542 {\it keys} is a bit list of the following:
2543
2544 \begin{itemize}\itemsep=0pt
2545 \item KEY\_SHIFT
2546 \item KEY\_CTRL
2547 \end{itemize}
2548
2549 \membersection{wxShapeCanvas::Redraw}
2550
2551 \func{void}{Redraw}{\void}
2552
2553 Calls wxDiagram::Redraw.
2554
2555 \membersection{wxShapeCanvas::RemoveShape}
2556
2557 \func{void}{RemoveShape}{\param{wxShape *}{shape}}
2558
2559 Calls wxDiagram::RemoveShape.
2560
2561 \membersection{wxShapeCanvas::SetDiagram}
2562
2563 \func{void}{SetDiagram}{\param{wxDiagram *}{diagram}}
2564
2565 Sets the diagram associated with this diagram.
2566
2567 \membersection{wxShapeCanvas::Snap}
2568
2569 \func{void}{Snap}{\param{double *}{x}, \param{double *}{y}}
2570
2571 Calls wxDiagram::Snap.
2572
2573
2574
2575 \section{\class{wxShapeEvtHandler}}\label{wxshapeevthandler}
2576
2577 wxShapeEvtHandler is a class from which wxShape (and therefore all shape classes) are derived.
2578 A wxShape also contains a pointer to its current wxShapeEvtHandler. Event handlers
2579 can be swapped in and out, altering the behaviour of a shape. This allows, for example,
2580 a range of behaviours to be redefined in one class, rather than requiring
2581 each shape class to be subclassed.
2582
2583 \wxheading{Derived from}
2584
2585 wxObject
2586
2587 \latexignore{\rtfignore{\wxheading{Members}}}
2588
2589 \membersection{wxShapeEvtHandler::m\_handlerShape}
2590
2591 \member{wxShape*}{m\_handlerShape}
2592
2593 Pointer to the shape associated with this handler.
2594
2595 \membersection{wxShapeEvtHandler::m\_previousHandler}
2596
2597 \member{wxShapeEvtHandler*}{m\_previousHandler}
2598
2599 Pointer to the previous handler.
2600
2601 \membersection{wxShapeEvtHandler::wxShapeEvtHandler}
2602
2603 \func{void}{wxShapeEvtHandler}{\param{wxShapeEvtHandler *}{previous = NULL}, \param{wxShape *}{shape = NULL}}
2604
2605 Constructs a new event handler.
2606
2607 \membersection{wxShapeEvtHandler::\destruct{wxShapeEvtHandler}}
2608
2609 \func{void}{\destruct{wxShapeEvtHandler}}{\void}
2610
2611 Destructor.
2612
2613 \membersection{wxShapeEvtHandler::CopyData}\label{wxshapeevthandlercopydata}
2614
2615 \func{void}{CopyData}{\param{wxShapeEvtHandler\&}{ handler}}
2616
2617 A virtual function to copy the data from this object to {\it handler}. Override if you
2618 derive from wxShapeEvtHandler and have data to copy.
2619
2620 \membersection{wxShapeEvtHandler::CreateNewCopy}\label{wxshapeevthandlercreatenewcopy}
2621
2622 \func{wxShapeEvtHandler*}{CreateNewCopy}{\void}
2623
2624 Creates a new event handler object of the same class as this object, and then
2625 calls \helpref{wxShapeEvtHandler::CopyData}{wxshapeevthandlercopydata}.
2626
2627 \membersection{wxShapeEvtHandler::GetPreviousHandler}\label{wxshapeevthandlergetprevioushandler}
2628
2629 \constfunc{wxShapeEvtHandler*}{GetPreviousHandler}{\void}
2630
2631 Returns the previous handler.
2632
2633 \membersection{wxShapeEvtHandler::GetShape}\label{wxshapeevthandlergetshape}
2634
2635 \constfunc{wxShape*}{GetShape}{\void}
2636
2637 Returns the shape associated with this handler.
2638
2639 \membersection{wxShapeEvtHandler::OnBeginDragLeft}
2640
2641 \func{void}{OnBeginDragLeft}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
2642
2643 Called when the user is beginning to drag using the left mouse button.
2644
2645 \membersection{wxShapeEvtHandler::OnBeginDragRight}
2646
2647 \func{void}{OnBeginDragRight}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
2648
2649 Called when the user is beginning to drag using the right mouse button.
2650
2651 \membersection{wxShapeEvtHandler::OnBeginSize}
2652
2653 \func{void}{OnBeginSize}{\param{double}{ width}, \param{double}{ height}}
2654
2655 Called when a shape starts to be resized.
2656
2657 \membersection{wxShapeEvtHandler::OnChangeAttachment}\label{wxshapeevthandleronchangeattachment}
2658
2659 \func{void}{OnChangeAttachment}{\param{int}{ attachment}, \param{wxLineShape*}{ line}, \param{wxList\&}{ ordering}}
2660
2661 Override this to prevent or intercept line reordering. wxShape's implementation of this function
2662 calls \helpref{wxShape::ApplyAttachmentOrdering}{wxshapeapplyattachmentordering} to apply
2663 the new ordering.
2664
2665 \membersection{wxShapeEvtHandler::OnDragLeft}
2666
2667 \func{void}{OnDragLeft}{\param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
2668
2669 Called twice when the shape is being dragged, once to allow erasing the old
2670 image, and again to allow drawing at the new position.
2671
2672 \membersection{wxShapeEvtHandler::OnDragRight}
2673
2674 \func{void}{OnDragRight}{\param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
2675
2676 Called twice when the shape is being dragged, once to allow erasing the old
2677 image, and again to allow drawing at the new position.
2678
2679 \membersection{wxShapeEvtHandler::OnDraw}
2680
2681 \func{void}{OnDraw}{\param{wxDC\&}{ dc}}
2682
2683 Defined for each class to draw the main graphic, but
2684 not the contents.
2685
2686 \membersection{wxShapeEvtHandler::OnDrawContents}
2687
2688 \func{void}{OnDrawContents}{\param{wxDC\&}{ dc}}
2689
2690 Defined for each class to draw the contents of the
2691 shape, such as text.
2692
2693 \membersection{wxShapeEvtHandler::OnDrawControlPoints}
2694
2695 \func{void}{OnDrawControlPoints}{\param{wxDC\&}{ dc}}
2696
2697 Called when the shape's control points (handles) should
2698 be drawn.
2699
2700 \membersection{wxShapeEvtHandler::OnDrawOutline}
2701
2702 \func{void}{OnDrawOutline}{\param{wxDC\&}{ dc}}
2703
2704 Called when the outline of the shape should be drawn.
2705
2706 \membersection{wxShapeEvtHandler::OnEndDragLeft}
2707
2708 \func{void}{OnEndDragLeft}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
2709
2710 Called when the user is stopping dragging using the left mouse button.
2711
2712 \membersection{wxShapeEvtHandler::OnEndDragRight}
2713
2714 \func{void}{OnEndDragRight}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
2715
2716 Called when the user is stopping dragging using the right mouse button.
2717
2718 \membersection{wxShapeEvtHandler::OnEndSize}
2719
2720 \func{void}{OnEndSize}{\param{double}{ width}, \param{double}{ height}}
2721
2722 Called after a shape is resized.
2723
2724 \membersection{wxShapeEvtHandler::OnErase}
2725
2726 \func{void}{OnErase}{\param{wxDC\&}{ dc}}
2727
2728 Called when the whole shape should be erased.
2729
2730 \membersection{wxShapeEvtHandler::OnEraseContents}
2731
2732 \func{void}{OnEraseContents}{\param{wxDC\&}{ dc}}
2733
2734 Called when the contents should be erased.
2735
2736 \membersection{wxShapeEvtHandler::OnEraseControlPoints}
2737
2738 \func{void}{OnEraseControlPoints}{\param{wxDC\&}{ dc}}
2739
2740 Called when the shape's control points (handles) should
2741 be erased.
2742
2743 \membersection{wxShapeEvtHandler::OnHighlight}
2744
2745 \func{void}{OnHighlight}{\param{wxDC\&}{ dc}}
2746
2747 Called when the shape should be highlighted.
2748
2749 \membersection{wxShapeEvtHandler::OnLeftClick}
2750
2751 \func{void}{OnLeftClick}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys =0}, \param{int}{ attachment = 0}}
2752
2753 Called when the shape receives a left mouse click event.
2754
2755 \membersection{wxShapeEvtHandler::OnMoveLink}
2756
2757 \func{void}{OnMoveLink}{\param{wxDC\&}{ dc}, \param{bool}{ moveControlPoints=TRUE}}
2758
2759 Called when the line attached to an shape need to be repositioned,
2760 because the shape has moved.
2761
2762 \membersection{wxShapeEvtHandler::OnMoveLinks}
2763
2764 \func{void}{OnMoveLinks}{\param{wxDC\&}{ dc}}
2765
2766 Called when the lines attached to an shape need to be repositioned,
2767 because the shape has moved.
2768
2769 \membersection{wxShapeEvtHandler::OnMovePost}
2770
2771 \func{bool}{OnMovePost}{\param{wxDC\&}{ dc}, \param{double}{ x}, \param{double}{ y}, \param{double}{ oldX}, \param{double}{ oldY}, \param{bool}{ display = TRUE}}
2772
2773 Called just after the shape receives a move request.
2774
2775 \membersection{wxShapeEvtHandler::OnMovePre}
2776
2777 \func{bool}{OnMovePre}{\param{wxDC\&}{ dc}, \param{double}{ x}, \param{double}{ y}, \param{double}{ oldX}, \param{double}{ oldY}, \param{bool}{ display = TRUE}}
2778
2779 Called just before the shape receives a move request. Returning TRUE
2780 allows the move to be processed; returning FALSE vetoes the move.
2781
2782 \membersection{wxShapeEvtHandler::OnRightClick}
2783
2784 \func{void}{OnRightClick}{\param{double}{ x}, \param{double}{ y}, \param{int}{ keys = 0}, \param{int}{ attachment = 0}}
2785
2786 Called when the shape receives a mouse mouse click event.
2787
2788 \membersection{wxShapeEvtHandler::OnSize}
2789
2790 \func{void}{OnSize}{\param{double}{ x}, \param{double}{ y}}
2791
2792 Called when the shape receives a resize request.
2793
2794 \membersection{wxShapeEvtHandler::OnSizingBeginDragLeft}
2795
2796 \func{void}{OnSizingBeginDragLeft}{\param{wxControlPoint*}{ pt}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
2797
2798 Called when a sizing drag is beginning.
2799
2800 \membersection{wxShapeEvtHandler::OnSizingDragLeft}
2801
2802 \func{void}{OnSizingDragLeft}{\param{wxControlPoint*}{ pt}, \param{bool}{ draw}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
2803
2804 Called when a sizing drag is occurring.
2805
2806 \membersection{wxShapeEvtHandler::OnSizingEndDragLeft}
2807
2808 \func{void}{OnSizingEndDragLeft}{\param{wxControlPoint*}{ pt}, \param{double}{ x}, \param{double}{ y}, \param{int}{ keys=0}, \param{int}{ attachment = 0}}
2809
2810 Called when a sizing drag is ending.
2811
2812 \membersection{wxShapeEvtHandler::SetPreviousHandler}\label{wxshapeevthandlersetprevioushandler}
2813
2814 \func{void}{SetPreviousHandler}{\param{wxShapeEvtHandler*}{ handler}}
2815
2816 Sets the previous handler.
2817
2818 \membersection{wxShapeEvtHandler::SetShape}\label{wxshapeevthandlersetshape}
2819
2820 \func{void}{SetShape}{\param{wxShape*}{ shape}}
2821
2822 Sets the shape for this handler.
2823
2824 \section{\class{wxTextShape}}\label{wxtextshape}
2825
2826 As wxRectangleShape, but only the text is displayed.
2827
2828 \wxheading{Derived from}
2829
2830 \helpref{wxRectangleShape}{wxrectangleshape}
2831
2832 \latexignore{\rtfignore{\wxheading{Members}}}
2833
2834 \membersection{wxTextShape::wxTextShape}
2835
2836 \func{void}{wxTextShape}{\param{double}{ width = 0.0}, \param{double}{ height = 0.0}}
2837
2838 Constructor.
2839
2840 \membersection{wxTextShape::\destruct{wxTextShape}}
2841
2842 \func{void}{\destruct{wxTextShape}}{\void}
2843
2844 Destructor.
2845
2846 \section{Functions}\label{functions}
2847
2848 These are the OGL functions.
2849
2850 \membersection{::wxOGLInitialize}
2851
2852 \func{void}{wxOGLInitialize}{\void}
2853
2854 Initializes OGL.
2855
2856 \membersection{::wxOGLCleanUp}
2857
2858 \func{void}{wxOGLCleanUp}{\void}
2859
2860 Cleans up OGL.
2861