]>
Commit | Line | Data |
---|---|---|
23324ae1 FM |
1 | ///////////////////////////////////////////////////////////////////////////// |
2 | // Name: dcsvg.h | |
e54c96f1 | 3 | // Purpose: interface of wxSVGFileDC |
23324ae1 FM |
4 | // Author: wxWidgets team |
5 | // RCS-ID: $Id$ | |
6 | // Licence: wxWindows license | |
7 | ///////////////////////////////////////////////////////////////////////////// | |
8 | ||
9 | /** | |
10 | @class wxSVGFileDC | |
11 | @wxheader{dcsvg.h} | |
7c913512 | 12 | |
23324ae1 FM |
13 | A wxSVGFileDC is a @e device context onto which graphics and text can be drawn, |
14 | and the output | |
7c913512 | 15 | produced as a vector file, in the SVG format |
23324ae1 FM |
16 | (see W3C specifications). |
17 | This format can be read by a range of programs, including a Netscape plugin | |
7c913512 | 18 | (Adobe), full details |
23324ae1 FM |
19 | in the SVG Implementation and Resource Directory. |
20 | Vector formats may often be smaller than raster formats. | |
7c913512 | 21 | |
23324ae1 | 22 | The intention behind wxSVGFileDC is that it can be used to produce a file |
7c913512 | 23 | corresponding |
23324ae1 FM |
24 | to the screen display context, wxSVGFileDC, by passing the wxSVGFileDC as a |
25 | parameter instead of a wxSVGFileDC. Thus the wxSVGFileDC is a write-only class. | |
7c913512 | 26 | |
23324ae1 FM |
27 | As the wxSVGFileDC is a vector format, raster operations like GetPixel are |
28 | unlikely to be supported. | |
29 | However, the SVG specification allows for PNG format raster files to be | |
7c913512 | 30 | embedded in the SVG, and so |
23324ae1 | 31 | bitmaps, icons and blit operations into the wxSVGFileDC are supported. |
7c913512 | 32 | |
23324ae1 FM |
33 | A more substantial SVG library (for reading and writing) is available at the |
34 | wxArt2D website. | |
7c913512 | 35 | |
23324ae1 FM |
36 | @library{wxcore} |
37 | @category{FIXME} | |
7c913512 | 38 | |
e54c96f1 | 39 | @see @b Members |
23324ae1 FM |
40 | */ |
41 | class wxSVGFileDC : public wxDC | |
42 | { | |
43 | public: | |
44 | //@{ | |
45 | /** | |
7c913512 | 46 | Constructors: |
4cc4bfaf | 47 | a filename @a f with default size 340x240 at 72.0 dots per inch (a frequent |
23324ae1 | 48 | screen resolution). |
4cc4bfaf FM |
49 | a filename @a f with size @a Width by @a Height at 72.0 dots per inch |
50 | a filename @a f with size @a Width by @a Height at @a dpi resolution. | |
23324ae1 FM |
51 | */ |
52 | wxSVGFileDC(wxString f); | |
7c913512 FM |
53 | wxSVGFileDC(wxString f, int Width, int Height); |
54 | wxSVGFileDC(wxString f, int Width, int Height, float dpi); | |
23324ae1 FM |
55 | //@} |
56 | ||
57 | /** | |
58 | Destructor. | |
59 | */ | |
60 | ~wxSVGFileDC(); | |
61 | ||
62 | /** | |
63 | Does nothing | |
64 | */ | |
65 | ||
66 | ||
67 | /** | |
68 | As wxDC: Copy from a source DC to this DC, specifying the destination | |
69 | coordinates, size of area to copy, source DC, source coordinates, | |
70 | logical function, whether to use a bitmap mask, and mask source position. | |
71 | */ | |
72 | bool Blit(wxCoord xdest, wxCoord ydest, wxCoord width, | |
73 | wxCoord height, wxSVGFileDC* source, | |
74 | wxCoord xsrc, wxCoord ysrc, | |
75 | int logicalFunc = wxCOPY, | |
76 | bool useMask = FALSE, | |
77 | wxCoord xsrcMask = -1, | |
78 | wxCoord ysrcMask = -1); | |
79 | ||
80 | /** | |
7c913512 FM |
81 | Adds the specified point to the bounding box which can be retrieved with |
82 | wxDC::MinX, wxDC::MaxX and | |
23324ae1 FM |
83 | wxDC::MinY, wxDC::MaxY functions. |
84 | */ | |
85 | void CalcBoundingBox(wxCoord x, wxCoord y); | |
86 | ||
87 | /** | |
88 | This makes no sense in wxSVGFileDC and does nothing | |
89 | */ | |
90 | void Clear(); | |
91 | ||
92 | /** | |
93 | Not Implemented | |
94 | */ | |
95 | void CrossHair(wxCoord x, wxCoord y); | |
96 | ||
97 | /** | |
98 | Not Implemented | |
99 | */ | |
100 | void DestroyClippingRegion(); | |
101 | ||
102 | /** | |
103 | Convert device X coordinate to logical coordinate, using the current | |
104 | mapping mode. | |
105 | */ | |
106 | wxCoord DeviceToLogicalX(wxCoord x); | |
107 | ||
108 | /** | |
109 | Convert device X coordinate to relative logical coordinate, using the current | |
110 | mapping mode but ignoring the x axis orientation. | |
111 | Use this function for converting a width, for example. | |
112 | */ | |
113 | wxCoord DeviceToLogicalXRel(wxCoord x); | |
114 | ||
115 | /** | |
116 | Converts device Y coordinate to logical coordinate, using the current | |
117 | mapping mode. | |
118 | */ | |
119 | wxCoord DeviceToLogicalY(wxCoord y); | |
120 | ||
121 | /** | |
122 | Convert device Y coordinate to relative logical coordinate, using the current | |
123 | mapping mode but ignoring the y axis orientation. | |
124 | Use this function for converting a height, for example. | |
125 | */ | |
126 | wxCoord DeviceToLogicalYRel(wxCoord y); | |
127 | ||
128 | /** | |
129 | Draws an arc of a circle, centred on (@e xc, yc), with starting point (@e x1, | |
130 | y1) | |
131 | and ending at (@e x2, y2). The current pen is used for the outline | |
132 | and the current brush for filling the shape. | |
23324ae1 FM |
133 | The arc is drawn in an anticlockwise direction from the start point to the end |
134 | point. | |
135 | */ | |
136 | void DrawArc(wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2, | |
137 | wxCoord xc, wxCoord yc); | |
138 | ||
139 | /** | |
4cc4bfaf | 140 | Draw a bitmap on the device context at the specified point. If @a transparent |
23324ae1 FM |
141 | is @true and the bitmap has |
142 | a transparency mask, the bitmap will be drawn transparently. | |
23324ae1 FM |
143 | When drawing a mono-bitmap, the current text foreground colour will be used to |
144 | draw the foreground | |
145 | of the bitmap (all bits set to 1), and the current text background colour to | |
146 | draw the background | |
7c913512 | 147 | (all bits set to 0). See also wxDC::SetTextForeground, |
23324ae1 FM |
148 | wxDC::SetTextBackground and wxMemoryDC. |
149 | */ | |
150 | void DrawBitmap(const wxBitmap& bitmap, wxCoord x, wxCoord y, | |
151 | bool transparent); | |
152 | ||
153 | //@{ | |
154 | /** | |
155 | Draws a check mark inside the given rectangle. | |
156 | */ | |
157 | void DrawCheckMark(wxCoord x, wxCoord y, wxCoord width, | |
158 | wxCoord height); | |
4cc4bfaf | 159 | void DrawCheckMark(const wxRect& rect); |
23324ae1 FM |
160 | //@} |
161 | ||
162 | //@{ | |
163 | /** | |
164 | Draws a circle with the given centre and radius. | |
3c4f71cc | 165 | |
4cc4bfaf | 166 | @see wxDC::DrawEllipse |
23324ae1 FM |
167 | */ |
168 | void DrawCircle(wxCoord x, wxCoord y, wxCoord radius); | |
7c913512 | 169 | void DrawCircle(const wxPoint& pt, wxCoord radius); |
23324ae1 FM |
170 | //@} |
171 | ||
172 | //@{ | |
173 | /** | |
174 | Draws an ellipse contained in the rectangle specified either with the given top | |
175 | left corner and the given size or directly. The current pen is used for the | |
176 | outline and the current brush for filling the shape. | |
3c4f71cc | 177 | |
4cc4bfaf | 178 | @see wxDC::DrawCircle |
23324ae1 FM |
179 | */ |
180 | void DrawEllipse(wxCoord x, wxCoord y, wxCoord width, | |
181 | wxCoord height); | |
7c913512 FM |
182 | void DrawEllipse(const wxPoint& pt, const wxSize& size); |
183 | void DrawEllipse(const wxRect& rect); | |
23324ae1 FM |
184 | //@} |
185 | ||
186 | /** | |
187 | Draws an arc of an ellipse. The current pen is used for drawing the arc and | |
188 | the current brush is used for drawing the pie. | |
4cc4bfaf | 189 | @a x and @a y specify the x and y coordinates of the upper-left corner of the |
23324ae1 FM |
190 | rectangle that contains |
191 | the ellipse. | |
4cc4bfaf | 192 | @a width and @a height specify the width and height of the rectangle that |
23324ae1 FM |
193 | contains |
194 | the ellipse. | |
4cc4bfaf | 195 | @a start and @a end specify the start and end of the arc relative to the |
23324ae1 FM |
196 | three-o'clock |
197 | position from the center of the rectangle. Angles are specified | |
198 | in degrees (360 is a complete circle). Positive values mean | |
4cc4bfaf | 199 | counter-clockwise motion. If @a start is equal to @e end, a |
23324ae1 FM |
200 | complete ellipse will be drawn. |
201 | */ | |
202 | void DrawEllipticArc(wxCoord x, wxCoord y, wxCoord width, | |
203 | wxCoord height, | |
204 | double start, | |
205 | double end); | |
206 | ||
207 | /** | |
208 | Draw an icon on the display (does nothing if the device context is PostScript). | |
209 | This can be the simplest way of drawing bitmaps on a window. | |
210 | */ | |
211 | void DrawIcon(const wxIcon& icon, wxCoord x, wxCoord y); | |
212 | ||
213 | /** | |
214 | Draws a line from the first point to the second. The current pen is used | |
215 | for drawing the line. | |
216 | */ | |
217 | void DrawLine(wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2); | |
218 | ||
219 | //@{ | |
220 | /** | |
4cc4bfaf | 221 | Draws lines using an array of @a points of size @e n, or list of |
23324ae1 FM |
222 | pointers to points, adding the optional offset coordinate. The current |
223 | pen is used for drawing the lines. The programmer is responsible for | |
224 | deleting the list of points. | |
225 | */ | |
226 | void DrawLines(int n, wxPoint points[], wxCoord xoffset = 0, | |
227 | wxCoord yoffset = 0); | |
4cc4bfaf | 228 | void DrawLines(wxList* points, wxCoord xoffset = 0, |
7c913512 | 229 | wxCoord yoffset = 0); |
23324ae1 FM |
230 | //@} |
231 | ||
232 | /** | |
233 | Draws a point using the current pen. | |
234 | */ | |
235 | void DrawPoint(wxCoord x, wxCoord y); | |
236 | ||
237 | //@{ | |
238 | /** | |
4cc4bfaf | 239 | Draws a filled polygon using an array of @a points of size @e n, |
23324ae1 | 240 | or list of pointers to points, adding the optional offset coordinate. |
23324ae1 FM |
241 | The last argument specifies the fill rule: @b wxODDEVEN_RULE (the |
242 | default) or @b wxWINDING_RULE. | |
23324ae1 FM |
243 | The current pen is used for drawing the outline, and the current brush |
244 | for filling the shape. Using a transparent brush suppresses filling. | |
245 | The programmer is responsible for deleting the list of points. | |
23324ae1 FM |
246 | Note that wxWindows automatically closes the first and last points. |
247 | */ | |
248 | void DrawPolygon(int n, wxPoint points[], wxCoord xoffset = 0, | |
249 | wxCoord yoffset = 0, | |
250 | int fill_style = wxODDEVEN_RULE); | |
4cc4bfaf | 251 | void DrawPolygon(wxList* points, wxCoord xoffset = 0, |
7c913512 FM |
252 | wxCoord yoffset = 0, |
253 | int fill_style = wxODDEVEN_RULE); | |
23324ae1 FM |
254 | //@} |
255 | ||
256 | /** | |
257 | Draws a rectangle with the given top left corner, and with the given | |
258 | size. The current pen is used for the outline and the current brush | |
259 | for filling the shape. | |
260 | */ | |
261 | void DrawRectangle(wxCoord x, wxCoord y, wxCoord width, | |
262 | wxCoord height); | |
263 | ||
264 | /** | |
4cc4bfaf | 265 | Draws the text rotated by @a angle degrees. |
23324ae1 FM |
266 | The wxMSW wxDC and wxSVGFileDC rotate the text around slightly different |
267 | points, depending on the size of the font | |
268 | */ | |
269 | void DrawRotatedText(const wxString& text, wxCoord x, wxCoord y, | |
270 | double angle); | |
271 | ||
272 | /** | |
273 | Draws a rectangle with the given top left corner, and with the given | |
274 | size. The corners are quarter-circles using the given radius. The | |
275 | current pen is used for the outline and the current brush for filling | |
276 | the shape. | |
4cc4bfaf FM |
277 | If @a radius is positive, the value is assumed to be the |
278 | radius of the rounded corner. If @a radius is negative, | |
23324ae1 FM |
279 | the absolute value is assumed to be the @e proportion of the smallest |
280 | dimension of the rectangle. This means that the corner can be | |
281 | a sensible size relative to the size of the rectangle, and also avoids | |
282 | the strange effects X produces when the corners are too big for | |
283 | the rectangle. | |
284 | */ | |
285 | void DrawRoundedRectangle(wxCoord x, wxCoord y, wxCoord width, | |
286 | wxCoord height, | |
287 | double radius = 20); | |
288 | ||
289 | //@{ | |
290 | /** | |
291 | Draws a three-point spline using the current pen. | |
292 | */ | |
4cc4bfaf | 293 | void DrawSpline(wxList* points); |
7c913512 FM |
294 | void DrawSpline(wxCoord x1, wxCoord y1, wxCoord x2, |
295 | wxCoord y2, | |
296 | wxCoord x3, | |
297 | wxCoord y3); | |
23324ae1 FM |
298 | //@} |
299 | ||
300 | /** | |
301 | Draws a text string at the specified point, using the current text font, | |
302 | and the current text foreground and background colours. | |
23324ae1 FM |
303 | The coordinates refer to the top-left corner of the rectangle bounding |
304 | the string. See GetTextExtent() for how | |
305 | to get the dimensions of a text string, which can be used to position the | |
306 | text more precisely. | |
307 | */ | |
308 | void DrawText(const wxString& text, wxCoord x, wxCoord y); | |
309 | ||
310 | /** | |
311 | Does nothing | |
312 | */ | |
313 | void EndDoc(); | |
314 | ||
315 | /** | |
316 | Does nothing | |
317 | */ | |
318 | void EndDrawing(); | |
319 | ||
320 | /** | |
321 | Does nothing | |
322 | */ | |
323 | void EndPage(); | |
324 | ||
325 | /** | |
326 | Not implemented | |
327 | */ | |
328 | void FloodFill(wxCoord x, wxCoord y, const wxColour& colour, | |
4cc4bfaf | 329 | int style = wxFLOOD_SURFACE); |
23324ae1 FM |
330 | |
331 | //@{ | |
332 | /** | |
333 | Gets the brush used for painting the background (see | |
334 | wxSVGFileDC::SetBackground). | |
335 | */ | |
328f5751 FM |
336 | wxBrush GetBackground() const; |
337 | const wxBrush GetBackground() const; | |
23324ae1 FM |
338 | //@} |
339 | ||
340 | /** | |
341 | Returns the current background mode: @c wxSOLID or @c wxTRANSPARENT. | |
3c4f71cc | 342 | |
4cc4bfaf | 343 | @see wxDC::SetBackgroundMode |
23324ae1 | 344 | */ |
328f5751 | 345 | int GetBackgroundMode() const; |
23324ae1 FM |
346 | |
347 | //@{ | |
348 | /** | |
349 | Gets the current brush (see wxSVGFileDC::SetBrush). | |
350 | */ | |
328f5751 FM |
351 | wxBrush GetBrush() const; |
352 | const wxBrush GetBrush() const; | |
23324ae1 FM |
353 | //@} |
354 | ||
355 | /** | |
356 | Gets the character height of the currently set font. | |
357 | */ | |
358 | wxCoord GetCharHeight(); | |
359 | ||
360 | /** | |
361 | Gets the average character width of the currently set font. | |
362 | */ | |
363 | wxCoord GetCharWidth(); | |
364 | ||
365 | /** | |
366 | Not implemented | |
367 | */ | |
368 | void GetClippingBox(wxCoord x, wxCoord y, wxCoord width, | |
369 | wxCoord height); | |
370 | ||
371 | //@{ | |
372 | /** | |
373 | Gets the current font (see wxSVGFileDC::SetFont). | |
374 | */ | |
328f5751 FM |
375 | wxFont GetFont() const; |
376 | const wxFont GetFont() const; | |
23324ae1 FM |
377 | //@} |
378 | ||
379 | /** | |
380 | Gets the current logical function (see wxSVGFileDC::SetLogicalFunction). | |
381 | */ | |
382 | int GetLogicalFunction(); | |
383 | ||
384 | /** | |
385 | Gets the @e mapping mode for the device context (see wxSVGFileDC::SetMapMode). | |
386 | */ | |
387 | int GetMapMode(); | |
388 | ||
389 | //@{ | |
390 | /** | |
391 | Gets the current pen (see wxSVGFileDC::SetPen). | |
392 | */ | |
328f5751 FM |
393 | wxPen GetPen() const; |
394 | const wxPen GetPen() const; | |
23324ae1 FM |
395 | //@} |
396 | ||
397 | /** | |
398 | Not implemented | |
399 | */ | |
4cc4bfaf | 400 | bool GetPixel(wxCoord x, wxCoord y, wxColour* colour); |
23324ae1 FM |
401 | |
402 | /** | |
403 | For a Windows printer device context, this gets the horizontal and vertical | |
404 | resolution. | |
405 | */ | |
4cc4bfaf | 406 | void GetSize(wxCoord* width, wxCoord* height); |
23324ae1 FM |
407 | |
408 | //@{ | |
409 | /** | |
410 | Gets the current text background colour (see wxSVGFileDC::SetTextBackground). | |
411 | */ | |
328f5751 FM |
412 | wxColour GetTextBackground() const; |
413 | const wxColour GetTextBackground() const; | |
23324ae1 FM |
414 | //@} |
415 | ||
416 | /** | |
417 | Gets the dimensions of the string using the currently selected font. | |
4cc4bfaf FM |
418 | @a string is the text string to measure, @a w and @a h are |
419 | the total width and height respectively, @a descent is the | |
23324ae1 | 420 | dimension from the baseline of the font to the bottom of the |
4cc4bfaf | 421 | descender, and @a externalLeading is any extra vertical space added |
23324ae1 | 422 | to the font by the font designer (usually is zero). |
4cc4bfaf | 423 | The optional parameter @a font specifies an alternative |
23324ae1 FM |
424 | to the currently selected font: but note that this does not |
425 | yet work under Windows, so you need to set a font for | |
426 | the device context first. | |
23324ae1 FM |
427 | See also wxFont, SetFont(). |
428 | */ | |
4cc4bfaf FM |
429 | void GetTextExtent(const wxString& string, wxCoord* w, |
430 | wxCoord* h, | |
431 | wxCoord* descent = NULL, | |
432 | wxCoord* externalLeading = NULL, | |
433 | wxFont* font = NULL); | |
23324ae1 FM |
434 | |
435 | //@{ | |
436 | /** | |
437 | Gets the current text foreground colour (see wxSVGFileDC::SetTextForeground). | |
438 | */ | |
328f5751 FM |
439 | wxColour GetTextForeground() const; |
440 | const wxColour GetTextForeground() const; | |
23324ae1 FM |
441 | //@} |
442 | ||
443 | /** | |
444 | Gets the current user scale factor (set by wxDC::SetUserScale). | |
445 | */ | |
446 | void GetUserScale(double x, double y); | |
447 | ||
448 | /** | |
449 | Converts logical X coordinate to device coordinate, using the current | |
450 | mapping mode. | |
451 | */ | |
452 | wxCoord LogicalToDeviceX(wxCoord x); | |
453 | ||
454 | /** | |
455 | Converts logical X coordinate to relative device coordinate, using the current | |
456 | mapping mode but ignoring the x axis orientation. | |
457 | Use this for converting a width, for example. | |
458 | */ | |
459 | wxCoord LogicalToDeviceXRel(wxCoord x); | |
460 | ||
461 | /** | |
462 | Converts logical Y coordinate to device coordinate, using the current | |
463 | mapping mode. | |
464 | */ | |
465 | wxCoord LogicalToDeviceY(wxCoord y); | |
466 | ||
467 | /** | |
468 | Converts logical Y coordinate to relative device coordinate, using the current | |
469 | mapping mode but ignoring the y axis orientation. | |
470 | Use this for converting a height, for example. | |
471 | */ | |
472 | wxCoord LogicalToDeviceYRel(wxCoord y); | |
473 | ||
474 | /** | |
475 | Gets the maximum horizontal extent used in drawing commands so far. | |
476 | */ | |
4cc4bfaf | 477 | wxCoord MaxX(); |
23324ae1 FM |
478 | |
479 | /** | |
480 | Gets the maximum vertical extent used in drawing commands so far. | |
481 | */ | |
4cc4bfaf | 482 | wxCoord MaxY(); |
23324ae1 FM |
483 | |
484 | /** | |
485 | Gets the minimum horizontal extent used in drawing commands so far. | |
486 | */ | |
4cc4bfaf | 487 | wxCoord MinX(); |
23324ae1 FM |
488 | |
489 | /** | |
490 | Gets the minimum vertical extent used in drawing commands so far. | |
491 | */ | |
4cc4bfaf | 492 | wxCoord MinY(); |
23324ae1 FM |
493 | |
494 | /** | |
7c913512 | 495 | Returns @true if the DC is ok to use; False values arise from being unable to |
23324ae1 FM |
496 | write the file |
497 | */ | |
4cc4bfaf | 498 | bool Ok(); |
23324ae1 FM |
499 | |
500 | /** | |
501 | Resets the bounding box: after a call to this function, the bounding box | |
502 | doesn't contain anything. | |
3c4f71cc | 503 | |
4cc4bfaf | 504 | @see wxDC::CalcBoundingBox |
23324ae1 FM |
505 | */ |
506 | void ResetBoundingBox(); | |
507 | ||
508 | /** | |
509 | Sets the x and y axis orientation (i.e., the direction from lowest to | |
510 | highest values on the axis). The default orientation is the natural | |
511 | orientation, e.g. x axis from left to right and y axis from bottom up. | |
3c4f71cc | 512 | |
7c913512 | 513 | @param xLeftRight |
4cc4bfaf FM |
514 | True to set the x axis orientation to the natural |
515 | left to right orientation, @false to invert it. | |
7c913512 | 516 | @param yBottomUp |
4cc4bfaf FM |
517 | True to set the y axis orientation to the natural |
518 | bottom up orientation, @false to invert it. | |
23324ae1 FM |
519 | */ |
520 | void SetAxisOrientation(bool xLeftRight, bool yBottomUp); | |
521 | ||
522 | /** | |
523 | Sets the current background brush for the DC. | |
524 | */ | |
525 | void SetBackground(const wxBrush& brush); | |
526 | ||
527 | /** | |
4cc4bfaf | 528 | @a mode may be one of wxSOLID and wxTRANSPARENT. This setting determines |
23324ae1 FM |
529 | whether text will be drawn with a background colour or not. |
530 | */ | |
531 | void SetBackgroundMode(int mode); | |
532 | ||
533 | /** | |
534 | Sets the current brush for the DC. | |
23324ae1 FM |
535 | If the argument is wxNullBrush, the current brush is selected out of the device |
536 | context, and the original brush restored, allowing the current brush to | |
537 | be destroyed safely. | |
23324ae1 | 538 | See also wxBrush. |
23324ae1 FM |
539 | See also wxMemoryDC for the interpretation of colours |
540 | when drawing into a monochrome bitmap. | |
541 | */ | |
542 | void SetBrush(const wxBrush& brush); | |
543 | ||
544 | //@{ | |
545 | /** | |
546 | Not implemented | |
547 | */ | |
548 | void SetClippingRegion(wxCoord x, wxCoord y, wxCoord width, | |
549 | wxCoord height); | |
7c913512 FM |
550 | void SetClippingRegion(const wxPoint& pt, const wxSize& sz); |
551 | void SetClippingRegion(const wxRect& rect); | |
552 | void SetClippingRegion(const wxRegion& region); | |
23324ae1 FM |
553 | //@} |
554 | ||
555 | /** | |
556 | Sets the device origin (i.e., the origin in pixels after scaling has been | |
557 | applied). | |
23324ae1 FM |
558 | This function may be useful in Windows printing |
559 | operations for placing a graphic on a page. | |
560 | */ | |
561 | void SetDeviceOrigin(wxCoord x, wxCoord y); | |
562 | ||
563 | /** | |
564 | Sets the current font for the DC. It must be a valid font, in particular you | |
565 | should not pass @c wxNullFont to this method. | |
23324ae1 FM |
566 | See also wxFont. |
567 | */ | |
568 | void SetFont(const wxFont& font); | |
569 | ||
570 | /** | |
571 | Only wxCOPY is avalaible; trying to set one of the othe values will fail | |
572 | */ | |
573 | void SetLogicalFunction(int function); | |
574 | ||
575 | /** | |
576 | The @e mapping mode of the device context defines the unit of | |
577 | measurement used to convert logical units to device units. Note that | |
578 | in X, text drawing isn't handled consistently with the mapping mode; a | |
579 | font is always specified in point size. However, setting the @e user scale (see | |
580 | wxSVGFileDC::SetUserScale) scales the text appropriately. In | |
581 | Windows, scaleable TrueType fonts are always used; in X, results depend | |
582 | on availability of fonts, but usually a reasonable match is found. | |
23324ae1 FM |
583 | Note that the coordinate origin should ideally be selectable, but for |
584 | now is always at the top left of the screen/printer. | |
23324ae1 FM |
585 | Drawing to a Windows printer device context under UNIX |
586 | uses the current mapping mode, but mapping mode is currently ignored for | |
587 | PostScript output. | |
23324ae1 | 588 | The mapping mode can be one of the following: |
3c4f71cc | 589 | |
23324ae1 | 590 | wxMM_TWIPS |
3c4f71cc | 591 | |
23324ae1 FM |
592 | Each logical unit is 1/20 of a point, or 1/1440 of |
593 | an inch. | |
3c4f71cc | 594 | |
23324ae1 | 595 | wxMM_POINTS |
3c4f71cc | 596 | |
23324ae1 | 597 | Each logical unit is a point, or 1/72 of an inch. |
3c4f71cc | 598 | |
23324ae1 | 599 | wxMM_METRIC |
3c4f71cc | 600 | |
23324ae1 | 601 | Each logical unit is 1 mm. |
3c4f71cc | 602 | |
23324ae1 | 603 | wxMM_LOMETRIC |
3c4f71cc | 604 | |
23324ae1 | 605 | Each logical unit is 1/10 of a mm. |
3c4f71cc | 606 | |
23324ae1 | 607 | wxMM_TEXT |
3c4f71cc | 608 | |
23324ae1 FM |
609 | Each logical unit is 1 pixel. |
610 | */ | |
611 | void SetMapMode(int int); | |
612 | ||
613 | /** | |
614 | Not implemented | |
615 | */ | |
616 | void SetPalette(const wxPalette& palette); | |
617 | ||
618 | /** | |
619 | Sets the current pen for the DC. | |
23324ae1 FM |
620 | If the argument is wxNullPen, the current pen is selected out of the device |
621 | context, and the original pen restored. | |
23324ae1 FM |
622 | See also wxMemoryDC for the interpretation of colours |
623 | when drawing into a monochrome bitmap. | |
624 | */ | |
625 | void SetPen(const wxPen& pen); | |
626 | ||
627 | /** | |
628 | Sets the current text background colour for the DC. | |
629 | */ | |
630 | void SetTextBackground(const wxColour& colour); | |
631 | ||
632 | /** | |
633 | Sets the current text foreground colour for the DC. | |
23324ae1 FM |
634 | See also wxMemoryDC for the interpretation of colours |
635 | when drawing into a monochrome bitmap. | |
636 | */ | |
637 | void SetTextForeground(const wxColour& colour); | |
638 | ||
639 | /** | |
640 | Sets the user scaling factor, useful for applications which require | |
641 | 'zooming'. | |
642 | */ | |
643 | void SetUserScale(double xScale, double yScale); | |
644 | ||
645 | /** | |
646 | Does nothing | |
647 | */ | |
648 | bool StartDoc(const wxString& message); | |
649 | }; | |
e54c96f1 | 650 |