]> git.saurik.com Git - wxWidgets.git/blobdiff - samples/drawing/drawing.cpp
getting rid of warnings
[wxWidgets.git] / samples / drawing / drawing.cpp
index 5c71ee2b096971e5c04c2ddd013dd27ca761bc76..c3c0b3796adcfcdcb89f77119f4b93b117d5e53c 100644 (file)
@@ -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));