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-2001 Kevin Rosenberg
12 ** $Id: views.h,v 1.49 2001/03/11 06:34:37 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"
38 #include "threadrecon.h"
41 #include "graph3dview.h"
44 class ImageFileCanvas;
45 class ImageFileView : public wxView
48 DECLARE_DYNAMIC_CLASS(ImageFileView)
50 wxMemoryDC m_memoryDC;
52 wxMenu* m_pMenuAnalyze;
54 ImageFileCanvas *CreateCanvas (wxFrame* parent);
56 wxDocMDIChildFrame* m_pFrame;
57 wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
59 wxDocChildFrame* m_pFrame;
60 wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
63 ImageFileCanvas *m_pCanvas;
69 double m_dAutoScaleFactor;
71 int m_iDefaultExportFormatID;
73 wxWindow* getFrameForChild()
75 { return theApp->getMainFrame(); }
82 virtual ~ImageFileView();
84 { m_pCanvas = NULL; m_pFrame = NULL; }
87 { return m_pFileMenu; }
89 bool OnCreate(wxDocument *doc, long flags);
90 void OnDraw(wxDC* dc);
91 void OnUpdate(wxView *sender, wxObject *hint = NULL);
92 bool OnClose (bool deleteWindow = true);
94 void OnRevert (wxCommandEvent& event);
95 void OnExport (wxCommandEvent& event);
96 void OnProperties (wxCommandEvent& event);
98 void OnCompare (wxCommandEvent& event);
99 void OnScaleSize (wxCommandEvent& event);
100 void OnInvertValues (wxCommandEvent& event);
101 void OnSquare (wxCommandEvent& event);
102 void OnSquareRoot (wxCommandEvent& event);
103 void OnLog (wxCommandEvent& event);
104 void OnExp (wxCommandEvent& event);
105 void OnAdd (wxCommandEvent& event);
106 void OnSubtract (wxCommandEvent& event);
107 void OnMultiply (wxCommandEvent& event);
108 void OnDivide (wxCommandEvent& event);
109 void OnFourier (wxCommandEvent& event);
110 void OnInverseFourier (wxCommandEvent& event);
111 void OnShuffleNaturalToFourierOrder (wxCommandEvent& event);
112 void OnShuffleFourierToNaturalOrder (wxCommandEvent& event);
114 void OnConvert3d (wxCommandEvent& event);
118 void OnFFT (wxCommandEvent& event);
119 void OnIFFT (wxCommandEvent& event);
120 void OnFFTRows (wxCommandEvent& event);
121 void OnIFFTRows (wxCommandEvent& event);
122 void OnFFTCols (wxCommandEvent& event);
123 void OnIFFTCols (wxCommandEvent& event);
126 void OnMagnitude (wxCommandEvent& event);
127 void OnPhase (wxCommandEvent& event);
129 void OnScaleAuto (wxCommandEvent& event);
130 void OnScaleMinMax (wxCommandEvent& event);
131 void OnScaleFull (wxCommandEvent& event);
132 void OnPlotRow (wxCommandEvent& event);
133 void OnPlotCol (wxCommandEvent& event);
135 void OnPlotFFTRow (wxCommandEvent& event);
136 void OnPlotFFTCol (wxCommandEvent& event);
138 void OnPlotHistogram (wxCommandEvent& event);
139 void OnCompareRow (wxCommandEvent& event);
140 void OnCompareCol (wxCommandEvent& event);
143 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
145 wxDocChildFrame* getFrame() { return m_pFrame; }
148 wxMenu* getMenuAnalyze() { return m_pMenuAnalyze; }
150 ImageFileDocument* GetDocument()
151 { return dynamic_cast<ImageFileDocument*>(wxView::GetDocument()); }
153 DECLARE_EVENT_TABLE()
156 class ImageFileCanvas: public wxScrolledWindow
159 ImageFileView* m_pView;
165 ImageFileCanvas (ImageFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
166 virtual ~ImageFileCanvas();
168 virtual void OnDraw(wxDC& dc);
169 void OnChar(wxKeyEvent& event);
170 void OnMouseEvent(wxMouseEvent& event);
171 void DrawRubberBandCursor (wxDC& dc, int x, int y);
172 bool GetCurrentCursor (int& x, int& y);
174 virtual wxSize GetBestSize() const;
175 void setView(ImageFileView* pView)
179 DECLARE_EVENT_TABLE()
183 class ProjectionFileCanvas;
184 class ProjectionFileView : public wxView
187 DECLARE_DYNAMIC_CLASS(ProjectionFileView)
189 wxMemoryDC m_memoryDC;
192 ProjectionFileCanvas *CreateCanvas (wxFrame* parent);
194 wxDocMDIChildFrame* m_pFrame;
195 wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
197 wxDocChildFrame* m_pFrame;
198 wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
201 ProjectionFileCanvas *m_pCanvas;
206 int m_iDefaultFilter;
207 int m_iDefaultFilterMethod;
208 double m_dDefaultFilterParam;
209 int m_iDefaultFilterGeneration;
210 int m_iDefaultZeropad;
211 int m_iDefaultInterpolation;
212 int m_iDefaultInterpParam;
213 int m_iDefaultBackprojector;
216 int m_iDefaultPolarNX;
217 int m_iDefaultPolarNY;
218 int m_iDefaultPolarInterpolation;
219 int m_iDefaultPolarZeropad;
221 wxWindow* getFrameForChild()
223 { return theApp->getMainFrame(); }
229 ProjectionFileView();
230 virtual ~ProjectionFileView();
232 { m_pCanvas = NULL; m_pFrame = NULL; }
234 bool OnCreate(wxDocument *doc, long flags);
235 void OnDraw(wxDC* dc);
236 void OnUpdate(wxView *sender, wxObject *hint = NULL);
237 bool OnClose (bool deleteWindow = true);
238 void OnProperties (wxCommandEvent& event);
239 void OnReconstructFBP (wxCommandEvent& event);
240 void OnReconstructFourier (wxCommandEvent& event);
241 void OnConvertPolar (wxCommandEvent& event);
242 void OnConvertFFTPolar (wxCommandEvent& event);
243 void OnPlotTThetaSampling (wxCommandEvent& event);
244 void OnConvertParallel (wxCommandEvent& event);
245 void OnArtifactReduction (wxCommandEvent& event);
248 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
250 wxDocChildFrame* getFrame() { return m_pFrame; }
252 ProjectionFileCanvas* getCanvas() { return m_pCanvas; }
254 wxMenu* getFileMenu() { return m_pFileMenu; }
256 ProjectionFileDocument* GetDocument()
257 { return dynamic_cast<ProjectionFileDocument*>(wxView::GetDocument()); }
258 DECLARE_EVENT_TABLE()
261 class ProjectionFileCanvas: public wxScrolledWindow
264 ProjectionFileView* m_pView;
267 ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
268 virtual ~ProjectionFileCanvas() ;
270 virtual wxSize GetBestSize() const;
271 virtual void OnDraw(wxDC& dc);
272 void setView(ProjectionFileView* pView)
278 class PhantomFileView : public wxView
281 DECLARE_DYNAMIC_CLASS(PhantomFileView)
282 DECLARE_EVENT_TABLE()
284 PhantomCanvas *CreateCanvas (wxFrame* parent);
286 wxDocMDIChildFrame* m_pFrame;
287 wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
289 wxDocChildFrame* m_pFrame;
290 wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
293 PhantomCanvas *m_pCanvas;
298 int m_iDefaultNSample;
299 int m_iDefaultGeometry;
301 double m_dDefaultRotation;
302 double m_dDefaultFocalLength;
303 double m_dDefaultCenterDetectorLength;
304 double m_dDefaultViewRatio;
305 double m_dDefaultScanRatio;
307 int m_iDefaultRasterNX;
308 int m_iDefaultRasterNY;
309 int m_iDefaultRasterNSamples;
310 double m_dDefaultRasterViewRatio;
312 wxWindow* getFrameForChild()
314 { return theApp->getMainFrame(); }
321 virtual ~PhantomFileView();
323 { m_pCanvas = NULL; m_pFrame = NULL; }
325 bool OnCreate(wxDocument *doc, long flags);
326 void OnUpdate(wxView *sender, wxObject *hint = NULL);
327 bool OnClose (bool deleteWindow = true);
328 void OnDraw(wxDC* dc);
329 void OnProperties (wxCommandEvent& event);
330 void OnRasterize (wxCommandEvent& event);
331 void OnProjections (wxCommandEvent& event);
333 PhantomFileDocument* GetDocument()
334 { return dynamic_cast<PhantomFileDocument*>(wxView::GetDocument()); }
336 wxMenu* getFileMenu() { return m_pFileMenu; }
338 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
340 wxDocChildFrame* getFrame() { return m_pFrame; }
344 class PhantomCanvas: public wxScrolledWindow
347 PhantomFileView* m_pView;
350 PhantomCanvas (PhantomFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
351 virtual ~PhantomCanvas();
353 virtual wxSize GetBestSize() const;
354 void setView(PhantomFileView* pView)
356 virtual void OnDraw(wxDC& dc);
359 class PlotFileCanvas;
360 class PlotFileView : public wxView
362 DECLARE_DYNAMIC_CLASS(PlotFileView)
366 wxDocMDIChildFrame* m_pFrame;
367 wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
369 wxDocChildFrame* m_pFrame;
370 wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
373 PlotFileCanvas *m_pCanvas;
377 bool m_bMinSpecified;
378 bool m_bMaxSpecified;
381 double m_dAutoScaleFactor;
383 PlotFileCanvas *CreateCanvas (wxFrame* parent);
384 wxWindow* getFrameForChild()
386 { return theApp->getMainFrame(); }
393 virtual ~PlotFileView();
395 { m_pCanvas = NULL; m_pFrame = NULL; }
397 bool OnCreate(wxDocument *doc, long flags);
398 void OnDraw(wxDC* dc);
399 void OnUpdate(wxView *sender, wxObject *hint = NULL);
400 bool OnClose (bool deleteWindow = true);
402 void OnProperties (wxCommandEvent& event);
403 void OnScaleMinMax (wxCommandEvent& event);
404 void OnScaleAuto (wxCommandEvent& event);
405 void OnScaleFull (wxCommandEvent& event);
408 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
410 wxDocChildFrame* getFrame() { return m_pFrame; }
413 wxMenu* getFileMenu() { return m_pFileMenu; }
414 PlotFileDocument* GetDocument()
415 { return dynamic_cast<PlotFileDocument*>(wxView::GetDocument()); }
417 DECLARE_EVENT_TABLE()
420 class PlotFileCanvas: public wxScrolledWindow
423 PlotFileView* m_pView;
426 PlotFileCanvas (PlotFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
427 virtual ~PlotFileCanvas();
429 virtual void OnDraw(wxDC& dc);
431 void setView (PlotFileView* pView)
436 class TextFileCanvas;
437 class TextFileView: public wxView
440 DECLARE_DYNAMIC_CLASS(TextFileView)
443 wxDocMDIChildFrame* m_pFrame;
444 wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
446 wxDocChildFrame* m_pFrame;
447 wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
450 TextFileCanvas *m_pCanvas;
454 : wxView() , m_pFrame(0), m_pCanvas(0)
460 bool OnCreate (wxDocument *doc, long flags);
461 void OnDraw (wxDC *dc);
462 void OnUpdate (wxView *sender, wxObject *hint = (wxObject *) NULL);
463 bool OnClose (bool deleteWindow = TRUE);
465 TextFileDocument* GetDocument()
466 { return dynamic_cast<TextFileDocument*>(wxView::GetDocument()); }
468 TextFileCanvas* getTextCtrl() { return m_pCanvas; }
469 wxMenu* getFileMenu() { return m_pFileMenu; }
471 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
473 wxDocChildFrame* getFrame() { return m_pFrame; }
477 class TextFileCanvas: public wxTextCtrl
479 TextFileView *m_pView;
482 TextFileCanvas (TextFileView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, long style);