X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ad813b00d5956f35f2b1585a276095e24ce8ad5a..c2b83fddb9b1f6ea32ce12051be4c28d742b6d05:/samples/docvwmdi/view.cpp diff --git a/samples/docvwmdi/view.cpp b/samples/docvwmdi/view.cpp index 80adc13467..6bb0129450 100644 --- a/samples/docvwmdi/view.cpp +++ b/samples/docvwmdi/view.cpp @@ -5,14 +5,10 @@ // Modified by: // Created: 04/01/98 // RCS-ID: $Id$ -// Copyright: (c) Julian Smart and Markus Holzem -// Licence: wxWindows license +// Copyright: (c) Julian Smart +// Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ -// #pragma implementation -#endif - // For compilers that support precompilation, includes "wx/wx.h". #include "wx/wxprec.h" @@ -46,19 +42,20 @@ END_EVENT_TABLE() // windows for displaying the view. bool DrawingView::OnCreate(wxDocument *doc, long WXUNUSED(flags) ) { - frame = wxGetApp().CreateChildFrame(doc, this, TRUE); - frame->SetTitle("DrawingView"); + frame = wxGetApp().CreateChildFrame(doc, this, true); + frame->SetTitle(_T("DrawingView")); canvas = GetMainFrame()->CreateCanvas(this, frame); #ifdef __X__ // X seems to require a forced resize int x, y; frame->GetSize(&x, &y); - frame->SetSize(-1, -1, x, y); + frame->SetSize(wxDefaultCoord, wxDefaultCoord, x, y); #endif - frame->Show(TRUE); + frame->Show(true); + Activate(true); - return TRUE; + return true; } // Sneakily gets used for default print/preview @@ -68,12 +65,12 @@ void DrawingView::OnDraw(wxDC *dc) dc->SetFont(*wxNORMAL_FONT); dc->SetPen(*wxBLACK_PEN); - wxNode *node = ((DrawingDocument *)GetDocument())->GetDoodleSegments().First(); + wxList::compatibility_iterator node = ((DrawingDocument *)GetDocument())->GetDoodleSegments().GetFirst(); while (node) { - DoodleSegment *seg = (DoodleSegment *)node->Data(); + DoodleSegment *seg = (DoodleSegment *)node->GetData(); seg->Draw(dc); - node = node->Next(); + node = node->GetNext(); } } @@ -101,11 +98,11 @@ void DrawingView::OnUpdate(wxView *WXUNUSED(sender), wxObject *WXUNUSED(hint)) bool DrawingView::OnClose(bool deleteWindow) { if (!GetDocument()->Close()) - return FALSE; + return false; // Clear the canvas in case we're in single-window mode, // and the canvas stays. - canvas->Clear(); + canvas->ClearBackground(); canvas->view = (wxView *) NULL; canvas = (MyCanvas *) NULL; @@ -115,44 +112,44 @@ bool DrawingView::OnClose(bool deleteWindow) SetFrame((wxFrame*)NULL); - Activate(FALSE); - + Activate(false); + if (deleteWindow) { delete frame; - return TRUE; + return true; } - return TRUE; + return true; } void DrawingView::OnCut(wxCommandEvent& WXUNUSED(event) ) { DrawingDocument *doc = (DrawingDocument *)GetDocument(); - doc->GetCommandProcessor()->Submit(new DrawingCommand((const wxString) "Cut Last Segment", DOODLE_CUT, doc, (DoodleSegment *) NULL)); + doc->GetCommandProcessor()->Submit(new DrawingCommand(_T("Cut Last Segment"), DOODLE_CUT, doc, (DoodleSegment *) NULL)); } IMPLEMENT_DYNAMIC_CLASS(TextEditView, wxView) bool TextEditView::OnCreate(wxDocument *doc, long WXUNUSED(flags) ) { - frame = wxGetApp().CreateChildFrame(doc, this, FALSE); + frame = wxGetApp().CreateChildFrame(doc, this, false); int width, height; frame->GetClientSize(&width, &height); textsw = new MyTextWindow(this, frame, wxPoint(0, 0), wxSize(width, height), wxTE_MULTILINE); - frame->SetTitle("TextEditView"); + frame->SetTitle(_T("TextEditView")); #ifdef __X__ // X seems to require a forced resize int x, y; frame->GetSize(&x, &y); - frame->SetSize(-1, -1, x, y); + frame->SetSize(wxDefaultCoord, wxDefaultCoord, x, y); #endif - frame->Show(TRUE); - Activate(TRUE); - - return TRUE; + frame->Show(true); + Activate(true); + + return true; } // Handled by wxTextWindow @@ -167,16 +164,16 @@ void TextEditView::OnUpdate(wxView *WXUNUSED(sender), wxObject *WXUNUSED(hint) ) bool TextEditView::OnClose(bool deleteWindow) { if (!GetDocument()->Close()) - return FALSE; - - Activate(FALSE); + return false; + + Activate(false); if (deleteWindow) { delete frame; - return TRUE; + return true; } - return TRUE; + return true; } /* @@ -188,8 +185,8 @@ BEGIN_EVENT_TABLE(MyCanvas, wxScrolledWindow) END_EVENT_TABLE() // Define a constructor for my canvas -MyCanvas::MyCanvas(wxView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, long style): - wxScrolledWindow(frame, -1, pos, size, style) +MyCanvas::MyCanvas(wxView *v, wxMDIChildFrame *frame, const wxPoint& pos, const wxSize& size, long style): + wxScrolledWindow(frame, wxID_ANY, pos, size, style) { view = v; } @@ -207,7 +204,7 @@ void MyCanvas::OnMouseEvent(wxMouseEvent& event) { if (!view) return; - + static DoodleSegment *currentSegment = (DoodleSegment *) NULL; wxClientDC dc(this); @@ -219,7 +216,7 @@ void MyCanvas::OnMouseEvent(wxMouseEvent& event) if (currentSegment && event.LeftUp()) { - if (currentSegment->lines.Number() == 0) + if (currentSegment->lines.GetCount() == 0) { delete currentSegment; currentSegment = (DoodleSegment *) NULL; @@ -229,25 +226,25 @@ void MyCanvas::OnMouseEvent(wxMouseEvent& event) // We've got a valid segment on mouse left up, so store it. DrawingDocument *doc = (DrawingDocument *)view->GetDocument(); - doc->GetCommandProcessor()->Submit(new DrawingCommand("Add Segment", DOODLE_ADD, doc, currentSegment)); + doc->GetCommandProcessor()->Submit(new DrawingCommand(_T("Add Segment"), DOODLE_ADD, doc, currentSegment)); - view->GetDocument()->Modify(TRUE); + view->GetDocument()->Modify(true); currentSegment = (DoodleSegment *) NULL; } } - + if (xpos > -1 && ypos > -1 && event.Dragging()) { if (!currentSegment) currentSegment = new DoodleSegment; DoodleLine *newLine = new DoodleLine; - newLine->x1 = (long)xpos; + newLine->x1 = (long)xpos; newLine->y1 = (long)ypos; - newLine->x2 = pt.x; + newLine->x2 = pt.x; newLine->y2 = pt.y; currentSegment->lines.Append(newLine); - + dc.DrawLine( (long)xpos, (long)ypos, pt.x, pt.y); } xpos = pt.x; @@ -255,8 +252,8 @@ void MyCanvas::OnMouseEvent(wxMouseEvent& event) } // Define a constructor for my text subwindow -MyTextWindow::MyTextWindow(wxView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, long style): - wxTextCtrl(frame, -1, "", pos, size, style) +MyTextWindow::MyTextWindow(wxView *v, wxMDIChildFrame *frame, const wxPoint& pos, const wxSize& size, long style): + wxTextCtrl(frame, wxID_ANY, _T(""), pos, size, style) { view = v; }