X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6bdf5153fef0772f7dca91c67073dee8f87e467d..f68e16c5fcf53c411742c8338a290addc5fb4b62:/samples/docview/view.h diff --git a/samples/docview/view.h b/samples/docview/view.h index b956daadeb..cb05b2ebcb 100644 --- a/samples/docview/view.h +++ b/samples/docview/view.h @@ -1,49 +1,73 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: view.h +// Name: samples/docview/view.h // Purpose: View classes // Author: Julian Smart -// Modified by: +// Modified by: Vadim Zeitlin: merge with the MDI version and general cleanup // Created: 04/01/98 // RCS-ID: $Id$ -// Copyright: (c) Julian Smart +// Copyright: (c) 1998 Julian Smart +// (c) 2008 Vadim Zeitlin // Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// -#ifndef __VIEW_H__ -#define __VIEW_H__ +#ifndef _WX_SAMPLES_DOCVIEW_VIEW_H_ +#define _WX_SAMPLES_DOCVIEW_VIEW_H_ #include "wx/docview.h" -class DrawingView; +// ---------------------------------------------------------------------------- +// Drawing view classes +// ---------------------------------------------------------------------------- + +// The window showing the drawing itself class MyCanvas : public wxScrolledWindow { public: - DrawingView* m_view; + // view may be NULL if we're not associated with one yet, but parent must + // be a valid pointer + MyCanvas(wxView *view, wxWindow *parent); + virtual ~MyCanvas(); - MyCanvas(DrawingView*, wxFrame*, const wxPoint& pos, const wxSize& size, const long style); virtual void OnDraw(wxDC& dc); -protected: + // in a normal multiple document application a canvas is associated with + // one view from the beginning until the end, but to support the single + // document mode in which all documents reuse the same MyApp::GetCanvas() + // we need to allow switching the canvas from one view to another one + + void SetView(wxView *view) + { + wxASSERT_MSG( !m_view, "shouldn't be already associated with a view" ); + + m_view = view; + } + + void ResetView() + { + wxASSERT_MSG( m_view, "should be associated with a view" ); + + m_view = NULL; + } + +private: void OnMouseEvent(wxMouseEvent& event); - DECLARE_EVENT_TABLE() -}; -class MyTextWindow: public wxTextCtrl -{ -public: - wxView* m_view; + wxView *m_view; + + // the segment being currently drawn or NULL if none + DoodleSegment *m_currentSegment; + + // the last mouse press position + wxPoint m_lastMousePos; - MyTextWindow(wxView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style); + DECLARE_EVENT_TABLE() }; +// The view using MyCanvas to show its contents class DrawingView : public wxView { public: - wxFrame* m_frame; - MyCanvas* m_canvas; - - DrawingView() { m_canvas = NULL; m_frame = NULL; }; - virtual ~DrawingView() {}; + DrawingView() { m_canvas = NULL; m_frame = NULL; } virtual bool OnCreate(wxDocument *doc, long flags); virtual void OnDraw(wxDC *dc); @@ -52,31 +76,99 @@ public: DrawingDocument* GetDocument(); -protected: +private: void OnCut(wxCommandEvent& event); -private: + wxFrame *m_frame; + MyCanvas *m_canvas; + DECLARE_EVENT_TABLE() DECLARE_DYNAMIC_CLASS(DrawingView) }; +// ---------------------------------------------------------------------------- +// Text view classes +// ---------------------------------------------------------------------------- + +// The view using a standard wxTextCtrl to show its contents class TextEditView : public wxView { public: - wxFrame* m_frame; - MyTextWindow* m_textsw; - - TextEditView(): wxView() { m_frame = NULL; m_textsw = NULL; } - virtual ~TextEditView() {} + TextEditView() : wxView() { m_frame = NULL; m_text = NULL; } virtual bool OnCreate(wxDocument *doc, long flags); virtual void OnDraw(wxDC *dc); - virtual void OnUpdate(wxView *sender, wxObject *hint = NULL); virtual bool OnClose(bool deleteWindow = true); - virtual bool ProcessEvent(wxEvent&); + + wxTextCtrl *GetText() const { return m_text; } private: + void OnCopy(wxCommandEvent& WXUNUSED(event)) { m_text->Copy(); } + void OnPaste(wxCommandEvent& WXUNUSED(event)) { m_text->Paste(); } + void OnSelectAll(wxCommandEvent& WXUNUSED(event)) { m_text->SelectAll(); } + + wxFrame *m_frame; + wxTextCtrl *m_text; + + DECLARE_EVENT_TABLE() DECLARE_DYNAMIC_CLASS(TextEditView) }; -#endif +// ---------------------------------------------------------------------------- +// ImageCanvas +// ---------------------------------------------------------------------------- + +class ImageCanvas : public wxScrolledWindow +{ +public: + ImageCanvas(wxView*, wxWindow* parent); + + virtual void OnDraw(wxDC& dc); + + // in a normal multiple document application a canvas is associated with + // one view from the beginning until the end, but to support the single + // document mode in which all documents reuse the same MyApp::GetCanvas() + // we need to allow switching the canvas from one view to another one + + void SetView(wxView* view) + { + wxASSERT_MSG( !m_view, "shouldn't be already associated with a view" ); + + m_view = view; + } + + void ResetView() + { + wxASSERT_MSG( m_view, "should be associated with a view" ); + + m_view = NULL; + } + +private: + wxView *m_view; +}; + +// ---------------------------------------------------------------------------- +// ImageView +// ---------------------------------------------------------------------------- + +class ImageView : public wxView +{ +public: + ImageView() : wxView(), m_frame(NULL) {} + + virtual bool OnCreate(wxDocument*, long flags); + virtual void OnDraw(wxDC*); + virtual bool OnClose(bool deleteWindow = true); + virtual void OnUpdate(wxView *sender, wxObject *hint = NULL); + + ImageDocument* GetDocument(); + +private: + wxFrame* m_frame; + ImageCanvas* m_canvas; + + DECLARE_DYNAMIC_CLASS(ImageView) +}; + +#endif // _WX_SAMPLES_DOCVIEW_VIEW_H_