]>
Commit | Line | Data |
---|---|---|
7e664d85 RD |
1 | ///////////////////////////////////////////////////////////////////////////// |
2 | // Name: | |
3 | // Purpose: Wraper definitions for the wxPseudoDC Class | |
4 | // Author: Paul Lanier | |
5 | // Modified by: | |
6 | // Created: 05/25/06 | |
7 | // RCS-ID: $Id$ | |
8 | // Copyright: (c) wxWidgets team | |
9 | // Licence: wxWindows licence | |
10 | ///////////////////////////////////////////////////////////////////////////// | |
11 | ||
12 | ||
13 | %{ | |
14 | #include "wx/wxPython/pseudodc.h" | |
15 | %} | |
16 | ||
17 | %newgroup; | |
18 | ||
19 | DocStr(wxPseudoDC, | |
20 | "A PseudoDC is an object that can be used as if it were a `wx.DC`. All | |
21 | commands issued to the PseudoDC are stored in a list. You can then | |
22 | play these commands back to a real DC object using the DrawToDC | |
23 | method. Commands in the command list are indexed by ID. You can use | |
24 | this to clear the operations associated with a single ID and then | |
25 | re-draw the object associated with that ID.", ""); | |
26 | ||
27 | class wxPseudoDC : public wxObject | |
28 | { | |
29 | public: | |
30 | DocCtorStr( | |
31 | wxPseudoDC(), | |
32 | "Constructs a new Pseudo device context for recording dc operations",""); | |
33 | DocDeclStr( | |
34 | void , BeginDrawing(), | |
35 | "Allows for optimization of drawing code on platforms that need it. On | |
36 | other platforms this is just an empty function and is harmless. To | |
37 | take advantage of this postential optimization simply enclose each | |
38 | group of calls to the drawing primitives within calls to | |
39 | `BeginDrawing` and `EndDrawing`.", ""); | |
40 | ||
41 | DocDeclStr( | |
42 | void , EndDrawing(), | |
43 | "Ends the group of drawing primitives started with `BeginDrawing`, and | |
44 | invokes whatever optimization is available for this DC type on the | |
45 | current platform.", ""); | |
46 | DocCtorStr( | |
47 | ~wxPseudoDC(), | |
48 | "Frees memory used by the operation list of the pseudo dc",""); | |
49 | DocDeclStr( | |
50 | void, RemoveAll(), | |
51 | "Removes all objects and operations from the recorded list.", ""); | |
52 | DocDeclStr( | |
53 | int, GetLen(), | |
54 | "Returns the number of operations in the recorded list.", ""); | |
55 | DocDeclStr( | |
56 | void, SetId(int id), | |
57 | "Sets the id to be associated with subsequent operations.", ""); | |
58 | DocDeclStr( | |
59 | void, ClearId(int id), | |
60 | "Removes all operations associated with id so the object can be redrawn.", ""); | |
61 | DocDeclStr( | |
62 | void, RemoveId(int id), | |
63 | "Remove the object node (and all operations) associated with an id.", ""); | |
64 | DocDeclStr( | |
65 | void, TranslateId(int id, wxCoord dx, wxCoord dy), | |
66 | "Translate the operations of id by dx,dy.", ""); | |
67 | DocDeclStr( | |
68 | void, DrawIdToDC(int id, wxDC *dc), | |
69 | "Draw recorded operations of id to dc.", ""); | |
70 | DocDeclStr( | |
71 | void, SetIdBounds(int id, wxRect& rect), | |
72 | "Set the bounding rect of a given object. This will create | |
73 | an object node if one doesn't exist.", ""); | |
74 | %extend { | |
75 | DocStr( | |
76 | GetIdBounds, | |
77 | "Returns the bounding rectangle previouly set with SetIdBounds. If | |
78 | no bounds have been set, it returns wx.Rect(0,0,0,0).", ""); | |
79 | wxRect GetIdBounds(int id) { | |
80 | wxRect rect; | |
81 | self->GetIdBounds(id, rect); | |
82 | return rect; | |
83 | } | |
84 | } | |
85 | DocDeclStr( | |
86 | void, DrawToDCClipped(wxDC *dc, const wxRect& rect), | |
87 | "Draws the recorded operations to dc unless the operation is known to | |
88 | be outside rect.", ""); | |
89 | DocDeclStr( | |
90 | void, DrawToDCClippedRgn(wxDC *dc, const wxRegion& region), | |
91 | "Draws the recorded operations to dc unless the operation is known to | |
92 | be outside rect.", ""); | |
93 | DocDeclStr( | |
94 | void, DrawToDC(wxDC *dc), | |
95 | "Draws the recorded operations to dc.", ""); | |
96 | ||
97 | //------------------------------------------------------------------------- | |
98 | // Methods Mirrored from wxDC | |
99 | //------------------------------------------------------------------------- | |
100 | // | |
101 | // DocDeclStr( | |
102 | // void , SetFont(const wxFont& font), | |
103 | // "Sets the current font for the DC. It must be a valid font, in | |
104 | //particular you should not pass ``wx.NullFont`` to this method."," | |
105 | // | |
106 | //:see: `wx.Font`"); | |
107 | // | |
108 | // DocDeclStr( | |
109 | // void , SetPen(const wxPen& pen), | |
110 | // "Sets the current pen for the DC. | |
111 | // | |
112 | //If the argument is ``wx.NullPen``, the current pen is selected out of the | |
113 | //device context, and the original pen restored.", " | |
114 | // | |
115 | //:see: `wx.Pen`"); | |
116 | // | |
117 | // DocDeclStr( | |
118 | // void , SetBrush(const wxBrush& brush), | |
119 | // "Sets the current brush for the DC. | |
120 | // | |
121 | //If the argument is ``wx.NullBrush``, the current brush is selected out | |
122 | //of the device context, and the original brush restored, allowing the | |
123 | //current brush to be destroyed safely."," | |
124 | // | |
125 | //:see: `wx.Brush`"); | |
126 | // | |
127 | // DocDeclStr( | |
128 | // void , SetBackground(const wxBrush& brush), | |
129 | // "Sets the current background brush for the DC.", ""); | |
130 | // | |
131 | // DocDeclStr( | |
132 | // void , SetBackgroundMode(int mode), | |
133 | // "*mode* may be one of ``wx.SOLID`` and ``wx.TRANSPARENT``. This setting | |
134 | //determines whether text will be drawn with a background colour or | |
135 | //not.", ""); | |
136 | // | |
137 | // DocDeclStr( | |
138 | // void , SetTextForeground(const wxColour& colour), | |
139 | // "Sets the current text foreground colour for the DC.", ""); | |
140 | // | |
141 | // DocDeclStr( | |
142 | // void , SetTextBackground(const wxColour& colour), | |
143 | // "Sets the current text background colour for the DC.", ""); | |
144 | // DocDeclStr( | |
145 | // void , DrawLabel(const wxString& text, const wxRect& rect, | |
146 | // int alignment = wxALIGN_LEFT | wxALIGN_TOP, | |
147 | // int indexAccel = -1), | |
148 | // "Draw *text* within the specified rectangle, abiding by the alignment | |
149 | //flags. Will additionally emphasize the character at *indexAccel* if | |
150 | //it is not -1.", " | |
151 | // | |
152 | //:see: `DrawImageLabel`"); | |
153 | // DocStr( | |
154 | // DrawText, | |
155 | // "Draws a text string at the specified point, using the current text | |
156 | //font, and the current text foreground and background colours. | |
157 | // | |
158 | //The coordinates refer to the top-left corner of the rectangle bounding | |
159 | //the string. See `GetTextExtent` for how to get the dimensions of a | |
160 | //text string, which can be used to position the text more precisely. | |
161 | // | |
162 | //**NOTE**: under wxGTK the current logical function is used by this | |
163 | //function but it is ignored by wxMSW. Thus, you should avoid using | |
164 | //logical functions with this function in portable programs.", " | |
165 | // | |
166 | //:see: `DrawRotatedText`"); | |
167 | // void DrawText(const wxString& text, wxCoord x, wxCoord y); | |
168 | // DocStr( | |
169 | // DrawLine, | |
170 | // "Draws a line from the first point to the second. The current pen is | |
171 | //used for drawing the line. Note that the second point is *not* part of | |
172 | //the line and is not drawn by this function (this is consistent with | |
173 | //the behaviour of many other toolkits).", ""); | |
174 | // void DrawLine(wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2); | |
175 | // DocDeclStr( | |
176 | // void, DrawRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height), | |
177 | // "Draws a rectangle with the given top left corner, and with the given | |
178 | //size. The current pen is used for the outline and the current brush | |
179 | //for filling the shape.", ""); | |
180 | // DocDeclStr( | |
181 | // void , Clear(), | |
182 | // "Clears the device context using the current background brush.", ""); | |
183 | ||
184 | DocStr( | |
185 | FloodFill, | |
186 | "Flood fills the device context starting from the given point, using | |
187 | the current brush colour, and using a style: | |
188 | ||
189 | - **wxFLOOD_SURFACE**: the flooding occurs until a colour other than | |
190 | the given colour is encountered. | |
191 | ||
192 | - **wxFLOOD_BORDER**: the area to be flooded is bounded by the given | |
193 | colour. | |
194 | ||
195 | Returns False if the operation failed. | |
196 | ||
197 | Note: The present implementation for non-Windows platforms may fail to | |
198 | find colour borders if the pixels do not match the colour | |
199 | exactly. However the function will still return true.", ""); | |
200 | void FloodFill(wxCoord x, wxCoord y, const wxColour& col, int style = wxFLOOD_SURFACE); | |
201 | %Rename(FloodFillPoint, void, FloodFill(const wxPoint& pt, const wxColour& col, int style = wxFLOOD_SURFACE)); | |
202 | ||
203 | ||
204 | DocStr( | |
205 | DrawLine, | |
206 | "Draws a line from the first point to the second. The current pen is | |
207 | used for drawing the line. Note that the second point is *not* part of | |
208 | the line and is not drawn by this function (this is consistent with | |
209 | the behaviour of many other toolkits).", ""); | |
210 | void DrawLine(wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2); | |
211 | %Rename(DrawLinePoint, void, DrawLine(const wxPoint& pt1, const wxPoint& pt2)); | |
212 | ||
213 | ||
214 | DocStr( | |
215 | CrossHair, | |
216 | "Displays a cross hair using the current pen. This is a vertical and | |
217 | horizontal line the height and width of the window, centred on the | |
218 | given point.", ""); | |
219 | void CrossHair(wxCoord x, wxCoord y); | |
220 | %Rename(CrossHairPoint, void, CrossHair(const wxPoint& pt)); | |
221 | ||
222 | ||
223 | DocStr( | |
224 | DrawArc, | |
225 | "Draws an arc of a circle, centred on the *center* point (xc, yc), from | |
226 | the first point to the second. The current pen is used for the outline | |
227 | and the current brush for filling the shape. | |
228 | ||
229 | The arc is drawn in an anticlockwise direction from the start point to | |
230 | the end point.", ""); | |
231 | void DrawArc(wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2, wxCoord xc, wxCoord yc); | |
232 | %Rename(DrawArcPoint, void, DrawArc(const wxPoint& pt1, const wxPoint& pt2, const wxPoint& center)); | |
233 | ||
234 | ||
235 | DocStr( | |
236 | DrawCheckMark, | |
237 | "Draws a check mark inside the given rectangle.", ""); | |
238 | void DrawCheckMark(wxCoord x, wxCoord y, wxCoord width, wxCoord height); | |
239 | %Rename(DrawCheckMarkRect, void, DrawCheckMark(const wxRect& rect)); | |
240 | ||
241 | DocStr( | |
242 | DrawEllipticArc, | |
243 | "Draws an arc of an ellipse, with the given rectangle defining the | |
244 | bounds of the ellipse. The current pen is used for drawing the arc and | |
245 | the current brush is used for drawing the pie. | |
246 | ||
247 | The *start* and *end* parameters specify the start and end of the arc | |
248 | relative to the three-o'clock position from the center of the | |
249 | rectangle. Angles are specified in degrees (360 is a complete | |
250 | circle). Positive values mean counter-clockwise motion. If start is | |
251 | equal to end, a complete ellipse will be drawn.", ""); | |
252 | void DrawEllipticArc(wxCoord x, wxCoord y, wxCoord w, wxCoord h, double start, double end); | |
253 | %Rename(DrawEllipticArcPointSize, void, DrawEllipticArc(const wxPoint& pt, const wxSize& sz, double start, double end)); | |
254 | ||
255 | ||
256 | DocStr( | |
257 | DrawPoint, | |
258 | "Draws a point using the current pen.", ""); | |
259 | void DrawPoint(wxCoord x, wxCoord y); | |
260 | %Rename(DrawPointPoint, void, DrawPoint(const wxPoint& pt)); | |
261 | ||
262 | ||
263 | DocStr( | |
264 | DrawRectangle, | |
265 | "Draws a rectangle with the given top left corner, and with the given | |
266 | size. The current pen is used for the outline and the current brush | |
267 | for filling the shape.", ""); | |
268 | void DrawRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height); | |
269 | %Rename(DrawRectangleRect,void, DrawRectangle(const wxRect& rect)); | |
270 | %Rename(DrawRectanglePointSize, void, DrawRectangle(const wxPoint& pt, const wxSize& sz)); | |
271 | ||
272 | ||
273 | DocStr( | |
274 | DrawRoundedRectangle, | |
275 | "Draws a rectangle with the given top left corner, and with the given | |
276 | size. The corners are quarter-circles using the given radius. The | |
277 | current pen is used for the outline and the current brush for filling | |
278 | the shape. | |
279 | ||
280 | If radius is positive, the value is assumed to be the radius of the | |
281 | rounded corner. If radius is negative, the absolute value is assumed | |
282 | to be the proportion of the smallest dimension of the rectangle. This | |
283 | means that the corner can be a sensible size relative to the size of | |
284 | the rectangle, and also avoids the strange effects X produces when the | |
285 | corners are too big for the rectangle.", ""); | |
286 | void DrawRoundedRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height, double radius); | |
287 | %Rename(DrawRoundedRectangleRect, void, DrawRoundedRectangle(const wxRect& r, double radius)); | |
288 | %Rename(DrawRoundedRectanglePointSize, void, DrawRoundedRectangle(const wxPoint& pt, const wxSize& sz, double radius)); | |
289 | ||
290 | ||
291 | DocStr( | |
292 | DrawCircle, | |
293 | "Draws a circle with the given center point and radius. The current | |
294 | pen is used for the outline and the current brush for filling the | |
295 | shape.", " | |
296 | ||
297 | :see: `DrawEllipse`"); | |
298 | void DrawCircle(wxCoord x, wxCoord y, wxCoord radius); | |
299 | %Rename(DrawCirclePoint, void, DrawCircle(const wxPoint& pt, wxCoord radius)); | |
300 | ||
301 | ||
302 | DocStr( | |
303 | DrawEllipse, | |
304 | "Draws an ellipse contained in the specified rectangle. The current pen | |
305 | is used for the outline and the current brush for filling the shape.", " | |
306 | ||
307 | :see: `DrawCircle`"); | |
308 | void DrawEllipse(wxCoord x, wxCoord y, wxCoord width, wxCoord height); | |
309 | %Rename(DrawEllipseRect, void, DrawEllipse(const wxRect& rect)); | |
310 | %Rename(DrawEllipsePointSize, void, DrawEllipse(const wxPoint& pt, const wxSize& sz)); | |
311 | ||
312 | ||
313 | DocStr( | |
314 | DrawIcon, | |
315 | "Draw an icon on the display (does nothing if the device context is | |
316 | PostScript). This can be the simplest way of drawing bitmaps on a | |
317 | window.", ""); | |
318 | void DrawIcon(const wxIcon& icon, wxCoord x, wxCoord y); | |
319 | %Rename(DrawIconPoint, void, DrawIcon(const wxIcon& icon, const wxPoint& pt)); | |
320 | ||
321 | ||
322 | DocStr( | |
323 | DrawBitmap, | |
324 | "Draw a bitmap on the device context at the specified point. If | |
325 | *transparent* is true and the bitmap has a transparency mask, (or | |
326 | alpha channel on the platforms that support it) then the bitmap will | |
327 | be drawn transparently.", " | |
328 | ||
329 | When drawing a mono-bitmap, the current text foreground colour will be | |
330 | used to draw the foreground of the bitmap (all bits set to 1), and the | |
331 | current text background colour to draw the background (all bits set to | |
332 | 0). | |
333 | ||
334 | :see: `SetTextForeground`, `SetTextBackground` and `wx.MemoryDC`"); | |
335 | void DrawBitmap(const wxBitmap &bmp, wxCoord x, wxCoord y, bool useMask = false); | |
336 | %Rename(DrawBitmapPoint, void, DrawBitmap(const wxBitmap &bmp, const wxPoint& pt, bool useMask = false)); | |
337 | ||
338 | ||
339 | DocStr( | |
340 | DrawText, | |
341 | "Draws a text string at the specified point, using the current text | |
342 | font, and the current text foreground and background colours. | |
343 | ||
344 | The coordinates refer to the top-left corner of the rectangle bounding | |
345 | the string. See `GetTextExtent` for how to get the dimensions of a | |
346 | text string, which can be used to position the text more precisely. | |
347 | ||
348 | **NOTE**: under wxGTK the current logical function is used by this | |
349 | function but it is ignored by wxMSW. Thus, you should avoid using | |
350 | logical functions with this function in portable programs.", " | |
351 | ||
352 | :see: `DrawRotatedText`"); | |
353 | void DrawText(const wxString& text, wxCoord x, wxCoord y); | |
354 | %Rename(DrawTextPoint, void, DrawText(const wxString& text, const wxPoint& pt)); | |
355 | ||
356 | ||
357 | DocStr( | |
358 | DrawRotatedText, | |
359 | "Draws the text rotated by *angle* degrees, if supported by the platform. | |
360 | ||
361 | **NOTE**: Under Win9x only TrueType fonts can be drawn by this | |
362 | function. In particular, a font different from ``wx.NORMAL_FONT`` | |
363 | should be used as the it is not normally a TrueType | |
364 | font. ``wx.SWISS_FONT`` is an example of a font which is."," | |
365 | ||
366 | :see: `DrawText`"); | |
367 | void DrawRotatedText(const wxString& text, wxCoord x, wxCoord y, double angle); | |
368 | %Rename(DrawRotatedTextPoint, void, DrawRotatedText(const wxString& text, const wxPoint& pt, double angle)); | |
369 | ||
370 | ||
371 | // DocDeclStr( | |
372 | // bool , Blit(wxCoord xdest, wxCoord ydest, wxCoord width, wxCoord height, | |
373 | // wxDC *source, wxCoord xsrc, wxCoord ysrc, | |
374 | // int rop = wxCOPY, bool useMask = false, | |
375 | // wxCoord xsrcMask = -1, wxCoord ysrcMask = -1), | |
376 | // "Copy from a source DC to this DC. Parameters specify the destination | |
377 | //coordinates, size of area to copy, source DC, source coordinates, | |
378 | //logical function, whether to use a bitmap mask, and mask source | |
379 | //position.", " | |
380 | // | |
381 | // :param xdest: Destination device context x position. | |
382 | // :param ydest: Destination device context y position. | |
383 | // :param width: Width of source area to be copied. | |
384 | // :param height: Height of source area to be copied. | |
385 | // :param source: Source device context. | |
386 | // :param xsrc: Source device context x position. | |
387 | // :param ysrc: Source device context y position. | |
388 | // :param rop: Logical function to use: see `SetLogicalFunction`. | |
389 | // :param useMask: If true, Blit does a transparent blit using the mask | |
390 | // that is associated with the bitmap selected into the | |
391 | // source device context. | |
392 | // :param xsrcMask: Source x position on the mask. If both xsrcMask and | |
393 | // ysrcMask are -1, xsrc and ysrc will be assumed for | |
394 | // the mask source position. | |
395 | // :param ysrcMask: Source y position on the mask. | |
396 | //"); | |
397 | ||
398 | // DocDeclStrName( | |
399 | // bool , Blit(const wxPoint& destPt, const wxSize& sz, | |
400 | // wxDC *source, const wxPoint& srcPt, | |
401 | // int rop = wxCOPY, bool useMask = false, | |
402 | // const wxPoint& srcPtMask = wxDefaultPosition), | |
403 | // "Copy from a source DC to this DC. Parameters specify the destination | |
404 | //coordinates, size of area to copy, source DC, source coordinates, | |
405 | //logical function, whether to use a bitmap mask, and mask source | |
406 | //position.", " | |
407 | // | |
408 | // :param destPt: Destination device context position. | |
409 | // :param sz: Size of source area to be copied. | |
410 | // :param source: Source device context. | |
411 | // :param srcPt: Source device context position. | |
412 | // :param rop: Logical function to use: see `SetLogicalFunction`. | |
413 | // :param useMask: If true, Blit does a transparent blit using the mask | |
414 | // that is associated with the bitmap selected into the | |
415 | // source device context. | |
416 | // :param srcPtMask: Source position on the mask. | |
417 | //", | |
418 | // BlitPointSize); | |
419 | ||
420 | ||
421 | DocDeclAStr( | |
422 | void , DrawLines(int points, wxPoint* points_array, | |
423 | wxCoord xoffset = 0, wxCoord yoffset = 0), | |
424 | "DrawLines(self, List points, int xoffset=0, int yoffset=0)", | |
425 | "Draws lines using a sequence of `wx.Point` objects, adding the | |
426 | optional offset coordinate. The current pen is used for drawing the | |
427 | lines.", ""); | |
428 | ||
429 | ||
430 | DocDeclAStr( | |
431 | void , DrawPolygon(int points, wxPoint* points_array, | |
432 | wxCoord xoffset = 0, wxCoord yoffset = 0, | |
433 | int fillStyle = wxODDEVEN_RULE), | |
434 | "DrawPolygon(self, List points, int xoffset=0, int yoffset=0, | |
435 | int fillStyle=ODDEVEN_RULE)", | |
436 | "Draws a filled polygon using a sequence of `wx.Point` objects, adding | |
437 | the optional offset coordinate. The last argument specifies the fill | |
438 | rule: ``wx.ODDEVEN_RULE`` (the default) or ``wx.WINDING_RULE``. | |
439 | ||
440 | The current pen is used for drawing the outline, and the current brush | |
441 | for filling the shape. Using a transparent brush suppresses | |
442 | filling. Note that wxWidgets automatically closes the first and last | |
443 | points.", ""); | |
444 | ||
445 | ||
446 | // TODO: Figure out a good typemap for this... | |
447 | // Convert the first 3 args from a sequence of sequences? | |
448 | // void DrawPolyPolygon(int n, int count[], wxPoint points[], | |
449 | // wxCoord xoffset = 0, wxCoord yoffset = 0, | |
450 | // int fillStyle = wxODDEVEN_RULE); | |
451 | ||
452 | ||
453 | DocDeclStr( | |
454 | void , DrawLabel(const wxString& text, const wxRect& rect, | |
455 | int alignment = wxALIGN_LEFT | wxALIGN_TOP, | |
456 | int indexAccel = -1), | |
457 | "Draw *text* within the specified rectangle, abiding by the alignment | |
458 | flags. Will additionally emphasize the character at *indexAccel* if | |
459 | it is not -1.", " | |
460 | ||
461 | :see: `DrawImageLabel`"); | |
462 | ||
463 | DocDeclStrName( | |
464 | void, DrawLabel(const wxString& text, | |
465 | const wxBitmap& image, | |
466 | const wxRect& rect, | |
467 | int alignment = wxALIGN_LEFT | wxALIGN_TOP, | |
468 | int indexAccel = -1), | |
469 | "Draw *text* and an image (which may be ``wx.NullBitmap`` to skip | |
470 | drawing it) within the specified rectangle, abiding by the alignment | |
471 | flags. Will additionally emphasize the character at *indexAccel* if | |
472 | it is not -1.", "", DrawImageLabel); | |
473 | ||
474 | ||
475 | DocDeclAStr( | |
476 | void , DrawSpline(int points, wxPoint* points_array), | |
477 | "DrawSpline(self, List points)", | |
478 | "Draws a spline between all given control points, (a list of `wx.Point` | |
479 | objects) using the current pen. The spline is drawn using a series of | |
480 | lines, using an algorithm taken from the X drawing program 'XFIG'.", ""); | |
481 | ||
482 | ||
483 | DocDeclStr( | |
484 | virtual void , Clear(), | |
485 | "Clears the device context using the current background brush.", ""); | |
486 | ||
487 | ||
488 | // set objects to use for drawing | |
489 | // ------------------------------ | |
490 | ||
491 | DocDeclStr( | |
492 | virtual void , SetFont(const wxFont& font), | |
493 | "Sets the current font for the DC. It must be a valid font, in | |
494 | particular you should not pass ``wx.NullFont`` to this method."," | |
495 | ||
496 | :see: `wx.Font`"); | |
497 | ||
498 | DocDeclStr( | |
499 | virtual void , SetPen(const wxPen& pen), | |
500 | "Sets the current pen for the DC. | |
501 | ||
502 | If the argument is ``wx.NullPen``, the current pen is selected out of the | |
503 | device context, and the original pen restored.", " | |
504 | ||
505 | :see: `wx.Pen`"); | |
506 | ||
507 | DocDeclStr( | |
508 | virtual void , SetBrush(const wxBrush& brush), | |
509 | "Sets the current brush for the DC. | |
510 | ||
511 | If the argument is ``wx.NullBrush``, the current brush is selected out | |
512 | of the device context, and the original brush restored, allowing the | |
513 | current brush to be destroyed safely."," | |
514 | ||
515 | :see: `wx.Brush`"); | |
516 | ||
517 | DocDeclStr( | |
518 | virtual void , SetBackground(const wxBrush& brush), | |
519 | "Sets the current background brush for the DC.", ""); | |
520 | ||
521 | DocDeclStr( | |
522 | virtual void , SetBackgroundMode(int mode), | |
523 | "*mode* may be one of ``wx.SOLID`` and ``wx.TRANSPARENT``. This setting | |
524 | determines whether text will be drawn with a background colour or | |
525 | not.", ""); | |
526 | ||
527 | DocDeclStr( | |
528 | virtual void , SetPalette(const wxPalette& palette), | |
529 | "If this is a window DC or memory DC, assigns the given palette to the | |
530 | window or bitmap associated with the DC. If the argument is | |
531 | ``wx.NullPalette``, the current palette is selected out of the device | |
532 | context, and the original palette restored.", " | |
533 | ||
534 | :see: `wx.Palette`"); | |
535 | ||
536 | ||
537 | DocDeclStr( | |
538 | virtual void , SetTextForeground(const wxColour& colour), | |
539 | "Sets the current text foreground colour for the DC.", ""); | |
540 | ||
541 | DocDeclStr( | |
542 | virtual void , SetTextBackground(const wxColour& colour), | |
543 | "Sets the current text background colour for the DC.", ""); | |
544 | ||
545 | DocDeclStr( | |
546 | virtual void , SetLogicalFunction(int function), | |
547 | "Sets the current logical function for the device context. This | |
548 | determines how a source pixel (from a pen or brush colour, or source | |
549 | device context if using `Blit`) combines with a destination pixel in | |
550 | the current device context. | |
551 | ||
552 | The possible values and their meaning in terms of source and | |
553 | destination pixel values are as follows: | |
554 | ||
555 | ================ ========================== | |
556 | wx.AND src AND dst | |
557 | wx.AND_INVERT (NOT src) AND dst | |
558 | wx.AND_REVERSE src AND (NOT dst) | |
559 | wx.CLEAR 0 | |
560 | wx.COPY src | |
561 | wx.EQUIV (NOT src) XOR dst | |
562 | wx.INVERT NOT dst | |
563 | wx.NAND (NOT src) OR (NOT dst) | |
564 | wx.NOR (NOT src) AND (NOT dst) | |
565 | wx.NO_OP dst | |
566 | wx.OR src OR dst | |
567 | wx.OR_INVERT (NOT src) OR dst | |
568 | wx.OR_REVERSE src OR (NOT dst) | |
569 | wx.SET 1 | |
570 | wx.SRC_INVERT NOT src | |
571 | wx.XOR src XOR dst | |
572 | ================ ========================== | |
573 | ||
574 | The default is wx.COPY, which simply draws with the current | |
575 | colour. The others combine the current colour and the background using | |
576 | a logical operation. wx.INVERT is commonly used for drawing rubber | |
577 | bands or moving outlines, since drawing twice reverts to the original | |
578 | colour. | |
579 | ", ""); | |
580 | }; |