]> git.saurik.com Git - wxWidgets.git/blame - samples/drawing/drawing.cpp
Fixed clicking on MSW slider not changing value with small ranges.
[wxWidgets.git] / samples / drawing / drawing.cpp
CommitLineData
aba99005 1/////////////////////////////////////////////////////////////////////////////
b11729f1 2// Name: samples/drawing/drawing.cpp
0f0c61d0 3// Purpose: shows and tests wxDC features
aba99005
RR
4// Author: Robert Roebling
5// Modified by:
6// Created: 04/01/98
7// RCS-ID: $Id$
8// Copyright: (c) Robert Roebling
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12// ============================================================================
13// declarations
14// ============================================================================
15
16// ----------------------------------------------------------------------------
17// headers
18// ----------------------------------------------------------------------------
568708e2 19
aba99005
RR
20// For compilers that support precompilation, includes "wx/wx.h".
21#include "wx/wxprec.h"
22
23#ifdef __BORLANDC__
24 #pragma hdrstop
25#endif
26
27// for all others, include the necessary headers (this file is usually all you
be5a51fb 28// need because it includes almost all "standard" wxWidgets headers
aba99005
RR
29#ifndef WX_PRECOMP
30 #include "wx/wx.h"
31#endif
32
0f0c61d0 33#include "wx/colordlg.h"
107a1787 34#include "wx/image.h"
389d906b 35#include "wx/artprov.h"
888dde65 36#include "wx/dcgraph.h"
8a021e00 37#include "wx/overlay.h"
795b5a8b 38#include "wx/graphics.h"
e0ac7d94 39#include "wx/filename.h"
8c6b0819 40#include "wx/metafile.h"
f31a4cb2 41
8a021e00
SC
42#define TEST_CAIRO_EVERYWHERE 0
43
aba99005 44// ----------------------------------------------------------------------------
795b5a8b 45// resources
aba99005 46// ----------------------------------------------------------------------------
568708e2 47
aba99005 48// the application icon
3cb332c1
VZ
49#if !defined(__WXMSW__) && !defined(__WXPM__)
50 #include "../sample.xpm"
aba99005
RR
51#endif
52
568708e2
VZ
53// ----------------------------------------------------------------------------
54// global variables
55// ----------------------------------------------------------------------------
56
f6bcfd97
BP
57static wxBitmap *gs_bmpNoMask = NULL,
58 *gs_bmpWithColMask = NULL,
59 *gs_bmpMask = NULL,
60 *gs_bmpWithMask = NULL,
61 *gs_bmp4 = NULL,
62 *gs_bmp4_mono = NULL,
63 *gs_bmp36 = NULL;
568708e2 64
aba99005
RR
65// ----------------------------------------------------------------------------
66// private classes
67// ----------------------------------------------------------------------------
68
69// Define a new application type, each program should derive a class from wxApp
70class MyApp : public wxApp
71{
72public:
73 // override base class virtuals
74 // ----------------------------
75
76 // this one is called on application startup and is a good place for the app
77 // initialization (doing it here and not in the ctor allows to have an error
78 // return: if OnInit() returns false, the application terminates)
79 virtual bool OnInit();
568708e2 80
f6bcfd97
BP
81 virtual int OnExit() { DeleteBitmaps(); return 0; }
82
568708e2 83protected:
f6bcfd97
BP
84 void DeleteBitmaps();
85
568708e2 86 bool LoadImages();
aba99005
RR
87};
88
b62c3631
RR
89class MyCanvas;
90
aba99005
RR
91// Define a new frame type: this is going to be our main frame
92class MyFrame : public wxFrame
93{
94public:
95 // ctor(s)
96 MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size);
97
98 // event handlers (these functions should _not_ be virtual)
99 void OnQuit(wxCommandEvent& event);
100 void OnAbout(wxCommandEvent& event);
204dd9a7 101 void OnClip(wxCommandEvent& event);
f31a4cb2
SC
102#if wxUSE_GRAPHICS_CONTEXT
103 void OnGraphicContext(wxCommandEvent& event);
104#endif
8c6b0819
VZ
105 void OnCopy(wxCommandEvent& event);
106 void OnSave(wxCommandEvent& event);
568708e2 107 void OnShow(wxCommandEvent &event);
aba99005 108 void OnOption(wxCommandEvent &event);
aba99005 109
960a83cc 110#if wxUSE_COLOURDLG
220af862 111 wxColour SelectColour();
960a83cc 112#endif // wxUSE_COLOURDLG
220af862 113 void PrepareDC(wxDC& dc);
0f0c61d0 114
b62c3631 115 int m_backgroundMode;
1edc9f45 116 int m_textureBackground;
89efaf2b 117 wxMappingMode m_mapMode;
b62c3631
RR
118 double m_xUserScale;
119 double m_yUserScale;
120 int m_xLogicalOrigin;
121 int m_yLogicalOrigin;
122 bool m_xAxisReversed,
123 m_yAxisReversed;
124 wxColour m_colourForeground, // these are _text_ colours
125 m_colourBackground;
126 wxBrush m_backgroundBrush;
127 MyCanvas *m_canvas;
aba99005
RR
128
129private:
be5a51fb 130 // any class wishing to process wxWidgets events must use this macro
aba99005
RR
131 DECLARE_EVENT_TABLE()
132};
133
b62c3631
RR
134// define a scrollable canvas for drawing onto
135class MyCanvas: public wxScrolledWindow
136{
137public:
138 MyCanvas( MyFrame *parent );
1e7fd311 139
b62c3631 140 void OnPaint(wxPaintEvent &event);
bf0c00c6 141 void OnMouseMove(wxMouseEvent &event);
8a021e00
SC
142 void OnMouseDown(wxMouseEvent &event);
143 void OnMouseUp(wxMouseEvent &event);
4786aabd 144
f65e33a3 145 void ToShow(int show) { m_show = show; Refresh(); }
568708e2 146
204dd9a7
VZ
147 // set or remove the clipping region
148 void Clip(bool clip) { m_clip = clip; Refresh(); }
f31a4cb2
SC
149#if wxUSE_GRAPHICS_CONTEXT
150 void UseGraphicContext(bool use) { m_useContext = use; Refresh(); }
151#endif
5707e433 152 void Draw(wxDC& dc);
204dd9a7 153
b62c3631 154protected:
e3b81044
VZ
155 enum DrawMode
156 {
157 Draw_Normal,
158 Draw_Stretch
159 };
160
568708e2 161 void DrawTestLines( int x, int y, int width, wxDC &dc );
6386110d
VZ
162 void DrawTestPoly(wxDC& dc);
163 void DrawTestBrushes(wxDC& dc);
568708e2 164 void DrawText(wxDC& dc);
e3b81044 165 void DrawImages(wxDC& dc, DrawMode mode);
81278df2 166 void DrawWithLogicalOps(wxDC& dc);
f31a4cb2
SC
167#if wxUSE_GRAPHICS_CONTEXT
168 void DrawAlpha(wxDC& dc);
7a5c82b1 169 void DrawGraphics(wxGraphicsContext* gc);
f31a4cb2 170#endif
bc3cedfa 171 void DrawRegions(wxDC& dc);
f6bcfd97 172 void DrawCircles(wxDC& dc);
b11729f1 173 void DrawSplines(wxDC& dc);
568708e2 174 void DrawDefault(wxDC& dc);
213ad8e7 175 void DrawGradients(wxDC& dc);
4786aabd 176
4cbcae16 177 void DrawRegionsHelper(wxDC& dc, wxCoord x, bool firstTime);
8e0e4b1b 178
b62c3631 179private:
568708e2
VZ
180 MyFrame *m_owner;
181
f65e33a3 182 int m_show;
0e09f76e
RR
183 wxBitmap m_smile_bmp;
184 wxIcon m_std_icon;
204dd9a7 185 bool m_clip;
8a021e00
SC
186 wxOverlay m_overlay;
187 bool m_rubberBand;
188 wxPoint m_anchorpoint;
189 wxPoint m_currentpoint;
f31a4cb2
SC
190#if wxUSE_GRAPHICS_CONTEXT
191 bool m_useContext ;
192#endif
568708e2 193
b62c3631
RR
194 DECLARE_EVENT_TABLE()
195};
196
aba99005
RR
197// ----------------------------------------------------------------------------
198// constants
199// ----------------------------------------------------------------------------
200
201// IDs for the controls and the menu commands
202enum
203{
204 // menu items
b11729f1
WS
205 File_Quit = wxID_EXIT,
206 File_About = wxID_ABOUT,
568708e2 207
b11729f1 208 MenuShow_First = wxID_HIGHEST,
568708e2
VZ
209 File_ShowDefault = MenuShow_First,
210 File_ShowText,
211 File_ShowLines,
6386110d 212 File_ShowBrushes,
568708e2
VZ
213 File_ShowPolygons,
214 File_ShowMask,
e3b81044 215 File_ShowMaskStretch,
81278df2 216 File_ShowOps,
bc3cedfa 217 File_ShowRegions,
f6bcfd97 218 File_ShowCircles,
b11729f1 219 File_ShowSplines,
f31a4cb2
SC
220#if wxUSE_GRAPHICS_CONTEXT
221 File_ShowAlpha,
7a5c82b1 222 File_ShowGraphics,
f31a4cb2 223#endif
213ad8e7
VZ
224 File_ShowGradients,
225 MenuShow_Last = File_ShowGradients,
0f0c61d0 226
204dd9a7 227 File_Clip,
f31a4cb2
SC
228#if wxUSE_GRAPHICS_CONTEXT
229 File_GraphicContext,
230#endif
8c6b0819
VZ
231 File_Copy,
232 File_Save,
204dd9a7 233
0f0c61d0
VZ
234 MenuOption_First,
235
236 MapMode_Text = MenuOption_First,
aba99005
RR
237 MapMode_Lometric,
238 MapMode_Twips,
239 MapMode_Points,
240 MapMode_Metric,
0f0c61d0 241
aba99005
RR
242 UserScale_StretchHoriz,
243 UserScale_ShrinkHoriz,
244 UserScale_StretchVertic,
245 UserScale_ShrinkVertic,
0f0c61d0
VZ
246 UserScale_Restore,
247
aba99005
RR
248 AxisMirror_Horiz,
249 AxisMirror_Vertic,
0f0c61d0 250
aba99005
RR
251 LogicalOrigin_MoveDown,
252 LogicalOrigin_MoveUp,
253 LogicalOrigin_MoveLeft,
254 LogicalOrigin_MoveRight,
fb576291
VZ
255 LogicalOrigin_Set,
256 LogicalOrigin_Restore,
0f0c61d0 257
960a83cc 258#if wxUSE_COLOURDLG
0f0c61d0
VZ
259 Colour_TextForeground,
260 Colour_TextBackground,
261 Colour_Background,
960a83cc 262#endif // wxUSE_COLOURDLG
0f0c61d0 263 Colour_BackgroundMode,
1edc9f45 264 Colour_TextureBackgound,
0f0c61d0 265
1edc9f45 266 MenuOption_Last = Colour_TextureBackgound
aba99005
RR
267};
268
269// ----------------------------------------------------------------------------
be5a51fb 270// event tables and other macros for wxWidgets
aba99005
RR
271// ----------------------------------------------------------------------------
272
aba99005 273
be5a51fb 274// Create a new application object: this macro will allow wxWidgets to create
aba99005
RR
275// the application object during program execution (it's better than using a
276// static object for many reasons) and also declares the accessor function
277// wxGetApp() which will return the reference of the right type (i.e. MyApp and
278// not wxApp)
279IMPLEMENT_APP(MyApp)
280
281// ============================================================================
282// implementation
283// ============================================================================
284
285// ----------------------------------------------------------------------------
286// the application class
287// ----------------------------------------------------------------------------
288
568708e2
VZ
289bool MyApp::LoadImages()
290{
f6bcfd97
BP
291 gs_bmpNoMask = new wxBitmap;
292 gs_bmpWithColMask = new wxBitmap;
293 gs_bmpMask = new wxBitmap;
294 gs_bmpWithMask = new wxBitmap;
295 gs_bmp4 = new wxBitmap;
296 gs_bmp4_mono = new wxBitmap;
297 gs_bmp36 = new wxBitmap;
298
568708e2 299 wxPathList pathList;
e0ac7d94
VZ
300 // special hack for Unix in-tree sample build, don't do this in real
301 // programs, use wxStandardPaths instead
302 pathList.Add(wxFileName(argv[0]).GetPath());
9a83f860
VZ
303 pathList.Add(wxT("."));
304 pathList.Add(wxT(".."));
305 pathList.Add(wxT("../.."));
568708e2 306
9a83f860 307 wxString path = pathList.FindValidPath(wxT("pat4.bmp"));
568708e2 308 if ( !path )
9da8feef 309 return false;
f6bcfd97 310
e1208c31 311 /* 4 colour bitmap */
f6bcfd97 312 gs_bmp4->LoadFile(path, wxBITMAP_TYPE_BMP);
e1208c31 313 /* turn into mono-bitmap */
f6bcfd97
BP
314 gs_bmp4_mono->LoadFile(path, wxBITMAP_TYPE_BMP);
315 wxMask* mask4 = new wxMask(*gs_bmp4_mono, *wxBLACK);
316 gs_bmp4_mono->SetMask(mask4);
568708e2 317
9a83f860 318 path = pathList.FindValidPath(wxT("pat36.bmp"));
568708e2 319 if ( !path )
9da8feef 320 return false;
f6bcfd97
BP
321 gs_bmp36->LoadFile(path, wxBITMAP_TYPE_BMP);
322 wxMask* mask36 = new wxMask(*gs_bmp36, *wxBLACK);
323 gs_bmp36->SetMask(mask36);
568708e2 324
9a83f860 325 path = pathList.FindValidPath(wxT("image.bmp"));
568708e2 326 if ( !path )
9da8feef 327 return false;
f6bcfd97
BP
328 gs_bmpNoMask->LoadFile(path, wxBITMAP_TYPE_BMP);
329 gs_bmpWithMask->LoadFile(path, wxBITMAP_TYPE_BMP);
330 gs_bmpWithColMask->LoadFile(path, wxBITMAP_TYPE_BMP);
568708e2 331
9a83f860 332 path = pathList.FindValidPath(wxT("mask.bmp"));
568708e2 333 if ( !path )
9da8feef 334 return false;
f6bcfd97 335 gs_bmpMask->LoadFile(path, wxBITMAP_TYPE_BMP);
b9de1315 336
f6bcfd97
BP
337 wxMask *mask = new wxMask(*gs_bmpMask, *wxBLACK);
338 gs_bmpWithMask->SetMask(mask);
568708e2 339
f6bcfd97
BP
340 mask = new wxMask(*gs_bmpWithColMask, *wxWHITE);
341 gs_bmpWithColMask->SetMask(mask);
568708e2 342
9da8feef 343 return true;
568708e2
VZ
344}
345
aba99005
RR
346// `Main program' equivalent: the program execution "starts" here
347bool MyApp::OnInit()
348{
45e6e6f8
VZ
349 if ( !wxApp::OnInit() )
350 return false;
351
aba99005 352 // Create the main application window
9a83f860 353 MyFrame *frame = new MyFrame(wxT("Drawing sample"),
5db56cd2 354 wxDefaultPosition, wxSize(550, 840));
aba99005 355
18f42b94 356 // Show it
9da8feef 357 frame->Show(true);
aba99005 358
568708e2
VZ
359 if ( !LoadImages() )
360 {
4693b20c
MB
361 wxLogError(wxT("Can't load one of the bitmap files needed ")
362 wxT("for this sample from the current or parent ")
363 wxT("directory, please copy them there."));
568708e2 364
e0ac7d94
VZ
365 // still continue, the sample can be used without images too if they're
366 // missing for whatever reason
568708e2 367 }
8c6b0819
VZ
368#if wxUSE_LIBPNG
369 wxImage::AddHandler( new wxPNGHandler );
370#endif
568708e2 371
9da8feef 372 return true;
aba99005
RR
373}
374
f6bcfd97
BP
375void MyApp::DeleteBitmaps()
376{
5276b0a5
VZ
377 wxDELETE(gs_bmpNoMask);
378 wxDELETE(gs_bmpWithColMask);
379 wxDELETE(gs_bmpMask);
380 wxDELETE(gs_bmpWithMask);
381 wxDELETE(gs_bmp4);
382 wxDELETE(gs_bmp4_mono);
383 wxDELETE(gs_bmp36);
f6bcfd97
BP
384}
385
aba99005 386// ----------------------------------------------------------------------------
b62c3631 387// MyCanvas
aba99005
RR
388// ----------------------------------------------------------------------------
389
be5a51fb 390// the event tables connect the wxWidgets events with the functions (event
b62c3631
RR
391// handlers) which process them.
392BEGIN_EVENT_TABLE(MyCanvas, wxScrolledWindow)
393 EVT_PAINT (MyCanvas::OnPaint)
bf0c00c6 394 EVT_MOTION (MyCanvas::OnMouseMove)
8a021e00
SC
395 EVT_LEFT_DOWN (MyCanvas::OnMouseDown)
396 EVT_LEFT_UP (MyCanvas::OnMouseUp)
b62c3631
RR
397END_EVENT_TABLE()
398
c4218a74 399#include "smile.xpm"
0e09f76e 400
c4218a74 401MyCanvas::MyCanvas(MyFrame *parent)
9da8feef 402 : wxScrolledWindow(parent, wxID_ANY, wxDefaultPosition, wxDefaultSize,
c4218a74 403 wxHSCROLL | wxVSCROLL | wxNO_FULL_REPAINT_ON_RESIZE)
b62c3631 404{
b97fa7cf 405 m_owner = parent;
f65e33a3 406 m_show = File_ShowDefault;
0e09f76e 407 m_smile_bmp = wxBitmap(smile_xpm);
389d906b 408 m_std_icon = wxArtProvider::GetIcon(wxART_INFORMATION);
9da8feef 409 m_clip = false;
8a021e00 410 m_rubberBand = false;
f31a4cb2
SC
411#if wxUSE_GRAPHICS_CONTEXT
412 m_useContext = false;
413#endif
b97fa7cf
VZ
414}
415
6386110d 416void MyCanvas::DrawTestBrushes(wxDC& dc)
b97fa7cf 417{
6386110d
VZ
418 static const wxCoord WIDTH = 200;
419 static const wxCoord HEIGHT = 80;
420
421 wxCoord x = 10,
422 y = 10;
423
424 dc.SetBrush(wxBrush(*wxGREEN, wxSOLID));
425 dc.DrawRectangle(x, y, WIDTH, HEIGHT);
9a83f860 426 dc.DrawText(wxT("Solid green"), x + 10, y + 10);
6386110d
VZ
427
428 y += HEIGHT;
429 dc.SetBrush(wxBrush(*wxRED, wxCROSSDIAG_HATCH));
430 dc.DrawRectangle(x, y, WIDTH, HEIGHT);
1910265f
VZ
431 dc.DrawText(wxT("Diagonally hatched red"), x + 10, y + 10);
432
433 y += HEIGHT;
434 dc.SetBrush(wxBrush(*wxBLUE, wxCROSS_HATCH));
435 dc.DrawRectangle(x, y, WIDTH, HEIGHT);
436 dc.DrawText(wxT("Cross hatched blue"), x + 10, y + 10);
437
438 y += HEIGHT;
439 dc.SetBrush(wxBrush(*wxCYAN, wxVERTICAL_HATCH));
440 dc.DrawRectangle(x, y, WIDTH, HEIGHT);
441 dc.DrawText(wxT("Vertically hatched cyan"), x + 10, y + 10);
442
443 y += HEIGHT;
444 dc.SetBrush(wxBrush(*wxBLACK, wxHORIZONTAL_HATCH));
445 dc.DrawRectangle(x, y, WIDTH, HEIGHT);
446 dc.DrawText(wxT("Horizontally hatched black"), x + 10, y + 10);
6386110d
VZ
447
448 y += HEIGHT;
449 dc.SetBrush(wxBrush(*gs_bmpMask));
450 dc.DrawRectangle(x, y, WIDTH, HEIGHT);
9a83f860 451 dc.DrawText(wxT("Stipple mono"), x + 10, y + 10);
6386110d
VZ
452
453 y += HEIGHT;
454 dc.SetBrush(wxBrush(*gs_bmpNoMask));
455 dc.DrawRectangle(x, y, WIDTH, HEIGHT);
9a83f860 456 dc.DrawText(wxT("Stipple colour"), x + 10, y + 10);
6386110d 457}
b97fa7cf 458
6386110d
VZ
459void MyCanvas::DrawTestPoly(wxDC& dc)
460{
461 wxBrush brushHatch(*wxRED, wxFDIAGONAL_HATCH);
462 dc.SetBrush(brushHatch);
463
464 wxPoint star[5];
465 star[0] = wxPoint(100, 60);
466 star[1] = wxPoint(60, 150);
467 star[2] = wxPoint(160, 100);
468 star[3] = wxPoint(40, 100);
469 star[4] = wxPoint(140, 150);
470
9a83f860
VZ
471 dc.DrawText(wxT("You should see two (irregular) stars below, the left one ")
472 wxT("hatched"), 10, 10);
473 dc.DrawText(wxT("except for the central region and the right ")
474 wxT("one entirely hatched"), 10, 30);
475 dc.DrawText(wxT("The third star only has a hatched outline"), 10, 50);
163dc80e
VZ
476
477 dc.DrawPolygon(WXSIZEOF(star), star, 0, 30);
478 dc.DrawPolygon(WXSIZEOF(star), star, 160, 30, wxWINDING_RULE);
479
480 wxPoint star2[10];
481 star2[0] = wxPoint(0, 100);
482 star2[1] = wxPoint(-59, -81);
483 star2[2] = wxPoint(95, 31);
484 star2[3] = wxPoint(-95, 31);
485 star2[4] = wxPoint(59, -81);
486 star2[5] = wxPoint(0, 80);
487 star2[6] = wxPoint(-47, -64);
488 star2[7] = wxPoint(76, 24);
489 star2[8] = wxPoint(-76, 24);
490 star2[9] = wxPoint(47, -64);
491 int count[2] = {5, 5};
492
493 dc.DrawPolyPolygon(WXSIZEOF(count), count, star2, 450, 150);
b62c3631
RR
494}
495
1e7fd311 496void MyCanvas::DrawTestLines( int x, int y, int width, wxDC &dc )
b62c3631 497{
a60b1f5d 498 dc.SetPen( wxPen( wxT("black"), width, wxSOLID) );
1e7fd311 499 dc.SetBrush( *wxRED_BRUSH );
4693b20c 500 dc.DrawText(wxString::Format(wxT("Testing lines of width %d"), width), x + 10, y - 10);
9a8c7620 501 dc.DrawRectangle( x+10, y+10, 100, 190 );
4786aabd 502
9a83f860 503 dc.DrawText(wxT("Solid/dot/short dash/long dash/dot dash"), x + 150, y + 10);
a60b1f5d 504 dc.SetPen( wxPen( wxT("black"), width, wxSOLID) );
696e1ea0 505 dc.DrawLine( x+20, y+20, 100, y+20 );
a60b1f5d 506 dc.SetPen( wxPen( wxT("black"), width, wxDOT) );
696e1ea0 507 dc.DrawLine( x+20, y+30, 100, y+30 );
a60b1f5d 508 dc.SetPen( wxPen( wxT("black"), width, wxSHORT_DASH) );
696e1ea0 509 dc.DrawLine( x+20, y+40, 100, y+40 );
a60b1f5d 510 dc.SetPen( wxPen( wxT("black"), width, wxLONG_DASH) );
696e1ea0 511 dc.DrawLine( x+20, y+50, 100, y+50 );
a60b1f5d 512 dc.SetPen( wxPen( wxT("black"), width, wxDOT_DASH) );
696e1ea0 513 dc.DrawLine( x+20, y+60, 100, y+60 );
1e7fd311 514
9a83f860 515 dc.DrawText(wxT("Misc hatches"), x + 150, y + 70);
a60b1f5d 516 dc.SetPen( wxPen( wxT("black"), width, wxBDIAGONAL_HATCH) );
696e1ea0 517 dc.DrawLine( x+20, y+70, 100, y+70 );
a60b1f5d 518 dc.SetPen( wxPen( wxT("black"), width, wxCROSSDIAG_HATCH) );
696e1ea0 519 dc.DrawLine( x+20, y+80, 100, y+80 );
a60b1f5d 520 dc.SetPen( wxPen( wxT("black"), width, wxFDIAGONAL_HATCH) );
696e1ea0 521 dc.DrawLine( x+20, y+90, 100, y+90 );
a60b1f5d 522 dc.SetPen( wxPen( wxT("black"), width, wxCROSS_HATCH) );
696e1ea0 523 dc.DrawLine( x+20, y+100, 100, y+100 );
a60b1f5d 524 dc.SetPen( wxPen( wxT("black"), width, wxHORIZONTAL_HATCH) );
696e1ea0 525 dc.DrawLine( x+20, y+110, 100, y+110 );
a60b1f5d 526 dc.SetPen( wxPen( wxT("black"), width, wxVERTICAL_HATCH) );
696e1ea0 527 dc.DrawLine( x+20, y+120, 100, y+120 );
1e7fd311 528
9a83f860 529 dc.DrawText(wxT("User dash"), x + 150, y + 140);
a60b1f5d 530 wxPen ud( wxT("black"), width, wxUSER_DASH );
e2a5251d
VZ
531 wxDash dash1[6];
532 dash1[0] = 8; // Long dash <---------+
533 dash1[1] = 2; // Short gap |
534 dash1[2] = 3; // Short dash |
535 dash1[3] = 2; // Short gap |
536 dash1[4] = 3; // Short dash |
537 dash1[5] = 2; // Short gap and repeat +
538 ud.SetDashes( 6, dash1 );
539 dc.SetPen( ud );
696e1ea0 540 dc.DrawLine( x+20, y+140, 100, y+140 );
e2a5251d
VZ
541 dash1[0] = 5; // Make first dash shorter
542 ud.SetDashes( 6, dash1 );
543 dc.SetPen( ud );
696e1ea0 544 dc.DrawLine( x+20, y+150, 100, y+150 );
e2a5251d
VZ
545 dash1[2] = 5; // Make second dash longer
546 ud.SetDashes( 6, dash1 );
547 dc.SetPen( ud );
696e1ea0 548 dc.DrawLine( x+20, y+160, 100, y+160 );
e2a5251d
VZ
549 dash1[4] = 5; // Make third dash longer
550 ud.SetDashes( 6, dash1 );
551 dc.SetPen( ud );
696e1ea0 552 dc.DrawLine( x+20, y+170, 100, y+170 );
b62c3631
RR
553}
554
568708e2 555void MyCanvas::DrawDefault(wxDC& dc)
b62c3631 556{
b62c3631
RR
557 // mark the origin
558 dc.DrawCircle(0, 0, 10);
f88c1a17 559
e95c145c 560#if !defined(wxMAC_USE_CORE_GRAPHICS) || !wxMAC_USE_CORE_GRAPHICS
f1e5c798
JS
561 // GetPixel and FloodFill not supported by Mac OS X CoreGraphics
562 // (FloodFill uses Blit from a non-wxMemoryDC)
f88c1a17
JS
563 //flood fill using brush, starting at 1,1 and replacing whatever colour we find there
564 dc.SetBrush(wxBrush(wxColour(128,128,0), wxSOLID));
f1e5c798 565
f88c1a17
JS
566 wxColour tmpColour ;
567 dc.GetPixel(1,1, &tmpColour);
568 dc.FloodFill(1,1, tmpColour, wxFLOOD_SURFACE);
f1e5c798 569#endif
11fdee42 570
cd9da200
VZ
571 dc.DrawCheckMark(5, 80, 15, 15);
572 dc.DrawCheckMark(25, 80, 30, 30);
573 dc.DrawCheckMark(60, 80, 60, 60);
574
0e09f76e 575 // this is the test for "blitting bitmap into DC damages selected brush" bug
0e09f76e 576 wxCoord rectSize = m_std_icon.GetWidth() + 10;
cd9da200 577 wxCoord x = 100;
11f26ea0
VZ
578 dc.SetPen(*wxTRANSPARENT_PEN);
579 dc.SetBrush( *wxGREEN_BRUSH );
cd9da200 580 dc.DrawRectangle(x, 10, rectSize, rectSize);
9da8feef 581 dc.DrawBitmap(m_std_icon, x + 5, 15, true);
cd9da200
VZ
582 x += rectSize + 10;
583 dc.DrawRectangle(x, 10, rectSize, rectSize);
0e09f76e 584 dc.DrawIcon(m_std_icon, x + 5, 15);
cd9da200
VZ
585 x += rectSize + 10;
586 dc.DrawRectangle(x, 10, rectSize, rectSize);
11f26ea0
VZ
587
588 // test for "transparent" bitmap drawing (it intersects with the last
589 // rectangle above)
590 //dc.SetBrush( *wxTRANSPARENT_BRUSH );
d6f0a4b3 591
a1b806b9 592 if (m_smile_bmp.IsOk())
9da8feef 593 dc.DrawBitmap(m_smile_bmp, x + rectSize - 20, rectSize - 10, true);
107a1787 594
ff7c6c9c 595 dc.SetBrush( *wxBLACK_BRUSH );
107a1787
RR
596 dc.DrawRectangle( 0, 160, 1000, 300 );
597
598 // draw lines
599 wxBitmap bitmap(20,70);
600 wxMemoryDC memdc;
601 memdc.SelectObject( bitmap );
602 memdc.SetBrush( *wxBLACK_BRUSH );
603 memdc.SetPen( *wxWHITE_PEN );
604 memdc.DrawRectangle(0,0,20,70);
605 memdc.DrawLine( 10,0,10,70 );
81278df2 606
d4aa3a4b 607 // to the right
4c45f240 608 wxPen pen = *wxRED_PEN;
4c45f240 609 memdc.SetPen(pen);
107a1787
RR
610 memdc.DrawLine( 10, 5,10, 5 );
611 memdc.DrawLine( 10,10,11,10 );
612 memdc.DrawLine( 10,15,12,15 );
613 memdc.DrawLine( 10,20,13,20 );
81278df2 614
d4aa3a4b
RR
615/*
616 memdc.SetPen(*wxRED_PEN);
107a1787
RR
617 memdc.DrawLine( 12, 5,12, 5 );
618 memdc.DrawLine( 12,10,13,10 );
619 memdc.DrawLine( 12,15,14,15 );
620 memdc.DrawLine( 12,20,15,20 );
d4aa3a4b 621*/
81278df2 622
107a1787
RR
623 // same to the left
624 memdc.DrawLine( 10,25,10,25 );
625 memdc.DrawLine( 10,30, 9,30 );
626 memdc.DrawLine( 10,35, 8,35 );
627 memdc.DrawLine( 10,40, 7,40 );
628
629 // XOR draw lines
d4aa3a4b 630 dc.SetPen(*wxWHITE_PEN);
107a1787
RR
631 memdc.SetLogicalFunction( wxINVERT );
632 memdc.SetPen( *wxWHITE_PEN );
633 memdc.DrawLine( 10,50,10,50 );
634 memdc.DrawLine( 10,55,11,55 );
635 memdc.DrawLine( 10,60,12,60 );
636 memdc.DrawLine( 10,65,13,65 );
81278df2 637
107a1787
RR
638 memdc.DrawLine( 12,50,12,50 );
639 memdc.DrawLine( 12,55,13,55 );
640 memdc.DrawLine( 12,60,14,60 );
641 memdc.DrawLine( 12,65,15,65 );
81278df2 642
107a1787
RR
643 memdc.SelectObject( wxNullBitmap );
644 dc.DrawBitmap( bitmap, 10, 170 );
389d906b 645 wxImage image = bitmap.ConvertToImage();
107a1787 646 image.Rescale( 60,210 );
389d906b 647 bitmap = wxBitmap(image);
107a1787 648 dc.DrawBitmap( bitmap, 50, 170 );
81278df2 649
b9de1315 650 // test the rectangle outline drawing - there should be one pixel between
ff7c6c9c
RR
651 // the rect and the lines
652 dc.SetPen(*wxWHITE_PEN);
653 dc.SetBrush( *wxTRANSPARENT_BRUSH );
ff7c6c9c 654 dc.DrawRectangle(150, 170, 49, 29);
107a1787 655 dc.DrawRectangle(200, 170, 49, 29);
ff7c6c9c 656 dc.SetPen(*wxWHITE_PEN);
107a1787
RR
657 dc.DrawLine(250, 210, 250, 170);
658 dc.DrawLine(260, 200, 150, 200);
b9de1315
VZ
659
660 // test the rectangle filled drawing - there should be one pixel between
ff7c6c9c
RR
661 // the rect and the lines
662 dc.SetPen(*wxTRANSPARENT_PEN);
663 dc.SetBrush( *wxWHITE_BRUSH );
664 dc.DrawRectangle(300, 170, 49, 29);
568708e2 665 dc.DrawRectangle(350, 170, 49, 29);
ff7c6c9c 666 dc.SetPen(*wxWHITE_PEN);
b9de1315
VZ
667 dc.DrawLine(400, 170, 400, 210);
668 dc.DrawLine(300, 200, 410, 200);
669
3d2d8da1
RR
670 // a few more tests of this kind
671 dc.SetPen(*wxRED_PEN);
672 dc.SetBrush( *wxWHITE_BRUSH );
673 dc.DrawRectangle(300, 220, 1, 1);
674 dc.DrawRectangle(310, 220, 2, 2);
675 dc.DrawRectangle(320, 220, 3, 3);
676 dc.DrawRectangle(330, 220, 4, 4);
677
678 dc.SetPen(*wxTRANSPARENT_PEN);
679 dc.SetBrush( *wxWHITE_BRUSH );
680 dc.DrawRectangle(300, 230, 1, 1);
681 dc.DrawRectangle(310, 230, 2, 2);
682 dc.DrawRectangle(320, 230, 3, 3);
683 dc.DrawRectangle(330, 230, 4, 4);
684
b9de1315
VZ
685 // and now for filled rect with outline
686 dc.SetPen(*wxRED_PEN);
687 dc.SetBrush( *wxWHITE_BRUSH );
688 dc.DrawRectangle(500, 170, 49, 29);
689 dc.DrawRectangle(550, 170, 49, 29);
690 dc.SetPen(*wxWHITE_PEN);
691 dc.DrawLine(600, 170, 600, 210);
692 dc.DrawLine(500, 200, 610, 200);
693
694 // test the rectangle outline drawing - there should be one pixel between
ff7c6c9c
RR
695 // the rect and the lines
696 dc.SetPen(*wxWHITE_PEN);
697 dc.SetBrush( *wxTRANSPARENT_BRUSH );
ff7c6c9c 698 dc.DrawRoundedRectangle(150, 270, 49, 29, 6);
107a1787 699 dc.DrawRoundedRectangle(200, 270, 49, 29, 6);
ff7c6c9c 700 dc.SetPen(*wxWHITE_PEN);
107a1787
RR
701 dc.DrawLine(250, 270, 250, 310);
702 dc.DrawLine(150, 300, 260, 300);
b9de1315
VZ
703
704 // test the rectangle filled drawing - there should be one pixel between
ff7c6c9c
RR
705 // the rect and the lines
706 dc.SetPen(*wxTRANSPARENT_PEN);
707 dc.SetBrush( *wxWHITE_BRUSH );
708 dc.DrawRoundedRectangle(300, 270, 49, 29, 6);
709 dc.DrawRoundedRectangle(350, 270, 49, 29, 6);
710 dc.SetPen(*wxWHITE_PEN);
b9de1315
VZ
711 dc.DrawLine(400, 270, 400, 310);
712 dc.DrawLine(300, 300, 410, 300);
ff7c6c9c 713
b14c14ff
JS
714 // Added by JACS to demonstrate bizarre behaviour.
715 // With a size of 70, we get a missing red RHS,
3103e8a9 716 // and the height is too small, so we get yellow
b14c14ff
JS
717 // showing. With a size of 40, it draws as expected:
718 // it just shows a white rectangle with red outline.
719 int totalWidth = 70;
720 int totalHeight = 70;
721 wxBitmap bitmap2(totalWidth, totalHeight);
722
723 wxMemoryDC memdc2;
724 memdc2.SelectObject(bitmap2);
725
925e9792
WS
726 wxColour clr(255, 255, 0);
727 wxBrush yellowBrush(clr, wxSOLID);
d6f0a4b3
JS
728 memdc2.SetBackground(yellowBrush);
729 memdc2.Clear();
b14c14ff 730
925e9792 731 wxPen yellowPen(clr, 1, wxSOLID);
b14c14ff
JS
732
733 // Now draw a white rectangle with red outline. It should
734 // entirely eclipse the yellow background.
735 memdc2.SetPen(*wxRED_PEN);
736 memdc2.SetBrush(*wxWHITE_BRUSH);
737
738 memdc2.DrawRectangle(0, 0, totalWidth, totalHeight);
739
b14c14ff
JS
740 memdc2.SetPen(wxNullPen);
741 memdc2.SetBrush(wxNullBrush);
cd9da200 742 memdc2.SelectObject(wxNullBitmap);
b14c14ff
JS
743
744 dc.DrawBitmap(bitmap2, 500, 270);
d6f0a4b3
JS
745
746 // Repeat, but draw directly on dc
747 // Draw a yellow rectangle filling the bitmap
748
749 x = 600; int y = 270;
750 dc.SetPen(yellowPen);
751 dc.SetBrush(yellowBrush);
752 dc.DrawRectangle(x, y, totalWidth, totalHeight);
753
754 // Now draw a white rectangle with red outline. It should
755 // entirely eclipse the yellow background.
756 dc.SetPen(*wxRED_PEN);
757 dc.SetBrush(*wxWHITE_BRUSH);
758
759 dc.DrawRectangle(x, y, totalWidth, totalHeight);
568708e2
VZ
760}
761
762void MyCanvas::DrawText(wxDC& dc)
763{
9a8c7620 764 // set underlined font for testing
9da8feef 765 dc.SetFont( wxFont(12, wxMODERN, wxNORMAL, wxNORMAL, true) );
9a83f860
VZ
766 dc.DrawText( wxT("This is text"), 110, 10 );
767 dc.DrawRotatedText( wxT("That is text"), 20, 10, -45 );
9a8c7620 768
4770df95
VZ
769 // use wxSWISS_FONT and not wxNORMAL_FONT as the latter can't be rotated
770 // under Win9x (it is not TrueType)
771 dc.SetFont( *wxSWISS_FONT );
b62c3631 772
696e1ea0 773 wxString text;
f6bcfd97 774 dc.SetBackgroundMode(wxTRANSPARENT);
696e1ea0
VZ
775
776 for ( int n = -180; n < 180; n += 30 )
777 {
4693b20c 778 text.Printf(wxT(" %d rotated text"), n);
696e1ea0
VZ
779 dc.DrawRotatedText(text , 400, 400, n);
780 }
95724b1a 781
196c87f4 782 dc.SetFont( wxFont( 18, wxSWISS, wxNORMAL, wxNORMAL ) );
c45a644e 783
9a83f860 784 dc.DrawText( wxT("This is Swiss 18pt text."), 110, 40 );
c45a644e 785
6f207e66
VS
786 wxCoord length;
787 wxCoord height;
788 wxCoord descent;
9a83f860 789 dc.GetTextExtent( wxT("This is Swiss 18pt text."), &length, &height, &descent );
e22fa4d7 790 text.Printf( wxT("Dimensions are length %d, height %d, descent %d"), length, height, descent );
c45a644e
RR
791 dc.DrawText( text, 110, 80 );
792
4693b20c 793 text.Printf( wxT("CharHeight() returns: %d"), dc.GetCharHeight() );
c45a644e
RR
794 dc.DrawText( text, 110, 120 );
795
568708e2 796 dc.DrawRectangle( 100, 40, 4, height );
f6bcfd97
BP
797
798 // test the logical function effect
799 wxCoord y = 150;
800 dc.SetLogicalFunction(wxINVERT);
e928566f 801 // text drawing should ignore logical function
9a83f860 802 dc.DrawText( wxT("There should be a text below"), 110, 150 );
f6bcfd97
BP
803 dc.DrawRectangle( 110, y, 100, height );
804
f6bcfd97 805 y += height;
9a83f860 806 dc.DrawText( wxT("Visible text"), 110, y );
f6bcfd97 807 dc.DrawRectangle( 110, y, 100, height );
9a83f860 808 dc.DrawText( wxT("Visible text"), 110, y );
f6bcfd97
BP
809 dc.DrawRectangle( 110, y, 100, height );
810 dc.SetLogicalFunction(wxCOPY);
811
812 y += height;
813 dc.DrawRectangle( 110, y, 100, height );
9a83f860 814 dc.DrawText( wxT("Another visible text"), 110, y );
a5bb4514
VZ
815
816 y += height;
817 dc.DrawText("And\nmore\ntext on\nmultiple\nlines", 110, y);
568708e2
VZ
818}
819
81278df2 820static const struct
568708e2 821{
81278df2 822 const wxChar *name;
89efaf2b 823 wxRasterOperationMode rop;
81278df2
VZ
824} rasterOperations[] =
825{
4693b20c
MB
826 { wxT("wxAND"), wxAND },
827 { wxT("wxAND_INVERT"), wxAND_INVERT },
828 { wxT("wxAND_REVERSE"), wxAND_REVERSE },
829 { wxT("wxCLEAR"), wxCLEAR },
830 { wxT("wxCOPY"), wxCOPY },
831 { wxT("wxEQUIV"), wxEQUIV },
832 { wxT("wxINVERT"), wxINVERT },
833 { wxT("wxNAND"), wxNAND },
834 { wxT("wxNO_OP"), wxNO_OP },
835 { wxT("wxOR"), wxOR },
836 { wxT("wxOR_INVERT"), wxOR_INVERT },
837 { wxT("wxOR_REVERSE"), wxOR_REVERSE },
838 { wxT("wxSET"), wxSET },
839 { wxT("wxSRC_INVERT"), wxSRC_INVERT },
840 { wxT("wxXOR"), wxXOR },
81278df2 841};
568708e2 842
e3b81044 843void MyCanvas::DrawImages(wxDC& dc, DrawMode mode)
81278df2 844{
9a83f860 845 dc.DrawText(wxT("original image"), 0, 0);
f6bcfd97 846 dc.DrawBitmap(*gs_bmpNoMask, 0, 20, 0);
9a83f860 847 dc.DrawText(wxT("with colour mask"), 0, 100);
9da8feef 848 dc.DrawBitmap(*gs_bmpWithColMask, 0, 120, true);
9a83f860 849 dc.DrawText(wxT("the mask image"), 0, 200);
f6bcfd97 850 dc.DrawBitmap(*gs_bmpMask, 0, 220, 0);
9a83f860 851 dc.DrawText(wxT("masked image"), 0, 300);
9da8feef 852 dc.DrawBitmap(*gs_bmpWithMask, 0, 320, true);
568708e2 853
f6bcfd97
BP
854 int cx = gs_bmpWithColMask->GetWidth(),
855 cy = gs_bmpWithColMask->GetHeight();
568708e2
VZ
856
857 wxMemoryDC memDC;
858 for ( size_t n = 0; n < WXSIZEOF(rasterOperations); n++ )
859 {
860 wxCoord x = 120 + 150*(n%4),
861 y = 20 + 100*(n/4);
4786aabd 862
568708e2 863 dc.DrawText(rasterOperations[n].name, x, y - 20);
f6bcfd97 864 memDC.SelectObject(*gs_bmpWithColMask);
e3b81044
VZ
865 if ( mode == Draw_Stretch )
866 {
867 dc.StretchBlit(x, y, cx, cy, &memDC, 0, 0, cx/2, cy/2,
868 rasterOperations[n].rop, true);
869 }
870 else
871 {
872 dc.Blit(x, y, cx, cy, &memDC, 0, 0, rasterOperations[n].rop, true);
873 }
568708e2
VZ
874 }
875}
876
81278df2
VZ
877void MyCanvas::DrawWithLogicalOps(wxDC& dc)
878{
879 static const wxCoord w = 60;
880 static const wxCoord h = 60;
881
882 // reuse the text colour here
883 dc.SetPen(wxPen(m_owner->m_colourForeground, 1, wxSOLID));
11f26ea0 884 dc.SetBrush(*wxTRANSPARENT_BRUSH);
81278df2 885
5888ef1e
VZ
886 size_t n;
887 for ( n = 0; n < WXSIZEOF(rasterOperations); n++ )
81278df2
VZ
888 {
889 wxCoord x = 20 + 150*(n%4),
890 y = 20 + 100*(n/4);
891
892 dc.DrawText(rasterOperations[n].name, x, y - 20);
893 dc.SetLogicalFunction(rasterOperations[n].rop);
11f26ea0 894 dc.DrawRectangle(x, y, w, h);
81278df2
VZ
895 dc.DrawLine(x, y, x + w, y + h);
896 dc.DrawLine(x + w, y, x, y + h);
897 }
c1d139da
GRG
898
899 // now some filled rectangles
900 dc.SetBrush(wxBrush(m_owner->m_colourForeground, wxSOLID));
901
5888ef1e 902 for ( n = 0; n < WXSIZEOF(rasterOperations); n++ )
c1d139da
GRG
903 {
904 wxCoord x = 20 + 150*(n%4),
905 y = 500 + 100*(n/4);
906
907 dc.DrawText(rasterOperations[n].name, x, y - 20);
908 dc.SetLogicalFunction(rasterOperations[n].rop);
909 dc.DrawRectangle(x, y, w, h);
910 }
81278df2
VZ
911}
912
f31a4cb2 913#if wxUSE_GRAPHICS_CONTEXT
ad0b4329 914#ifdef __WXGTK20__
84e0e526 915void MyCanvas::DrawAlpha(wxDC& WXUNUSED(dummyDC))
ad0b4329 916#else
f31a4cb2 917void MyCanvas::DrawAlpha(wxDC& dc)
ad0b4329 918#endif
f31a4cb2 919{
ad0b4329
RR
920#ifdef __WXGTK__
921 wxGCDC dc( this );
922 PrepareDC( dc );
923#endif
924
f31a4cb2
SC
925 wxDouble margin = 20 ;
926 wxDouble width = 180 ;
927 wxDouble radius = 30 ;
e3b81044 928
f31a4cb2
SC
929 dc.SetPen( wxPen( wxColour( 128, 0, 0, 255 ),12, wxSOLID));
930 dc.SetBrush( wxBrush( wxColour( 255, 0, 0, 255),wxSOLID));
e3b81044 931
f31a4cb2 932 wxRect r(margin,margin+width*0.66,width,width) ;
e3b81044 933
f31a4cb2 934 dc.DrawRoundedRectangle( r.x, r.y, r.width, r.width, radius ) ;
e3b81044 935
f31a4cb2
SC
936 dc.SetPen( wxPen( wxColour( 0, 0, 128, 255 ),12, wxSOLID));
937 dc.SetBrush( wxBrush( wxColour( 0, 0, 255, 255),wxSOLID));
e3b81044 938
f31a4cb2 939 r.Offset( width * 0.8 , - width * 0.66 ) ;
e3b81044 940
f31a4cb2 941 dc.DrawRoundedRectangle( r.x, r.y, r.width, r.width, radius ) ;
e3b81044 942
f31a4cb2
SC
943 dc.SetPen( wxPen( wxColour( 128, 128, 0, 255 ),12, wxSOLID));
944 dc.SetBrush( wxBrush( wxColour( 192, 192, 0, 255),wxSOLID));
945
946 r.Offset( width * 0.8 , width *0.5 ) ;
e3b81044 947
f31a4cb2 948 dc.DrawRoundedRectangle( r.x, r.y, r.width, r.width, radius ) ;
e3b81044 949
f31a4cb2
SC
950 dc.SetPen( *wxTRANSPARENT_PEN ) ;
951 dc.SetBrush( wxBrush( wxColour(255,255,128,128) ) );
952 dc.DrawRoundedRectangle( 0 , margin + width / 2 , width * 3 , 100 , radius) ;
e3b81044 953
ad0b4329
RR
954 dc.SetTextForeground( wxColour(255,255,0,128) );
955 dc.SetFont( wxFont( 40, wxFONTFAMILY_SWISS, wxFONTSTYLE_ITALIC, wxFONTWEIGHT_NORMAL ) );
956 dc.DrawText( wxT("Hello!"), 120, 80 );
f31a4cb2
SC
957}
958
959#endif
960
7a5c82b1
SC
961#if wxUSE_GRAPHICS_CONTEXT
962
963const int BASE = 80.0;
964const int BASE2 = BASE/2;
965const int BASE4 = BASE/4;
966
967static inline double DegToRad(double deg) { return (deg * M_PI) / 180.0; }
968
969
970// modeled along Robin Dunn's GraphicsContext.py sample
971
972void MyCanvas::DrawGraphics(wxGraphicsContext* gc)
973{
974 wxFont font = wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT);
975 gc->SetFont(font,*wxBLACK);
4ee4c7b9 976
7a5c82b1
SC
977 // make a path that contains a circle and some lines, centered at 0,0
978 wxGraphicsPath path = gc->CreatePath() ;
979 path.AddCircle( 0, 0, BASE2 );
980 path.MoveToPoint(0, -BASE2);
981 path.AddLineToPoint(0, BASE2);
982 path.MoveToPoint(-BASE2, 0);
983 path.AddLineToPoint(BASE2, 0);
984 path.CloseSubpath();
985 path.AddRectangle(-BASE4, -BASE4/2, BASE2, BASE4);
4ee4c7b9 986
7a5c82b1 987 // Now use that path to demonstrate various capbilites of the grpahics context
4ee4c7b9 988 gc->PushState(); // save current translation/scale/other state
7a5c82b1
SC
989 gc->Translate(60, 75); // reposition the context origin
990
991 gc->SetPen(wxPen("navy", 1));
992 gc->SetBrush(wxBrush("pink"));
4ee4c7b9 993
7a5c82b1
SC
994 for( int i = 0 ; i < 3 ; ++i )
995 {
996 wxString label;
997 switch( i )
998 {
999 case 0 :
1000 label = "StrokePath";
1001 break;
1002 case 1 :
1003 label = "FillPath";
1004 break;
1005 case 2 :
1006 label = "DrawPath";
1007 break;
1008 }
1009 wxDouble w, h;
1010 gc->GetTextExtent(label, &w, &h, NULL, NULL);
1011 gc->DrawText(label, -w/2, -BASE2-h-4);
1012 switch( i )
1013 {
1014 case 0 :
1015 gc->StrokePath(path);
1016 break;
1017 case 1 :
1018 gc->FillPath(path);
1019 break;
1020 case 2 :
1021 gc->DrawPath(path);
1022 break;
1023 }
1024 gc->Translate(2*BASE, 0);
1025 }
4ee4c7b9 1026
7a5c82b1
SC
1027 gc->PopState(); // restore saved state
1028 gc->PushState(); // save it again
1029 gc->Translate(60, 200); // offset to the lower part of the window
4ee4c7b9 1030
7a5c82b1
SC
1031 gc->DrawText("Scale", 0, -BASE2);
1032 gc->Translate(0, 20);
1033
1034 gc->SetBrush(wxBrush(wxColour(178, 34, 34, 128)));// 128 == half transparent
1035 for( int i = 0 ; i < 8 ; ++i )
1036 {
1037 gc->Scale(1.08, 1.08); // increase scale by 8%
4ee4c7b9 1038 gc->Translate(5,5);
7a5c82b1
SC
1039 gc->DrawPath(path);
1040 }
1041
1042 gc->PopState(); // restore saved state
1043 gc->PushState(); // save it again
4ee4c7b9
VZ
1044 gc->Translate(400, 200);
1045
7a5c82b1
SC
1046 gc->DrawText("Rotate", 0, -BASE2);
1047
1048 // Move the origin over to the next location
1049 gc->Translate(0, 75);
1050
1051 // draw our path again, rotating it about the central point,
1052 // and changing colors as we go
1053 for ( int angle = 0 ; angle < 360 ; angle += 30 )
1054 {
4ee4c7b9 1055 gc->PushState(); // save this new current state so we can
7a5c82b1
SC
1056 // pop back to it at the end of the loop
1057 wxImage::RGBValue val = wxImage::HSVtoRGB(wxImage::HSVValue(float(angle)/360, 1, 1));
1058 gc->SetBrush(wxBrush(wxColour(val.red, val.green, val.blue, 64)));
1059 gc->SetPen(wxPen(wxColour(val.red, val.green, val.blue, 128)));
4ee4c7b9 1060
7a5c82b1
SC
1061 // use translate to artfully reposition each drawn path
1062 gc->Translate(1.5 * BASE2 * cos(DegToRad(angle)),
1063 1.5 * BASE2 * sin(DegToRad(angle)));
4ee4c7b9 1064
7a5c82b1
SC
1065 // use Rotate to rotate the path
1066 gc->Rotate(DegToRad(angle));
1067
1068 // now draw it
1069 gc->DrawPath(path);
1070 gc->PopState();
1071 }
1072 gc->PopState();
ce6b1014
VZ
1073
1074 gc->PushState();
1075 gc->Translate(60, 400);
1076 gc->DrawText("Scaled smiley inside a square", 0, 0);
1077 gc->DrawRectangle(BASE2, BASE2, 100, 100);
1078 gc->DrawBitmap(m_smile_bmp, BASE2, BASE2, 100, 100);
1079 gc->PopState();
7a5c82b1 1080}
ce6b1014 1081#endif // wxUSE_GRAPHICS_CONTEXT
7a5c82b1 1082
f6bcfd97
BP
1083void MyCanvas::DrawCircles(wxDC& dc)
1084{
1085 int x = 100,
1086 y = 100,
1087 r = 20;
1088
d9d2dcd8
RR
1089 dc.SetPen( *wxRED_PEN );
1090 dc.SetBrush( *wxGREEN_BRUSH );
1091
9a83f860 1092 dc.DrawText(wxT("Some circles"), 0, y);
d9d2dcd8
RR
1093 dc.DrawCircle(x, y, r);
1094 dc.DrawCircle(x + 2*r, y, r);
1095 dc.DrawCircle(x + 4*r, y, r);
1096
1097 y += 2*r;
9a83f860 1098 dc.DrawText(wxT("And ellipses"), 0, y);
d9d2dcd8
RR
1099 dc.DrawEllipse(x - r, y, 2*r, r);
1100 dc.DrawEllipse(x + r, y, 2*r, r);
1101 dc.DrawEllipse(x + 3*r, y, 2*r, r);
1102
1103 y += 2*r;
9a83f860 1104 dc.DrawText(wxT("And arcs"), 0, y);
d9d2dcd8
RR
1105 dc.DrawArc(x - r, y, x + r, y, x, y);
1106 dc.DrawArc(x + 4*r, y, x + 2*r, y, x + 3*r, y);
1107 dc.DrawArc(x + 5*r, y, x + 5*r, y, x + 6*r, y);
1108
1109 y += 2*r;
1110 dc.DrawEllipticArc(x - r, y, 2*r, r, 0, 90);
1111 dc.DrawEllipticArc(x + r, y, 2*r, r, 90, 180);
1112 dc.DrawEllipticArc(x + 3*r, y, 2*r, r, 180, 270);
1113 dc.DrawEllipticArc(x + 5*r, y, 2*r, r, 270, 360);
e3b81044 1114
d9d2dcd8 1115 // same as above, just transparent brush
e3b81044 1116
d9d2dcd8
RR
1117 dc.SetPen( *wxRED_PEN );
1118 dc.SetBrush( *wxTRANSPARENT_BRUSH );
1119
1120 y += 2*r;
9a83f860 1121 dc.DrawText(wxT("Some circles"), 0, y);
f6bcfd97
BP
1122 dc.DrawCircle(x, y, r);
1123 dc.DrawCircle(x + 2*r, y, r);
1124 dc.DrawCircle(x + 4*r, y, r);
1125
1126 y += 2*r;
9a83f860 1127 dc.DrawText(wxT("And ellipses"), 0, y);
f6bcfd97
BP
1128 dc.DrawEllipse(x - r, y, 2*r, r);
1129 dc.DrawEllipse(x + r, y, 2*r, r);
1130 dc.DrawEllipse(x + 3*r, y, 2*r, r);
1131
1132 y += 2*r;
9a83f860 1133 dc.DrawText(wxT("And arcs"), 0, y);
f6bcfd97
BP
1134 dc.DrawArc(x - r, y, x + r, y, x, y);
1135 dc.DrawArc(x + 4*r, y, x + 2*r, y, x + 3*r, y);
1136 dc.DrawArc(x + 5*r, y, x + 5*r, y, x + 6*r, y);
1137
1138 y += 2*r;
1139 dc.DrawEllipticArc(x - r, y, 2*r, r, 0, 90);
1140 dc.DrawEllipticArc(x + r, y, 2*r, r, 90, 180);
1141 dc.DrawEllipticArc(x + 3*r, y, 2*r, r, 180, 270);
1142 dc.DrawEllipticArc(x + 5*r, y, 2*r, r, 270, 360);
e3b81044 1143
f6bcfd97
BP
1144}
1145
b11729f1
WS
1146void MyCanvas::DrawSplines(wxDC& dc)
1147{
1148#if wxUSE_SPLINES
9a83f860 1149 dc.DrawText(wxT("Some splines"), 10, 5);
b11729f1
WS
1150
1151 // values are hardcoded rather than randomly generated
1152 // so the output can be compared between native
1153 // implementations on platforms with different random
1154 // generators
1155
1156 const int R = 300;
1157 const wxPoint center( R + 20, R + 20 );
1158 const int angles[7] = { 0, 10, 33, 77, 13, 145, 90 };
1159 const int radii[5] = { 100 , 59, 85, 33, 90 };
1160 const int n = 200;
1161 wxPoint pts[n];
1162
1163 // background spline calculation
1164 unsigned int radius_pos = 0;
1165 unsigned int angle_pos = 0;
1166 int angle = 0;
1167 for ( int i = 0; i < n; i++ )
1168 {
1169 angle += angles[ angle_pos ];
1170 int r = R * radii[ radius_pos ] / 100;
1171 pts[ i ].x = center.x + (wxCoord)( r * cos( M_PI * angle / 180.0) );
1172 pts[ i ].y = center.y + (wxCoord)( r * sin( M_PI * angle / 180.0) );
1173
1174 angle_pos++;
1175 if ( angle_pos >= WXSIZEOF(angles) ) angle_pos = 0;
1176
1177 radius_pos++;
1178 if ( radius_pos >= WXSIZEOF(radii) ) radius_pos = 0;
1179 }
1180
1181 // background spline drawing
1182 dc.SetPen(*wxRED_PEN);
1183 dc.DrawSpline(WXSIZEOF(pts), pts);
1184
1185 // less detailed spline calculation
1186 wxPoint letters[4][5];
1187 // w
1188 letters[0][0] = wxPoint( 0,1); // O O
1189 letters[0][1] = wxPoint( 1,3); // * *
1190 letters[0][2] = wxPoint( 2,2); // * O *
1191 letters[0][3] = wxPoint( 3,3); // * * * *
1192 letters[0][4] = wxPoint( 4,1); // O O
1193 // x1
1194 letters[1][0] = wxPoint( 5,1); // O*O
1195 letters[1][1] = wxPoint( 6,1); // *
1196 letters[1][2] = wxPoint( 7,2); // O
1197 letters[1][3] = wxPoint( 8,3); // *
1198 letters[1][4] = wxPoint( 9,3); // O*O
1199 // x2
1200 letters[2][0] = wxPoint( 5,3); // O*O
1201 letters[2][1] = wxPoint( 6,3); // *
1202 letters[2][2] = wxPoint( 7,2); // O
1203 letters[2][3] = wxPoint( 8,1); // *
1204 letters[2][4] = wxPoint( 9,1); // O*O
1205 // W
1206 letters[3][0] = wxPoint(10,0); // O O
1207 letters[3][1] = wxPoint(11,3); // * *
1208 letters[3][2] = wxPoint(12,1); // * O *
1209 letters[3][3] = wxPoint(13,3); // * * * *
1210 letters[3][4] = wxPoint(14,0); // O O
1211
1212 const int dx = 2 * R / letters[3][4].x;
1213 const int h[4] = { -R/2, 0, R/4, R/2 };
1214
1215 for ( int m = 0; m < 4; m++ )
1216 {
1217 for ( int n = 0; n < 5; n++ )
1218 {
1219 letters[m][n].x = center.x - R + letters[m][n].x * dx;
1220 letters[m][n].y = center.y + h[ letters[m][n].y ];
1221 }
1222
1223 dc.SetPen( wxPen( wxT("blue"), 1, wxDOT) );
1224 dc.DrawLines(5, letters[m]);
1225 dc.SetPen( wxPen( wxT("black"), 4, wxSOLID) );
1226 dc.DrawSpline(5, letters[m]);
1227 }
1228
1229#else
9a83f860 1230 dc.DrawText(wxT("Splines not supported."), 10, 5);
b11729f1
WS
1231#endif
1232}
1233
213ad8e7
VZ
1234void MyCanvas::DrawGradients(wxDC& dc)
1235{
2c8f21f8
VZ
1236 static const int TEXT_HEIGHT = 15;
1237
213ad8e7 1238 // LHS: linear
2c8f21f8 1239 wxRect r(10, 10, 50, 50);
9a83f860 1240 dc.DrawText(wxT("wxRIGHT"), r.x, r.y);
2c8f21f8 1241 r.Offset(0, TEXT_HEIGHT);
213ad8e7
VZ
1242 dc.GradientFillLinear(r, *wxWHITE, *wxBLUE, wxRIGHT);
1243
2c8f21f8 1244 r.Offset(0, r.height + 10);
9a83f860 1245 dc.DrawText(wxT("wxLEFT"), r.x, r.y);
2c8f21f8 1246 r.Offset(0, TEXT_HEIGHT);
213ad8e7
VZ
1247 dc.GradientFillLinear(r, *wxWHITE, *wxBLUE, wxLEFT);
1248
2c8f21f8 1249 r.Offset(0, r.height + 10);
9a83f860 1250 dc.DrawText(wxT("wxDOWN"), r.x, r.y);
2c8f21f8 1251 r.Offset(0, TEXT_HEIGHT);
213ad8e7
VZ
1252 dc.GradientFillLinear(r, *wxWHITE, *wxBLUE, wxDOWN);
1253
2c8f21f8 1254 r.Offset(0, r.height + 10);
9a83f860 1255 dc.DrawText(wxT("wxUP"), r.x, r.y);
2c8f21f8 1256 r.Offset(0, TEXT_HEIGHT);
213ad8e7
VZ
1257 dc.GradientFillLinear(r, *wxWHITE, *wxBLUE, wxUP);
1258
4ee4c7b9 1259 wxRect gfr = wxRect(r);
213ad8e7
VZ
1260
1261 // RHS: concentric
2c8f21f8 1262 r = wxRect(200, 10, 50, 50);
9a83f860 1263 dc.DrawText(wxT("Blue inside"), r.x, r.y);
2c8f21f8 1264 r.Offset(0, TEXT_HEIGHT);
213ad8e7
VZ
1265 dc.GradientFillConcentric(r, *wxBLUE, *wxWHITE);
1266
2c8f21f8 1267 r.Offset(0, r.height + 10);
9a83f860 1268 dc.DrawText(wxT("White inside"), r.x, r.y);
2c8f21f8 1269 r.Offset(0, TEXT_HEIGHT);
213ad8e7
VZ
1270 dc.GradientFillConcentric(r, *wxWHITE, *wxBLUE);
1271
2c8f21f8 1272 r.Offset(0, r.height + 10);
9a83f860 1273 dc.DrawText(wxT("Blue in top left corner"), r.x, r.y);
2c8f21f8 1274 r.Offset(0, TEXT_HEIGHT);
213ad8e7
VZ
1275 dc.GradientFillConcentric(r, *wxBLUE, *wxWHITE, wxPoint(0, 0));
1276
2c8f21f8 1277 r.Offset(0, r.height + 10);
9a83f860 1278 dc.DrawText(wxT("Blue in bottom right corner"), r.x, r.y);
2c8f21f8
VZ
1279 r.Offset(0, TEXT_HEIGHT);
1280 dc.GradientFillConcentric(r, *wxBLUE, *wxWHITE, wxPoint(r.width, r.height));
5f77ee3b
VZ
1281
1282 // check that the area filled by the gradient is exactly the interior of
1283 // the rectangle
1284 r.x = 350;
1285 r.y = 30;
1286 dc.DrawText("The interior should be filled but", r.x, r.y);
1287 r.y += 15;
1288 dc.DrawText(" the red border should remain visible:", r.x, r.y);
1289 r.y += 15;
1290
1291 r.width =
1292 r.height = 50;
1293 wxRect r2 = r;
1294 r2.x += 60;
1295 wxRect r3 = r;
1296 r3.y += 60;
1297 wxRect r4 = r2;
1298 r4.y += 60;
1299 dc.SetPen(wxPen(wxColour(255, 0, 0)));
1300 dc.DrawRectangle(r);
1301 r.Deflate(1);
1302 dc.GradientFillLinear(r, wxColour(0,255,0), wxColour(0,0,0), wxNORTH);
1303 dc.DrawRectangle(r2);
1304 r2.Deflate(1);
1305 dc.GradientFillLinear(r2, wxColour(0,0,0), wxColour(0,255,0), wxSOUTH);
1306 dc.DrawRectangle(r3);
1307 r3.Deflate(1);
1308 dc.GradientFillLinear(r3, wxColour(0,255,0), wxColour(0,0,0), wxEAST);
1309 dc.DrawRectangle(r4);
1310 r4.Deflate(1);
1311 dc.GradientFillLinear(r4, wxColour(0,0,0), wxColour(0,255,0), wxWEST);
4ee4c7b9
VZ
1312
1313#if wxUSE_GRAPHICS_CONTEXT
1314 if (m_useContext)
1315 {
1316 wxGCDC &gdc = (wxGCDC&)dc;
1317 wxGraphicsContext *gc = gdc.GetGraphicsContext();
1318 wxGraphicsPath pth;
1319 wxGraphicsGradientStops stops;
1320
1321 gfr.Offset(0, gfr.height + 10);
1322 dc.DrawText(wxT("Linear Gradient with Stops"), gfr.x, gfr.y);
1323 gfr.Offset(0, TEXT_HEIGHT);
1324
1325 stops = wxGraphicsGradientStops(wxColour(255,0,0), wxColour(0,0,255));
1326 stops.Add(wxColour(255,255,0), 0.33f);
1327 stops.Add(wxColour(0,255,0), 0.67f);
1328
1329 gc->SetBrush(gc->CreateLinearGradientBrush(gfr.x, gfr.y,
1330 gfr.x + gfr.width, gfr.y + gfr.height,
1331 stops));
1332 pth = gc->CreatePath();
1333 pth.MoveToPoint(gfr.x,gfr.y);
1334 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y);
1335 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y+gfr.height);
1336 pth.AddLineToPoint(gfr.x,gfr.y+gfr.height);
1337 pth.CloseSubpath();
1338 gc->FillPath(pth);
1339
1340 gfr.Offset(0, gfr.height + 10);
1341 dc.DrawText(wxT("Radial Gradient with Stops"), gfr.x, gfr.y);
1342 gfr.Offset(0, TEXT_HEIGHT);
1343
1344 gc->SetBrush(gc->CreateRadialGradientBrush(gfr.x + gfr.width / 2,
1345 gfr.y + gfr.height / 2,
1346 gfr.x + gfr.width / 2,
1347 gfr.y + gfr.height / 2,
1348 gfr.width / 2,
1349 stops));
1350 pth = gc->CreatePath();
1351 pth.MoveToPoint(gfr.x,gfr.y);
1352 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y);
1353 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y+gfr.height);
1354 pth.AddLineToPoint(gfr.x,gfr.y+gfr.height);
1355 pth.CloseSubpath();
1356 gc->FillPath(pth);
1357
1358 gfr.Offset(0, gfr.height + 10);
1359 dc.DrawText(wxT("Linear Gradient with Stops and Gaps"), gfr.x, gfr.y);
1360 gfr.Offset(0, TEXT_HEIGHT);
1361
1362 stops = wxGraphicsGradientStops(wxColour(255,0,0), wxColour(0,0,255));
1363 stops.Add(wxColour(255,255,0), 0.33f);
1364 stops.Add(wxTransparentColour, 0.33f);
1365 stops.Add(wxTransparentColour, 0.67f);
1366 stops.Add(wxColour(0,255,0), 0.67f);
1367
1368 gc->SetBrush(gc->CreateLinearGradientBrush(gfr.x, gfr.y + gfr.height,
1369 gfr.x + gfr.width, gfr.y,
1370 stops));
1371 pth = gc->CreatePath();
1372 pth.MoveToPoint(gfr.x,gfr.y);
1373 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y);
1374 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y+gfr.height);
1375 pth.AddLineToPoint(gfr.x,gfr.y+gfr.height);
1376 pth.CloseSubpath();
1377 gc->FillPath(pth);
1378
1379 gfr.Offset(0, gfr.height + 10);
1380 dc.DrawText(wxT("Radial Gradient with Stops and Gaps"), gfr.x, gfr.y);
1381 gfr.Offset(0, TEXT_HEIGHT);
1382
1383 gc->SetBrush(gc->CreateRadialGradientBrush(gfr.x + gfr.width / 2,
1384 gfr.y + gfr.height / 2,
1385 gfr.x + gfr.width / 2,
1386 gfr.y + gfr.height / 2,
1387 gfr.width / 2,
1388 stops));
1389 pth = gc->CreatePath();
1390 pth.MoveToPoint(gfr.x,gfr.y);
1391 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y);
1392 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y+gfr.height);
1393 pth.AddLineToPoint(gfr.x,gfr.y+gfr.height);
1394 pth.CloseSubpath();
1395 gc->FillPath(pth);
1396
1397 gfr.Offset(0, gfr.height + 10);
1398 dc.DrawText(wxT("Gradients with Stops and Transparency"), gfr.x, gfr.y);
1399 gfr.Offset(0, TEXT_HEIGHT);
1400
1401 stops = wxGraphicsGradientStops(wxColour(255,0,0), wxTransparentColour);
1402 stops.Add(wxColour(255,0,0), 0.33f);
1403 stops.Add(wxTransparentColour, 0.33f);
1404 stops.Add(wxTransparentColour, 0.67f);
1405 stops.Add(wxColour(0,0,255), 0.67f);
1406 stops.Add(wxColour(0,0,255), 1.0f);
1407
1408 pth = gc->CreatePath();
1409 pth.MoveToPoint(gfr.x,gfr.y);
1410 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y);
1411 pth.AddLineToPoint(gfr.x + gfr.width,gfr.y+gfr.height);
1412 pth.AddLineToPoint(gfr.x,gfr.y+gfr.height);
1413 pth.CloseSubpath();
1414
1415 gc->SetBrush(gc->CreateRadialGradientBrush(gfr.x + gfr.width / 2,
1416 gfr.y + gfr.height / 2,
1417 gfr.x + gfr.width / 2,
1418 gfr.y + gfr.height / 2,
1419 gfr.width / 2,
1420 stops));
1421 gc->FillPath(pth);
1422
1423 stops = wxGraphicsGradientStops(wxColour(255,0,0, 128), wxColour(0,0,255, 128));
1424 stops.Add(wxColour(255,255,0,128), 0.33f);
1425 stops.Add(wxColour(0,255,0,128), 0.67f);
1426
1427 gc->SetBrush(gc->CreateLinearGradientBrush(gfr.x, gfr.y,
1428 gfr.x + gfr.width, gfr.y,
1429 stops));
1430 gc->FillPath(pth);
1431 }
1432#endif // wxUSE_GRAPHICS_CONTEXT
213ad8e7
VZ
1433}
1434
bc3cedfa
RR
1435void MyCanvas::DrawRegions(wxDC& dc)
1436{
9a83f860
VZ
1437 dc.DrawText(wxT("You should see a red rect partly covered by a cyan one ")
1438 wxT("on the left"), 10, 5);
1439 dc.DrawText(wxT("and 5 smileys from which 4 are partially clipped on the right"),
8e0e4b1b 1440 10, 5 + dc.GetCharHeight());
9a83f860
VZ
1441 dc.DrawText(wxT("The second copy should be identical but right part of it ")
1442 wxT("should be offset by 10 pixels."),
4cbcae16 1443 10, 5 + 2*dc.GetCharHeight());
8e0e4b1b 1444
9da8feef
WS
1445 DrawRegionsHelper(dc, 10, true);
1446 DrawRegionsHelper(dc, 350, false);
8e0e4b1b 1447}
c4218a74 1448
4cbcae16 1449void MyCanvas::DrawRegionsHelper(wxDC& dc, wxCoord x, bool firstTime)
8e0e4b1b 1450{
4cbcae16
VZ
1451 wxCoord y = 100;
1452
8e0e4b1b 1453 dc.DestroyClippingRegion();
bc3cedfa
RR
1454 dc.SetBrush( *wxWHITE_BRUSH );
1455 dc.SetPen( *wxTRANSPARENT_PEN );
4cbcae16 1456 dc.DrawRectangle( x, y, 310, 310 );
c4218a74 1457
4cbcae16 1458 dc.SetClippingRegion( x + 10, y + 10, 100, 270 );
c4218a74 1459
bc3cedfa 1460 dc.SetBrush( *wxRED_BRUSH );
4cbcae16 1461 dc.DrawRectangle( x, y, 310, 310 );
c4218a74 1462
4cbcae16 1463 dc.SetClippingRegion( x + 10, y + 10, 100, 100 );
993f97ee 1464
993f97ee 1465 dc.SetBrush( *wxCYAN_BRUSH );
4cbcae16
VZ
1466 dc.DrawRectangle( x, y, 310, 310 );
1467
1468 dc.DestroyClippingRegion();
1469
1470 wxRegion region(x + 110, y + 20, 100, 270);
8a28bf76 1471#if !defined(__WXMOTIF__)
4cbcae16
VZ
1472 if ( !firstTime )
1473 region.Offset(10, 10);
4cae9a20 1474#endif
795b5a8b 1475 dc.SetDeviceClippingRegion(region);
c4218a74 1476
bc3cedfa 1477 dc.SetBrush( *wxGREY_BRUSH );
4cbcae16 1478 dc.DrawRectangle( x, y, 310, 310 );
c4218a74 1479
a1b806b9 1480 if (m_smile_bmp.IsOk())
5d25c050 1481 {
9da8feef
WS
1482 dc.DrawBitmap( m_smile_bmp, x + 150, y + 150, true );
1483 dc.DrawBitmap( m_smile_bmp, x + 130, y + 10, true );
1484 dc.DrawBitmap( m_smile_bmp, x + 130, y + 280, true );
1485 dc.DrawBitmap( m_smile_bmp, x + 100, y + 70, true );
1486 dc.DrawBitmap( m_smile_bmp, x + 200, y + 70, true );
5d25c050 1487 }
bc3cedfa
RR
1488}
1489
568708e2
VZ
1490void MyCanvas::OnPaint(wxPaintEvent &WXUNUSED(event))
1491{
f31a4cb2 1492 wxPaintDC pdc(this);
8c6b0819
VZ
1493 Draw(pdc);
1494}
f31a4cb2 1495
5707e433 1496void MyCanvas::Draw(wxDC& pdc)
8c6b0819 1497{
f31a4cb2 1498#if wxUSE_GRAPHICS_CONTEXT
8a021e00 1499 wxGCDC gdc;
5707e433
VZ
1500 wxGraphicsRenderer* const renderer = wxGraphicsRenderer::
1501#if TEST_CAIRO_EVERYWHERE
1502 GetCairoRenderer()
8a021e00 1503#else
5707e433 1504 GetDefaultRenderer()
8a021e00 1505#endif
5707e433
VZ
1506 ;
1507
1508 wxGraphicsContext* context;
1509 if ( wxPaintDC *paintdc = wxDynamicCast(&pdc, wxPaintDC) )
1510 {
1511 context = renderer->CreateContext(*paintdc);
1512 }
1513 else if ( wxMemoryDC *memdc = wxDynamicCast(&pdc, wxMemoryDC) )
1514 {
1515 context = renderer->CreateContext(*memdc);
1516 }
1517#if wxUSE_METAFILE && defined(wxMETAFILE_IS_ENH)
1518 else if ( wxMetafileDC *metadc = wxDynamicCast(&pdc, wxMetafileDC) )
1519 {
1520 context = renderer->CreateContext(*metadc);
1521 }
1522#endif
1523 else
1524 {
1525 wxFAIL_MSG( "Unknown wxDC kind" );
1526 return;
1527 }
1528
1529 gdc.SetGraphicsContext(context);
1530
f31a4cb2
SC
1531 wxDC &dc = m_useContext ? (wxDC&) gdc : (wxDC&) pdc ;
1532#else
1533 wxDC &dc = pdc ;
1534#endif
1535
568708e2 1536 PrepareDC(dc);
c4218a74 1537
568708e2
VZ
1538 m_owner->PrepareDC(dc);
1539
1540 dc.SetBackgroundMode( m_owner->m_backgroundMode );
a1b806b9 1541 if ( m_owner->m_backgroundBrush.IsOk() )
568708e2 1542 dc.SetBackground( m_owner->m_backgroundBrush );
a1b806b9 1543 if ( m_owner->m_colourForeground.IsOk() )
568708e2 1544 dc.SetTextForeground( m_owner->m_colourForeground );
a1b806b9 1545 if ( m_owner->m_colourBackground.IsOk() )
568708e2 1546 dc.SetTextBackground( m_owner->m_colourBackground );
4786aabd 1547
1edc9f45 1548 if ( m_owner->m_textureBackground) {
a1b806b9 1549 if ( ! m_owner->m_backgroundBrush.IsOk() ) {
925e9792
WS
1550 wxColour clr(0,128,0);
1551 wxBrush b(clr, wxSOLID);
1edc9f45
RD
1552 dc.SetBackground(b);
1553 }
047473c9
RD
1554 }
1555
204dd9a7
VZ
1556 if ( m_clip )
1557 dc.SetClippingRegion(100, 100, 100, 100);
1558
e1208c31 1559 dc.Clear();
1edc9f45 1560
204dd9a7
VZ
1561 if ( m_owner->m_textureBackground )
1562 {
1edc9f45 1563 dc.SetPen(*wxMEDIUM_GREY_PEN);
204dd9a7 1564 for ( int i = 0; i < 200; i++ )
1edc9f45
RD
1565 dc.DrawLine(0, i*10, i*10, 0);
1566 }
1567
568708e2
VZ
1568 switch ( m_show )
1569 {
f65e33a3 1570 case File_ShowDefault:
568708e2
VZ
1571 DrawDefault(dc);
1572 break;
1e7fd311 1573
f65e33a3 1574 case File_ShowCircles:
f6bcfd97
BP
1575 DrawCircles(dc);
1576 break;
1577
f65e33a3 1578 case File_ShowSplines:
b11729f1
WS
1579 DrawSplines(dc);
1580 break;
1581
f65e33a3 1582 case File_ShowRegions:
bc3cedfa
RR
1583 DrawRegions(dc);
1584 break;
1585
f65e33a3 1586 case File_ShowText:
568708e2
VZ
1587 DrawText(dc);
1588 break;
1e7fd311 1589
f65e33a3 1590 case File_ShowLines:
568708e2 1591 DrawTestLines( 0, 100, 0, dc );
f6bcfd97
BP
1592 DrawTestLines( 0, 320, 1, dc );
1593 DrawTestLines( 0, 540, 2, dc );
1594 DrawTestLines( 0, 760, 6, dc );
568708e2 1595 break;
1e7fd311 1596
f65e33a3 1597 case File_ShowBrushes:
6386110d
VZ
1598 DrawTestBrushes(dc);
1599 break;
1600
f65e33a3 1601 case File_ShowPolygons:
6386110d 1602 DrawTestPoly(dc);
568708e2 1603 break;
1e7fd311 1604
f65e33a3 1605 case File_ShowMask:
e3b81044
VZ
1606 DrawImages(dc, Draw_Normal);
1607 break;
1608
f65e33a3 1609 case File_ShowMaskStretch:
e3b81044 1610 DrawImages(dc, Draw_Stretch);
568708e2 1611 break;
81278df2 1612
f65e33a3 1613 case File_ShowOps:
81278df2
VZ
1614 DrawWithLogicalOps(dc);
1615 break;
e3b81044 1616
f31a4cb2 1617#if wxUSE_GRAPHICS_CONTEXT
f65e33a3 1618 case File_ShowAlpha:
f31a4cb2
SC
1619 DrawAlpha(dc);
1620 break;
f65e33a3 1621 case File_ShowGraphics:
7a5c82b1
SC
1622 DrawGraphics(gdc.GetGraphicsContext());
1623 break;
f31a4cb2 1624#endif
213ad8e7 1625
f65e33a3 1626 case File_ShowGradients:
213ad8e7
VZ
1627 DrawGradients(dc);
1628 break;
e95c145c
WS
1629
1630 default:
1631 break;
568708e2 1632 }
b62c3631
RR
1633}
1634
bf0c00c6
RR
1635void MyCanvas::OnMouseMove(wxMouseEvent &event)
1636{
960a83cc 1637#if wxUSE_STATUSBAR
8a021e00
SC
1638 {
1639 wxClientDC dc(this);
1640 PrepareDC(dc);
1641 m_owner->PrepareDC(dc);
1642
1643 wxPoint pos = event.GetPosition();
1644 long x = dc.DeviceToLogicalX( pos.x );
1645 long y = dc.DeviceToLogicalY( pos.y );
1646 wxString str;
1647 str.Printf( wxT("Current mouse position: %d,%d"), (int)x, (int)y );
1648 m_owner->SetStatusText( str );
1649 }
4ee4c7b9 1650
8a021e00
SC
1651 if ( m_rubberBand )
1652 {
1653 int x,y, xx, yy ;
1654 event.GetPosition(&x,&y);
1655 CalcUnscrolledPosition( x, y, &xx, &yy );
1656 m_currentpoint = wxPoint( xx , yy ) ;
1657 wxRect newrect ( m_anchorpoint , m_currentpoint ) ;
1658
1659 wxClientDC dc( this ) ;
1660 PrepareDC( dc ) ;
1661
1662 wxDCOverlay overlaydc( m_overlay, &dc );
1663 overlaydc.Clear();
e630cd04 1664#ifdef __WXMAC__
8a021e00
SC
1665 dc.SetPen( *wxGREY_PEN );
1666 dc.SetBrush( wxColour( 192,192,192,64 ) );
1667#else
1668 dc.SetPen( wxPen( *wxLIGHT_GREY, 2, wxSOLID ) );
1669 dc.SetBrush( *wxTRANSPARENT_BRUSH );
1670#endif
1671 dc.DrawRectangle( newrect );
1672 }
960a83cc
WS
1673#else
1674 wxUnusedVar(event);
1675#endif // wxUSE_STATUSBAR
bf0c00c6
RR
1676}
1677
8a021e00
SC
1678void MyCanvas::OnMouseDown(wxMouseEvent &event)
1679{
4ee4c7b9
VZ
1680 int x,y,xx,yy ;
1681 event.GetPosition(&x,&y);
8a021e00
SC
1682 CalcUnscrolledPosition( x, y, &xx, &yy );
1683 m_anchorpoint = wxPoint( xx , yy ) ;
1684 m_currentpoint = m_anchorpoint ;
1685 m_rubberBand = true ;
1686 CaptureMouse() ;
1687}
1688
1689void MyCanvas::OnMouseUp(wxMouseEvent &event)
1690{
1691 if ( m_rubberBand )
1692 {
5f0d3411 1693 ReleaseMouse();
8a021e00
SC
1694 {
1695 wxClientDC dc( this );
1696 PrepareDC( dc );
1697 wxDCOverlay overlaydc( m_overlay, &dc );
1698 overlaydc.Clear();
1699 }
1700 m_overlay.Reset();
1701 m_rubberBand = false;
1702
8fa11bb2 1703 wxPoint endpoint = CalcUnscrolledPosition(event.GetPosition());
8a021e00 1704
8fa11bb2
VZ
1705 // Don't pop up the message box if nothing was actually selected.
1706 if ( endpoint != m_anchorpoint )
1707 {
1708 wxLogMessage("Selected rectangle from (%d, %d) to (%d, %d)",
1709 m_anchorpoint.x, m_anchorpoint.y,
1710 endpoint.x, endpoint.y);
1711 }
8a021e00
SC
1712 }
1713}
1714
b62c3631
RR
1715// ----------------------------------------------------------------------------
1716// MyFrame
1717// ----------------------------------------------------------------------------
1718
be5a51fb 1719// the event tables connect the wxWidgets events with the functions (event
b62c3631
RR
1720// handlers) which process them. It can be also done at run-time, but for the
1721// simple menu events like this the static method is much simpler.
1722BEGIN_EVENT_TABLE(MyFrame, wxFrame)
568708e2
VZ
1723 EVT_MENU (File_Quit, MyFrame::OnQuit)
1724 EVT_MENU (File_About, MyFrame::OnAbout)
204dd9a7 1725 EVT_MENU (File_Clip, MyFrame::OnClip)
f31a4cb2
SC
1726#if wxUSE_GRAPHICS_CONTEXT
1727 EVT_MENU (File_GraphicContext, MyFrame::OnGraphicContext)
1728#endif
8c6b0819
VZ
1729 EVT_MENU (File_Copy, MyFrame::OnCopy)
1730 EVT_MENU (File_Save, MyFrame::OnSave)
568708e2
VZ
1731
1732 EVT_MENU_RANGE(MenuShow_First, MenuShow_Last, MyFrame::OnShow)
1733
b62c3631
RR
1734 EVT_MENU_RANGE(MenuOption_First, MenuOption_Last, MyFrame::OnOption)
1735END_EVENT_TABLE()
1736
aba99005
RR
1737// frame constructor
1738MyFrame::MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size)
9da8feef 1739 : wxFrame((wxFrame *)NULL, wxID_ANY, title, pos, size,
c4218a74 1740 wxDEFAULT_FRAME_STYLE | wxNO_FULL_REPAINT_ON_RESIZE)
aba99005
RR
1741{
1742 // set the frame icon
3cb332c1 1743 SetIcon(wxICON(sample));
aba99005
RR
1744
1745 wxMenu *menuFile = new wxMenu;
9a83f860
VZ
1746 menuFile->Append(File_ShowDefault, wxT("&Default screen\tF1"));
1747 menuFile->Append(File_ShowText, wxT("&Text screen\tF2"));
1748 menuFile->Append(File_ShowLines, wxT("&Lines screen\tF3"));
1749 menuFile->Append(File_ShowBrushes, wxT("&Brushes screen\tF4"));
1750 menuFile->Append(File_ShowPolygons, wxT("&Polygons screen\tF5"));
1751 menuFile->Append(File_ShowMask, wxT("&Mask screen\tF6"));
1752 menuFile->Append(File_ShowMaskStretch, wxT("1/&2 scaled mask\tShift-F6"));
1753 menuFile->Append(File_ShowOps, wxT("&Raster operations screen\tF7"));
1754 menuFile->Append(File_ShowRegions, wxT("Re&gions screen\tF8"));
1755 menuFile->Append(File_ShowCircles, wxT("&Circles screen\tF9"));
f31a4cb2 1756#if wxUSE_GRAPHICS_CONTEXT
9a83f860 1757 menuFile->Append(File_ShowAlpha, wxT("&Alpha screen\tF10"));
f31a4cb2 1758#endif
8c6b0819 1759 menuFile->Append(File_ShowSplines, wxT("Spl&ines screen\tF11"));
9a83f860 1760 menuFile->Append(File_ShowGradients, wxT("&Gradients screen\tF12"));
7a5c82b1 1761#if wxUSE_GRAPHICS_CONTEXT
9a83f860 1762 menuFile->Append(File_ShowGraphics, wxT("&Graphics screen"));
7a5c82b1 1763#endif
568708e2 1764 menuFile->AppendSeparator();
9a83f860 1765 menuFile->AppendCheckItem(File_Clip, wxT("&Clip\tCtrl-C"), wxT("Clip/unclip drawing"));
f31a4cb2 1766#if wxUSE_GRAPHICS_CONTEXT
9a83f860 1767 menuFile->AppendCheckItem(File_GraphicContext, wxT("&Use GraphicContext\tCtrl-Y"), wxT("Use GraphicContext"));
f31a4cb2 1768#endif
204dd9a7 1769 menuFile->AppendSeparator();
8c6b0819
VZ
1770#if wxUSE_METAFILE && defined(wxMETAFILE_IS_ENH)
1771 menuFile->Append(File_Copy, wxT("Copy to clipboard"));
1772#endif
1773 menuFile->Append(File_Save, wxT("&Save...\tCtrl-S"), wxT("Save drawing to file"));
1774 menuFile->AppendSeparator();
9a83f860 1775 menuFile->Append(File_About, wxT("&About...\tCtrl-A"), wxT("Show about dialog"));
aba99005 1776 menuFile->AppendSeparator();
9a83f860 1777 menuFile->Append(File_Quit, wxT("E&xit\tAlt-X"), wxT("Quit this program"));
0f0c61d0 1778
aba99005 1779 wxMenu *menuMapMode = new wxMenu;
9a83f860
VZ
1780 menuMapMode->Append( MapMode_Text, wxT("&TEXT map mode") );
1781 menuMapMode->Append( MapMode_Lometric, wxT("&LOMETRIC map mode") );
1782 menuMapMode->Append( MapMode_Twips, wxT("T&WIPS map mode") );
1783 menuMapMode->Append( MapMode_Points, wxT("&POINTS map mode") );
1784 menuMapMode->Append( MapMode_Metric, wxT("&METRIC map mode") );
0f0c61d0 1785
aba99005 1786 wxMenu *menuUserScale = new wxMenu;
9a83f860
VZ
1787 menuUserScale->Append( UserScale_StretchHoriz, wxT("Stretch &horizontally\tCtrl-H") );
1788 menuUserScale->Append( UserScale_ShrinkHoriz, wxT("Shrin&k horizontally\tCtrl-G") );
1789 menuUserScale->Append( UserScale_StretchVertic, wxT("Stretch &vertically\tCtrl-V") );
1790 menuUserScale->Append( UserScale_ShrinkVertic, wxT("&Shrink vertically\tCtrl-W") );
0f0c61d0 1791 menuUserScale->AppendSeparator();
9a83f860 1792 menuUserScale->Append( UserScale_Restore, wxT("&Restore to normal\tCtrl-0") );
0f0c61d0 1793
aba99005 1794 wxMenu *menuAxis = new wxMenu;
9a83f860
VZ
1795 menuAxis->AppendCheckItem( AxisMirror_Horiz, wxT("Mirror horizontally\tCtrl-M") );
1796 menuAxis->AppendCheckItem( AxisMirror_Vertic, wxT("Mirror vertically\tCtrl-N") );
0f0c61d0 1797
aba99005 1798 wxMenu *menuLogical = new wxMenu;
9a83f860
VZ
1799 menuLogical->Append( LogicalOrigin_MoveDown, wxT("Move &down\tCtrl-D") );
1800 menuLogical->Append( LogicalOrigin_MoveUp, wxT("Move &up\tCtrl-U") );
1801 menuLogical->Append( LogicalOrigin_MoveLeft, wxT("Move &right\tCtrl-L") );
1802 menuLogical->Append( LogicalOrigin_MoveRight, wxT("Move &left\tCtrl-R") );
fb576291 1803 menuLogical->AppendSeparator();
9a83f860
VZ
1804 menuLogical->Append( LogicalOrigin_Set, wxT("Set to (&100, 100)\tShift-Ctrl-1") );
1805 menuLogical->Append( LogicalOrigin_Restore, wxT("&Restore to normal\tShift-Ctrl-0") );
aba99005 1806
0f0c61d0 1807 wxMenu *menuColour = new wxMenu;
960a83cc 1808#if wxUSE_COLOURDLG
9a83f860
VZ
1809 menuColour->Append( Colour_TextForeground, wxT("Text &foreground...") );
1810 menuColour->Append( Colour_TextBackground, wxT("Text &background...") );
1811 menuColour->Append( Colour_Background, wxT("Background &colour...") );
960a83cc 1812#endif // wxUSE_COLOURDLG
9a83f860
VZ
1813 menuColour->AppendCheckItem( Colour_BackgroundMode, wxT("&Opaque/transparent\tCtrl-B") );
1814 menuColour->AppendCheckItem( Colour_TextureBackgound, wxT("Draw textured back&ground\tCtrl-T") );
0f0c61d0 1815
aba99005
RR
1816 // now append the freshly created menu to the menu bar...
1817 wxMenuBar *menuBar = new wxMenuBar;
9a83f860
VZ
1818 menuBar->Append(menuFile, wxT("&File"));
1819 menuBar->Append(menuMapMode, wxT("&Mode"));
1820 menuBar->Append(menuUserScale, wxT("&Scale"));
1821 menuBar->Append(menuAxis, wxT("&Axis"));
1822 menuBar->Append(menuLogical, wxT("&Origin"));
1823 menuBar->Append(menuColour, wxT("&Colours"));
aba99005
RR
1824
1825 // ... and attach this menu bar to the frame
1826 SetMenuBar(menuBar);
1827
960a83cc 1828#if wxUSE_STATUSBAR
aba99005 1829 CreateStatusBar(2);
9a83f860 1830 SetStatusText(wxT("Welcome to wxWidgets!"));
960a83cc 1831#endif // wxUSE_STATUSBAR
0f0c61d0 1832
aba99005
RR
1833 m_mapMode = wxMM_TEXT;
1834 m_xUserScale = 1.0;
1835 m_yUserScale = 1.0;
1836 m_xLogicalOrigin = 0;
1837 m_yLogicalOrigin = 0;
0f0c61d0 1838 m_xAxisReversed =
9da8feef 1839 m_yAxisReversed = false;
0f0c61d0 1840 m_backgroundMode = wxSOLID;
4ee4c7b9
VZ
1841 m_colourForeground = *wxBLACK;
1842 m_colourBackground = *wxLIGHT_GREY;
9da8feef 1843 m_textureBackground = false;
aba99005 1844
b62c3631 1845 m_canvas = new MyCanvas( this );
b97fa7cf 1846 m_canvas->SetScrollbars( 10, 10, 100, 240 );
b62c3631 1847}
aba99005
RR
1848
1849// event handlers
1850
1851void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
1852{
9da8feef
WS
1853 // true is to force the frame to close
1854 Close(true);
aba99005
RR
1855}
1856
1857void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
1858{
1859 wxString msg;
c916e13b
RR
1860 msg.Printf( wxT("This is the about dialog of the drawing sample.\n")
1861 wxT("This sample tests various primitive drawing functions\n")
6386110d 1862 wxT("(without any attempts to prevent flicker).\n")
c916e13b 1863 wxT("Copyright (c) Robert Roebling 1999")
aba99005
RR
1864 );
1865
9a83f860 1866 wxMessageBox(msg, wxT("About Drawing"), wxOK | wxICON_INFORMATION, this);
aba99005
RR
1867}
1868
204dd9a7
VZ
1869void MyFrame::OnClip(wxCommandEvent& event)
1870{
1871 m_canvas->Clip(event.IsChecked());
1872}
1873
f31a4cb2
SC
1874#if wxUSE_GRAPHICS_CONTEXT
1875void MyFrame::OnGraphicContext(wxCommandEvent& event)
1876{
1877 m_canvas->UseGraphicContext(event.IsChecked());
1878}
1879#endif
1880
8c6b0819
VZ
1881void MyFrame::OnCopy(wxCommandEvent& WXUNUSED(event))
1882{
1883#if wxUSE_METAFILE && defined(wxMETAFILE_IS_ENH)
1884 wxMetafileDC dc;
1885 if (!dc.IsOk())
1886 return;
1887 m_canvas->Draw(dc);
1888 wxMetafile *mf = dc.Close();
1889 if (!mf)
1890 return;
1891 mf->SetClipboard();
1892 delete mf;
1893#endif
1894}
1895
1896void MyFrame::OnSave(wxCommandEvent& WXUNUSED(event))
1897{
1898 wxFileDialog dlg(this, wxT("Save as bitmap"), wxT(""), wxT(""),
1899#if wxUSE_LIBPNG
1900 wxT("PNG image (*.png)|*.png;*.PNG|")
1901#endif
1902 wxT("Bitmap image (*.bmp)|*.bmp;*.BMP"),
1903 wxFD_SAVE | wxFD_OVERWRITE_PROMPT);
1904 if (dlg.ShowModal() == wxID_OK)
1905 {
1906 wxBitmap bmp(500, 800);
1907 wxMemoryDC mdc(bmp);
1908 m_canvas->Draw(mdc);
1909 bmp.ConvertToImage().SaveFile(dlg.GetPath());
1910 }
1911}
1912
568708e2
VZ
1913void MyFrame::OnShow(wxCommandEvent& event)
1914{
f65e33a3 1915 m_canvas->ToShow(event.GetId());
568708e2
VZ
1916}
1917
1918void MyFrame::OnOption(wxCommandEvent& event)
aba99005 1919{
3ca6a5f0 1920 switch (event.GetId())
aba99005
RR
1921 {
1922 case MapMode_Text:
b9857632 1923 m_mapMode = wxMM_TEXT;
0f0c61d0 1924 break;
aba99005
RR
1925 case MapMode_Lometric:
1926 m_mapMode = wxMM_LOMETRIC;
0f0c61d0
VZ
1927 break;
1928 case MapMode_Twips:
aba99005 1929 m_mapMode = wxMM_TWIPS;
0f0c61d0
VZ
1930 break;
1931 case MapMode_Points:
aba99005 1932 m_mapMode = wxMM_POINTS;
0f0c61d0
VZ
1933 break;
1934 case MapMode_Metric:
aba99005 1935 m_mapMode = wxMM_METRIC;
0f0c61d0
VZ
1936 break;
1937
1938 case LogicalOrigin_MoveDown:
1939 m_yLogicalOrigin += 10;
1940 break;
1941 case LogicalOrigin_MoveUp:
1942 m_yLogicalOrigin -= 10;
1943 break;
1944 case LogicalOrigin_MoveLeft:
1945 m_xLogicalOrigin += 10;
1946 break;
1947 case LogicalOrigin_MoveRight:
1948 m_xLogicalOrigin -= 10;
1949 break;
fb576291
VZ
1950 case LogicalOrigin_Set:
1951 m_xLogicalOrigin =
1952 m_yLogicalOrigin = -100;
1953 break;
1954 case LogicalOrigin_Restore:
1955 m_xLogicalOrigin =
1956 m_yLogicalOrigin = 0;
1957 break;
0f0c61d0
VZ
1958
1959 case UserScale_StretchHoriz:
1960 m_xUserScale *= 1.10;
1961 break;
1962 case UserScale_ShrinkHoriz:
1963 m_xUserScale /= 1.10;
1964 break;
1965 case UserScale_StretchVertic:
1966 m_yUserScale *= 1.10;
1967 break;
1968 case UserScale_ShrinkVertic:
1969 m_yUserScale /= 1.10;
1970 break;
1971 case UserScale_Restore:
1972 m_xUserScale =
1973 m_yUserScale = 1.0;
1974 break;
1975
1976 case AxisMirror_Vertic:
1977 m_yAxisReversed = !m_yAxisReversed;
1978 break;
1979 case AxisMirror_Horiz:
1980 m_xAxisReversed = !m_xAxisReversed;
1981 break;
1982
960a83cc 1983#if wxUSE_COLOURDLG
0f0c61d0
VZ
1984 case Colour_TextForeground:
1985 m_colourForeground = SelectColour();
1986 break;
1987 case Colour_TextBackground:
1988 m_colourBackground = SelectColour();
1989 break;
1990 case Colour_Background:
1991 {
1992 wxColour col = SelectColour();
a1b806b9 1993 if ( col.IsOk() )
0f0c61d0
VZ
1994 {
1995 m_backgroundBrush.SetColour(col);
1996 }
1997 }
1998 break;
960a83cc
WS
1999#endif // wxUSE_COLOURDLG
2000
0f0c61d0
VZ
2001 case Colour_BackgroundMode:
2002 m_backgroundMode = m_backgroundMode == wxSOLID ? wxTRANSPARENT
2003 : wxSOLID;
2004 break;
2005
1edc9f45
RD
2006 case Colour_TextureBackgound:
2007 m_textureBackground = ! m_textureBackground;
2008 break;
2009
0f0c61d0
VZ
2010 default:
2011 // skip Refresh()
2012 return;
aba99005 2013 }
0f0c61d0 2014
1e7fd311 2015 m_canvas->Refresh();
aba99005
RR
2016}
2017
220af862 2018void MyFrame::PrepareDC(wxDC& dc)
aba99005 2019{
0f0c61d0 2020 dc.SetLogicalOrigin( m_xLogicalOrigin, m_yLogicalOrigin );
428db2ea 2021 dc.SetAxisOrientation( !m_xAxisReversed, m_yAxisReversed );
fb576291
VZ
2022 dc.SetUserScale( m_xUserScale, m_yUserScale );
2023 dc.SetMapMode( m_mapMode );
220af862
VZ
2024}
2025
960a83cc 2026#if wxUSE_COLOURDLG
220af862 2027wxColour MyFrame::SelectColour()
0f0c61d0
VZ
2028{
2029 wxColour col;
2030 wxColourData data;
2031 wxColourDialog dialog(this, &data);
2032
2033 if ( dialog.ShowModal() == wxID_OK )
2034 {
428db2ea 2035 col = dialog.GetColourData().GetColour();
0f0c61d0
VZ
2036 }
2037
2038 return col;
aba99005 2039}
960a83cc 2040#endif // wxUSE_COLOURDLG