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.20 2001/01/01 10:14:34 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 OnInvertValues (wxCommandEvent& event);
\r
70 void OnSquare (wxCommandEvent& event);
\r
71 void OnSquareRoot (wxCommandEvent& event);
\r
72 void OnLog (wxCommandEvent& event);
\r
73 void OnExp (wxCommandEvent& event);
\r
74 void OnFourier (wxCommandEvent& event);
\r
75 void OnInverseFourier (wxCommandEvent& event);
\r
77 void OnFFT (wxCommandEvent& event);
\r
78 void OnIFFT (wxCommandEvent& event);
\r
80 void OnMagnitude (wxCommandEvent& event);
\r
81 void OnPhase (wxCommandEvent& event);
\r
82 void OnScaleAuto (wxCommandEvent& event);
83 void OnScaleMinMax (wxCommandEvent& event);
84 void OnPlotRow (wxCommandEvent& event);
\r
85 void OnPlotCol (wxCommandEvent& event);
\r
86 void OnCompareRow (wxCommandEvent& event);
\r
87 void OnCompareCol (wxCommandEvent& event);
\r
92 ImageFileDocument* GetDocument(void)
93 { return dynamic_cast<ImageFileDocument*>(wxView::GetDocument()); }
98 class ImageFileCanvas: public wxScrolledWindow
105 ImageFileView* m_pView;
107 ImageFileCanvas (ImageFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
108 virtual void OnDraw(wxDC& dc);
109 void OnMouseEvent(wxMouseEvent& event);
111 void DrawRubberBandCursor (wxDC& dc, int x, int y);
\r
112 bool GetCurrentCursor (int& x, int& y);
\r
114 DECLARE_EVENT_TABLE()
118 class ProjectionFileCanvas;
119 class ProjectionFileView : public wxView
121 DECLARE_DYNAMIC_CLASS(ProjectionFileView)
123 wxMemoryDC m_memoryDC;
127 ProjectionFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
128 wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
130 ProjectionFileCanvas *m_canvas;
135 int m_iDefaultFilter;
136 int m_iDefaultFilterMethod;
137 double m_dDefaultFilterParam;
138 int m_iDefaultFilterGeneration;
139 int m_iDefaultZeropad;
140 int m_iDefaultInterpolation;
141 int m_iDefaultInterpParam;
142 int m_iDefaultBackprojector;
146 ProjectionFileView(void);
147 virtual ~ProjectionFileView(void);
149 bool OnCreate(wxDocument *doc, long flags);
150 void OnDraw(wxDC* dc);
151 void OnUpdate(wxView *sender, wxObject *hint = NULL);
152 bool OnClose (bool deleteWindow = true);
153 void OnProperties (wxCommandEvent& event);
154 void OnReconstruct (wxCommandEvent& event);
156 wxFrame* getFrame ()
\r
157 { return m_frame; }
\r
159 ProjectionFileDocument* GetDocument(void)
160 { return dynamic_cast<ProjectionFileDocument*>(wxView::GetDocument()); }
161 DECLARE_EVENT_TABLE()
164 class ProjectionFileCanvas: public wxScrolledWindow
167 ProjectionFileView* m_pView;
169 ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
170 virtual void OnDraw(wxDC& dc);
175 class PhantomView : public wxView
177 DECLARE_DYNAMIC_CLASS(PhantomView)
180 PhantomCanvas *CreateCanvas(wxView *view, wxFrame *parent);
181 wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
183 PhantomCanvas *m_canvas;
188 int m_iDefaultNSample;
189 int m_iDefaultGeometry;
191 double m_dDefaultRotation;
192 double m_dDefaultFocalLength;
193 double m_dDefaultFieldOfView;
197 virtual ~PhantomView(void);
199 bool OnCreate(wxDocument *doc, long flags);
200 void OnUpdate(wxView *sender, wxObject *hint = NULL);
201 bool OnClose (bool deleteWindow = true);
202 void OnDraw(wxDC* dc);
203 void OnProperties (wxCommandEvent& event);
204 void OnRasterize (wxCommandEvent& event);
205 void OnProjections (wxCommandEvent& event);
207 PhantomDocument* GetDocument(void)
208 { return dynamic_cast<PhantomDocument*>(wxView::GetDocument()); }
210 DECLARE_EVENT_TABLE()
213 class PhantomCanvas: public wxScrolledWindow
216 PhantomView* m_pView;
218 PhantomCanvas (PhantomView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
220 virtual void OnDraw(wxDC& dc);
224 class PlotFileCanvas;
225 class PlotFileView : public wxView
227 DECLARE_DYNAMIC_CLASS(PlotFileView)
230 PlotFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
231 wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
233 PlotFileCanvas *m_canvas;
236 bool m_bMinSpecified;
\r
237 bool m_bMaxSpecified;
\r
238 double m_dMinPixel;
\r
239 double m_dMaxPixel;
\r
240 double m_dAutoScaleFactor;
\r
244 virtual ~PlotFileView(void);
246 bool OnCreate(wxDocument *doc, long flags);
247 void OnDraw(wxDC* dc);
248 void OnUpdate(wxView *sender, wxObject *hint = NULL);
249 bool OnClose (bool deleteWindow = true);
250 void OnProperties (wxCommandEvent& event);
251 void OnScaleAuto (wxCommandEvent& event);
\r
252 void OnScaleMinMax (wxCommandEvent& event);
\r
257 PlotFileDocument* GetDocument(void)
258 { return dynamic_cast<PlotFileDocument*>(wxView::GetDocument()); }
260 DECLARE_EVENT_TABLE()
263 class PlotFileCanvas: public wxScrolledWindow
266 PlotFileView* m_pView;
268 PlotFileCanvas (PlotFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
269 virtual void OnDraw(wxDC& dc);