X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f88c1a172efd0391ad65621898e6a8823160c4f9..8a1e6413fe30df36ab9d458fd70d5634bc7f8457:/samples/drawing/drawing.cpp diff --git a/samples/drawing/drawing.cpp b/samples/drawing/drawing.cpp index 5c71ee2b09..c3c0b3796a 100644 --- a/samples/drawing/drawing.cpp +++ b/samples/drawing/drawing.cpp @@ -115,6 +115,7 @@ public: // event handlers (these functions should _not_ be virtual) void OnQuit(wxCommandEvent& event); void OnAbout(wxCommandEvent& event); + void OnClip(wxCommandEvent& event); void OnShow(wxCommandEvent &event); void OnOption(wxCommandEvent &event); @@ -151,6 +152,9 @@ public: void Show(ScreenToShow show) { m_show = show; Refresh(); } + // set or remove the clipping region + void Clip(bool clip) { m_clip = clip; Refresh(); } + protected: void DrawTestLines( int x, int y, int width, wxDC &dc ); void DrawTestPoly(wxDC& dc); @@ -170,6 +174,7 @@ private: ScreenToShow m_show; wxBitmap m_smile_bmp; wxIcon m_std_icon; + bool m_clip; DECLARE_EVENT_TABLE() }; @@ -197,6 +202,8 @@ enum File_ShowCircles, MenuShow_Last = File_ShowCircles, + File_Clip, + MenuOption_First, MapMode_Text = MenuOption_First, @@ -370,6 +377,7 @@ MyCanvas::MyCanvas(MyFrame *parent) m_show = Show_Default; m_smile_bmp = wxBitmap(smile_xpm); m_std_icon = wxArtProvider::GetIcon(wxART_INFORMATION); + m_clip = FALSE; } void MyCanvas::DrawTestBrushes(wxDC& dc) @@ -878,9 +886,10 @@ void MyCanvas::DrawRegionsHelper(wxDC& dc, wxCoord x, bool firstTime) dc.DestroyClippingRegion(); wxRegion region(x + 110, y + 20, 100, 270); +#if !defined(__WXMOTIF__) && !defined(__WXMAC__) if ( !firstTime ) region.Offset(10, 10); - +#endif dc.SetClippingRegion(region); dc.SetBrush( *wxGREY_BRUSH ); @@ -918,11 +927,15 @@ void MyCanvas::OnPaint(wxPaintEvent &WXUNUSED(event)) } } + if ( m_clip ) + dc.SetClippingRegion(100, 100, 100, 100); + dc.Clear(); - if ( m_owner->m_textureBackground) { + if ( m_owner->m_textureBackground ) + { dc.SetPen(*wxMEDIUM_GREY_PEN); - for (int i=0; i<200; i++) + for ( int i = 0; i < 200; i++ ) dc.DrawLine(0, i*10, i*10, 0); } @@ -993,6 +1006,7 @@ void MyCanvas::OnMouseMove(wxMouseEvent &event) BEGIN_EVENT_TABLE(MyFrame, wxFrame) EVT_MENU (File_Quit, MyFrame::OnQuit) EVT_MENU (File_About, MyFrame::OnAbout) + EVT_MENU (File_Clip, MyFrame::OnClip) EVT_MENU_RANGE(MenuShow_First, MenuShow_Last, MyFrame::OnShow) @@ -1018,6 +1032,8 @@ MyFrame::MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size) menuFile->Append(File_ShowRegions, "Re&gions screen\tF8"); menuFile->Append(File_ShowCircles, "&Circles screen\tF9"); menuFile->AppendSeparator(); + menuFile->AppendCheckItem(File_Clip, "&Clip\tCtrl-C", "Clip/unclip drawing"); + menuFile->AppendSeparator(); menuFile->Append(File_About, "&About...\tCtrl-A", "Show about dialog"); menuFile->AppendSeparator(); menuFile->Append(File_Quit, "E&xit\tAlt-X", "Quit this program"); @@ -1109,6 +1125,11 @@ void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event)) wxMessageBox(msg, "About Drawing", wxOK | wxICON_INFORMATION, this); } +void MyFrame::OnClip(wxCommandEvent& event) +{ + m_canvas->Clip(event.IsChecked()); +} + void MyFrame::OnShow(wxCommandEvent& event) { m_canvas->Show((ScreenToShow)(event.GetId() - MenuShow_First));