1 /*****************************************************************************
5 ** Purpose: Header file for View & Canvas routines of CTSim program
6 ** Programmer: Kevin Rosenberg
7 ** Date Started: July 2000
9 ** This is part of the CTSim program
10 ** Copyright (C) 1983-2000 Kevin Rosenberg
12 ** $Id: views.h,v 1.15 2000/12/21 03:40:58 kevin Exp $
14 ** This program is free software; you can redistribute it and/or modify
15 ** it under the terms of the GNU General Public License (version 2) as
16 ** published by the Free Software Foundation.
18 ** This program is distributed in the hope that it will be useful,
19 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
20 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 ** GNU General Public License for more details.
23 ** You should have received a copy of the GNU General Public License
24 ** along with this program; if not, write to the Free Software
25 ** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
26 ******************************************************************************/
37 #include "imagefile.h"
39 class ImageFileCanvas;
40 class ImageFileView : public wxView
42 DECLARE_DYNAMIC_CLASS(ImageFileView)
44 wxMemoryDC m_memoryDC;
48 ImageFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
49 wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
51 ImageFileCanvas *m_canvas;
57 double m_dAutoScaleFactor;
61 virtual ~ImageFileView(void);
63 bool OnCreate(wxDocument *doc, long flags);
64 void OnDraw(wxDC* dc);
65 void OnUpdate(wxView *sender, wxObject *hint = NULL);
66 bool OnClose (bool deleteWindow = true);
67 void OnProperties (wxCommandEvent& event);
68 void OnCompare (wxCommandEvent& event);
\r
69 void OnScaleAuto (wxCommandEvent& event);
70 void OnScaleMinMax (wxCommandEvent& event);
71 void OnPlotRow (wxCommandEvent& event);
\r
72 void OnPlotCol (wxCommandEvent& event);
\r
77 ImageFileDocument* GetDocument(void)
78 { return dynamic_cast<ImageFileDocument*>(wxView::GetDocument()); }
83 class ImageFileCanvas: public wxScrolledWindow
90 ImageFileView* m_pView;
92 ImageFileCanvas (ImageFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
93 virtual void OnDraw(wxDC& dc);
94 void OnMouseEvent(wxMouseEvent& event);
96 void DrawRubberBandCursor (wxDC& dc, int x, int y);
\r
97 bool GetCurrentCursor (int& x, int& y);
\r
103 class ProjectionFileCanvas;
104 class ProjectionFileView : public wxView
106 DECLARE_DYNAMIC_CLASS(ProjectionFileView)
108 wxMemoryDC m_memoryDC;
112 ProjectionFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
113 wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
115 ProjectionFileCanvas *m_canvas;
120 int m_iDefaultFilter;
121 int m_iDefaultFilterMethod;
122 double m_dDefaultFilterParam;
123 int m_iDefaultFilterGeneration;
124 int m_iDefaultZeropad;
125 int m_iDefaultInterpolation;
126 int m_iDefaultInterpParam;
127 int m_iDefaultBackprojector;
131 ProjectionFileView(void);
132 virtual ~ProjectionFileView(void);
134 bool OnCreate(wxDocument *doc, long flags);
135 void OnDraw(wxDC* dc);
136 void OnUpdate(wxView *sender, wxObject *hint = NULL);
137 bool OnClose (bool deleteWindow = true);
138 void OnProperties (wxCommandEvent& event);
139 void OnReconstruct (wxCommandEvent& event);
141 wxFrame* getFrame ()
\r
142 { return m_frame; }
\r
144 ProjectionFileDocument* GetDocument(void)
145 { return dynamic_cast<ProjectionFileDocument*>(wxView::GetDocument()); }
146 DECLARE_EVENT_TABLE()
149 class ProjectionFileCanvas: public wxScrolledWindow
152 ProjectionFileView* m_pView;
154 ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
155 virtual void OnDraw(wxDC& dc);
160 class PhantomView : public wxView
162 DECLARE_DYNAMIC_CLASS(PhantomView)
165 PhantomCanvas *CreateCanvas(wxView *view, wxFrame *parent);
166 wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
168 PhantomCanvas *m_canvas;
173 int m_iDefaultNSample;
174 int m_iDefaultGeometry;
176 double m_dDefaultRotation;
177 double m_dDefaultFocalLength;
178 double m_dDefaultFieldOfView;
182 virtual ~PhantomView(void);
184 bool OnCreate(wxDocument *doc, long flags);
185 void OnUpdate(wxView *sender, wxObject *hint = NULL);
186 bool OnClose (bool deleteWindow = true);
187 void OnDraw(wxDC* dc);
188 void OnProperties (wxCommandEvent& event);
189 void OnRasterize (wxCommandEvent& event);
190 void OnProjections (wxCommandEvent& event);
192 PhantomDocument* GetDocument(void)
193 { return dynamic_cast<PhantomDocument*>(wxView::GetDocument()); }
195 DECLARE_EVENT_TABLE()
198 class PhantomCanvas: public wxScrolledWindow
201 PhantomView* m_pView;
203 PhantomCanvas (PhantomView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
205 virtual void OnDraw(wxDC& dc);
209 class PlotFileCanvas;
210 class PlotFileView : public wxView
212 DECLARE_DYNAMIC_CLASS(PlotFileView)
215 PlotFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
216 wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
218 PlotFileCanvas *m_canvas;
220 bool m_bMinSpecified;
\r
221 bool m_bMaxSpecified;
\r
222 double m_dMinPixel;
\r
223 double m_dMaxPixel;
\r
224 double m_dAutoScaleFactor;
\r
228 virtual ~PlotFileView(void);
230 bool OnCreate(wxDocument *doc, long flags);
231 void OnDraw(wxDC* dc);
232 void OnUpdate(wxView *sender, wxObject *hint = NULL);
233 bool OnClose (bool deleteWindow = true);
234 void OnProperties (wxCommandEvent& event);
235 void OnScaleAuto (wxCommandEvent& event);
\r
236 void OnScaleMinMax (wxCommandEvent& event);
\r
241 PlotFileDocument* GetDocument(void)
242 { return dynamic_cast<PlotFileDocument*>(wxView::GetDocument()); }
244 DECLARE_EVENT_TABLE()
247 class PlotFileCanvas: public wxScrolledWindow
250 PlotFileView* m_pView;
252 PlotFileCanvas (PlotFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
253 virtual void OnDraw(wxDC& dc);