** Date Started: July 2000
**
** This is part of the CTSim program
-** Copyright (C) 1983-2000 Kevin Rosenberg
+** Copyright (c) 1983-2001 Kevin Rosenberg
**
-** $Id: views.h,v 1.27 2001/01/20 08:10:33 kevin Exp $
+** $Id: views.h,v 1.38 2001/01/28 22:45:54 kevin Exp $
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License (version 2) as
class ImageFileCanvas;
class ImageFileView : public wxView
{
+private:
DECLARE_DYNAMIC_CLASS(ImageFileView)
- wxMemoryDC m_memoryDC;
+ wxMemoryDC m_memoryDC;
wxBitmap m_bitmap;
+ wxMenu* m_pMenuAnalyze;
-private:
- ImageFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
- wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
+ ImageFileCanvas *CreateCanvas (wxFrame* parent);
+#if CTSIM_MDI
+ wxDocMDIChildFrame* m_pFrame;
+ wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#else
+ wxDocChildFrame* m_pFrame;
+ wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#endif
- ImageFileCanvas *m_canvas;
- wxFrame *m_frame;
+ ImageFileCanvas *m_pCanvas;
+ wxMenu* m_pFileMenu;
bool m_bMinSpecified;
bool m_bMaxSpecified;
double m_dMinPixel;
int m_iDefaultExportFormatID;
- wxFrame* getFrameForChild()
+ wxWindow* getFrameForChild()
#if CTSIM_MDI
{ return theApp->getMainFrame(); }
#else
- { return m_frame; }
+ { return m_pFrame; }
#endif
public:
- ImageFileView(void);
- virtual ~ImageFileView(void);
-
+ ImageFileView();
+ virtual ~ImageFileView();
+ void canvasClosed()
+ { m_pCanvas = NULL; m_pFrame = NULL; }
+
+ wxMenu* getFileMenu()
+ { return m_pFileMenu; }
+
bool OnCreate(wxDocument *doc, long flags);
void OnDraw(wxDC* dc);
void OnUpdate(wxView *sender, wxObject *hint = NULL);
void OnCompareRow (wxCommandEvent& event);
void OnCompareCol (wxCommandEvent& event);
- wxFrame* getFrame()
- { return m_frame; }
-
- ImageFileDocument* GetDocument(void)
+#if CTSIM_MDI
+ wxDocMDIChildFrame* getFrame() { return m_pFrame; }
+#else
+ wxDocChildFrame* getFrame() { return m_pFrame; }
+#endif
+
+ wxMenu* getMenuAnalyze() { return m_pMenuAnalyze; }
+
+ ImageFileDocument* GetDocument()
{ return dynamic_cast<ImageFileDocument*>(wxView::GetDocument()); }
DECLARE_EVENT_TABLE()
class ImageFileCanvas: public wxScrolledWindow
{
private:
-
+ ImageFileView* m_pView;
+
int m_xCursor;
int m_yCursor;
- ImageFileView* m_pView;
public:
ImageFileCanvas (ImageFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
- virtual ~ImageFileCanvas()
- {}
+ virtual ~ImageFileCanvas();
virtual void OnDraw(wxDC& dc);
void OnMouseEvent(wxMouseEvent& event);
bool GetCurrentCursor (int& x, int& y);
virtual wxSize GetBestSize() const;
+ void setView(ImageFileView* pView)
+ { m_pView = pView; }
+
DECLARE_EVENT_TABLE()
};
wxBitmap m_bitmap;
private:
- ProjectionFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
- wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
+ ProjectionFileCanvas *CreateCanvas (wxFrame* parent);
+#if CTSIM_MDI
+ wxDocMDIChildFrame* m_pFrame;
+ wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#else
+ wxDocChildFrame* m_pFrame;
+ wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#endif
- ProjectionFileCanvas *m_canvas;
- wxFrame *m_frame;
+ ProjectionFileCanvas *m_pCanvas;
+ wxMenu* m_pFileMenu;
int m_iDefaultNX;
int m_iDefaultNY;
int m_iDefaultPolarInterpolation;
int m_iDefaultPolarZeropad;
- wxFrame* getFrameForChild()
+ wxWindow* getFrameForChild()
#if CTSIM_MDI
{ return theApp->getMainFrame(); }
#else
- { return m_frame; }
+ { return m_pFrame; }
#endif
public:
- ProjectionFileView(void);
- virtual ~ProjectionFileView(void);
+ ProjectionFileView();
+ virtual ~ProjectionFileView();
+ void canvasClosed()
+ { m_pCanvas = NULL; m_pFrame = NULL; }
bool OnCreate(wxDocument *doc, long flags);
void OnDraw(wxDC* dc);
void OnConvertPolar (wxCommandEvent& event);
void OnConvertFFTPolar (wxCommandEvent& event);
- wxFrame* getFrame ()
- { return m_frame; }
-
- ProjectionFileDocument* GetDocument(void)
+#if CTSIM_MDI
+ wxDocMDIChildFrame* getFrame() { return m_pFrame; }
+#else
+ wxDocChildFrame* getFrame() { return m_pFrame; }
+#endif
+ ProjectionFileCanvas* getCanvas() { return m_pCanvas; }
+
+ wxMenu* getFileMenu() { return m_pFileMenu; }
+
+ ProjectionFileDocument* GetDocument()
{ return dynamic_cast<ProjectionFileDocument*>(wxView::GetDocument()); }
DECLARE_EVENT_TABLE()
};
public:
ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
- virtual ~ProjectionFileCanvas()
- {}
+ virtual ~ProjectionFileCanvas() ;
virtual wxSize GetBestSize() const;
-
virtual void OnDraw(wxDC& dc);
+ void setView(ProjectionFileView* pView)
+ { m_pView = pView; }
};
class PhantomCanvas;
-class PhantomView : public wxView
+class PhantomFileView : public wxView
{
- DECLARE_DYNAMIC_CLASS(PhantomView)
-
private:
- PhantomCanvas *CreateCanvas(wxView *view, wxFrame *parent);
- wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
+ DECLARE_DYNAMIC_CLASS(PhantomFileView)
+ DECLARE_EVENT_TABLE()
+
+ PhantomCanvas *CreateCanvas (wxFrame* parent);
+#if CTSIM_MDI
+ wxDocMDIChildFrame* m_pFrame;
+ wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#else
+ wxDocChildFrame* m_pFrame;
+ wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#endif
- PhantomCanvas *m_canvas;
- wxFrame *m_frame;
+ PhantomCanvas *m_pCanvas;
+ wxMenu* m_pFileMenu;
int m_iDefaultNDet;
int m_iDefaultNView;
int m_iDefaultRasterNY;
int m_iDefaultRasterNSamples;
- wxFrame* getFrameForChild()
+ wxWindow* getFrameForChild()
#if CTSIM_MDI
{ return theApp->getMainFrame(); }
#else
- { return m_frame; }
+ { return m_pFrame; }
#endif
public:
- PhantomView(void);
- virtual ~PhantomView(void);
+ PhantomFileView();
+ virtual ~PhantomFileView();
+ void canvasClosed()
+ { m_pCanvas = NULL; m_pFrame = NULL; }
bool OnCreate(wxDocument *doc, long flags);
void OnUpdate(wxView *sender, wxObject *hint = NULL);
void OnRasterize (wxCommandEvent& event);
void OnProjections (wxCommandEvent& event);
- PhantomDocument* GetDocument(void)
- { return dynamic_cast<PhantomDocument*>(wxView::GetDocument()); }
+ PhantomFileDocument* GetDocument()
+ { return dynamic_cast<PhantomFileDocument*>(wxView::GetDocument()); }
- DECLARE_EVENT_TABLE()
+ wxMenu* getFileMenu() { return m_pFileMenu; }
+#if CTSIM_MDI
+ wxDocMDIChildFrame* getFrame() { return m_pFrame; }
+#else
+ wxDocChildFrame* getFrame() { return m_pFrame; }
+#endif
};
class PhantomCanvas: public wxScrolledWindow
{
private:
- PhantomView* m_pView;
+ PhantomFileView* m_pView;
public:
- PhantomCanvas (PhantomView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
- virtual ~PhantomCanvas()
- {}
+ PhantomCanvas (PhantomFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
+ virtual ~PhantomCanvas();
+ void setView(PhantomFileView* pView)
+ { m_pView = pView; }
virtual void OnDraw(wxDC& dc);
};
DECLARE_DYNAMIC_CLASS(PlotFileView)
private:
- PlotFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
- wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
+#if CTSIM_MDI
+ wxDocMDIChildFrame* m_pFrame;
+ wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#else
+ wxDocChildFrame* m_pFrame;
+ wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#endif
- PlotFileCanvas *m_canvas;
- wxFrame *m_frame;
+ PlotFileCanvas *m_pCanvas;
EZPlot* m_pEZPlot;
+ wxMenu* m_pFileMenu;
bool m_bMinSpecified;
bool m_bMaxSpecified;
double m_dMaxPixel;
double m_dAutoScaleFactor;
- wxFrame* getFrameForChild()
+ PlotFileCanvas *CreateCanvas (wxFrame* parent);
+ wxWindow* getFrameForChild()
#if CTSIM_MDI
{ return theApp->getMainFrame(); }
#else
- { return m_frame; }
+ { return m_pFrame; }
#endif
public:
- PlotFileView(void);
- virtual ~PlotFileView(void);
+ PlotFileView();
+ virtual ~PlotFileView();
+ void canvasClosed()
+ { m_pCanvas = NULL; m_pFrame = NULL; }
bool OnCreate(wxDocument *doc, long flags);
void OnDraw(wxDC* dc);
void OnScaleAuto (wxCommandEvent& event);
void OnScaleFull (wxCommandEvent& event);
- wxFrame* getFrame ()
- { return m_frame; }
+#if CTSIM_MDI
+ wxDocMDIChildFrame* getFrame() { return m_pFrame; }
+#else
+ wxDocChildFrame* getFrame() { return m_pFrame; }
+#endif
- PlotFileDocument* GetDocument(void)
+ wxMenu* getFileMenu() { return m_pFileMenu; }
+ PlotFileDocument* GetDocument()
{ return dynamic_cast<PlotFileDocument*>(wxView::GetDocument()); }
DECLARE_EVENT_TABLE()
public:
PlotFileCanvas (PlotFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
- virtual ~PlotFileCanvas()
- {}
-
+ virtual ~PlotFileCanvas();
+
virtual void OnDraw(wxDC& dc);
+
+ void setView (PlotFileView* pView)
+ { m_pView = pView; }
+};
+
+
+class TextFileCanvas;
+class TextFileView: public wxView
+{
+private:
+ DECLARE_DYNAMIC_CLASS(TextFileView)
+
+#if CTSIM_MDI
+ wxDocMDIChildFrame* m_pFrame;
+ wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#else
+ wxDocChildFrame* m_pFrame;
+ wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
+#endif
+ wxMenu* m_pFileMenu;
+ TextFileCanvas *m_pCanvas;
+
+public:
+ TextFileView()
+ : wxView() , m_pFrame(0), m_pCanvas(0)
+ {}
+ ~TextFileView();
+ void canvasClosed()
+ { m_pFrame = NULL; }
+
+ bool OnCreate (wxDocument *doc, long flags);
+ void OnDraw (wxDC *dc);
+ void OnUpdate (wxView *sender, wxObject *hint = (wxObject *) NULL);
+ bool OnClose (bool deleteWindow = TRUE);
+
+ TextFileCanvas* getTextCtrl() { return m_pCanvas; }
+ wxMenu* getFileMenu() { return m_pFileMenu; }
+#if CTSIM_MDI
+ wxDocMDIChildFrame* getFrame() { return m_pFrame; }
+#else
+ wxDocChildFrame* getFrame() { return m_pFrame; }
+#endif
+};
+
+class TextFileCanvas: public wxTextCtrl
+{
+ TextFileView *m_pView;
+
+public:
+ TextFileCanvas (TextFileView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, long style);
+ ~TextFileCanvas ();
};