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.58 2002/06/06 22:50:24 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;
65 wxMenu* m_pFilterMenu;
70 double m_dAutoScaleFactor;
72 int m_iDefaultExportFormatID;
74 wxWindow* getFrameForChild()
76 { return theApp->getMainFrame(); }
83 virtual ~ImageFileView();
85 { m_pCanvas = NULL; m_pFrame = NULL; }
88 { return m_pFileMenu; }
90 bool OnCreate(wxDocument *doc, long flags);
91 void OnDraw(wxDC* dc);
92 void OnUpdate(wxView *sender, wxObject *hint = NULL);
93 bool OnClose (bool deleteWindow = true);
95 void OnEditCopy (wxCommandEvent& event);
96 void OnEditCut (wxCommandEvent& event);
97 void OnEditPaste (wxCommandEvent& event);
99 void OnRevert (wxCommandEvent& event);
100 void OnExport (wxCommandEvent& event);
101 void OnProperties (wxCommandEvent& event);
103 void OnCompare (wxCommandEvent& event);
104 void OnScaleSize (wxCommandEvent& event);
105 void OnInvertValues (wxCommandEvent& event);
106 void OnSquare (wxCommandEvent& event);
107 void OnSquareRoot (wxCommandEvent& event);
108 void OnLog (wxCommandEvent& event);
109 void OnExp (wxCommandEvent& event);
110 void OnAdd (wxCommandEvent& event);
111 void OnSubtract (wxCommandEvent& event);
112 void OnMultiply (wxCommandEvent& event);
113 void OnDivide (wxCommandEvent& event);
114 void OnFourier (wxCommandEvent& event);
115 void OnInverseFourier (wxCommandEvent& event);
116 void OnShuffleNaturalToFourierOrder (wxCommandEvent& event);
117 void OnShuffleFourierToNaturalOrder (wxCommandEvent& event);
119 void OnConvert3d (wxCommandEvent& event);
123 void OnFFT (wxCommandEvent& event);
124 void OnIFFT (wxCommandEvent& event);
125 void OnFFTRows (wxCommandEvent& event);
126 void OnIFFTRows (wxCommandEvent& event);
127 void OnFFTCols (wxCommandEvent& event);
128 void OnIFFTCols (wxCommandEvent& event);
131 void OnMagnitude (wxCommandEvent& event);
132 void OnPhase (wxCommandEvent& event);
133 void OnReal (wxCommandEvent& event);
134 void OnImaginary (wxCommandEvent& event);
136 void OnScaleAuto (wxCommandEvent& event);
137 void OnScaleMinMax (wxCommandEvent& event);
138 void OnScaleFull (wxCommandEvent& event);
139 void OnPlotRow (wxCommandEvent& event);
140 void OnPlotCol (wxCommandEvent& event);
142 void OnPlotFFTRow (wxCommandEvent& event);
143 void OnPlotFFTCol (wxCommandEvent& event);
145 void OnPlotHistogram (wxCommandEvent& event);
146 void OnCompareRow (wxCommandEvent& event);
147 void OnCompareCol (wxCommandEvent& event);
150 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
152 wxDocChildFrame* getFrame() { return m_pFrame; }
154 void setInitialClientSize();
156 wxMenu* getMenuAnalyze() { return m_pMenuAnalyze; }
158 ImageFileDocument* GetDocument()
159 { return dynamic_cast<ImageFileDocument*>(wxView::GetDocument()); }
161 DECLARE_EVENT_TABLE()
164 class ImageFileCanvas: public wxScrolledWindow
167 ImageFileView* m_pView;
173 ImageFileCanvas (ImageFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
174 virtual ~ImageFileCanvas();
176 virtual void OnDraw(wxDC& dc);
177 void OnChar(wxKeyEvent& event);
178 void OnMouseEvent(wxMouseEvent& event);
179 void DrawRubberBandCursor (wxDC& dc, int x, int y);
180 bool GetCurrentCursor (int& x, int& y);
182 virtual wxSize GetBestSize() const;
183 void setView(ImageFileView* pView)
187 DECLARE_EVENT_TABLE()
191 class ProjectionFileCanvas;
192 class ProjectionFileView : public wxView
195 DECLARE_DYNAMIC_CLASS(ProjectionFileView)
197 wxMemoryDC m_memoryDC;
200 ProjectionFileCanvas *CreateCanvas (wxFrame* parent);
202 wxDocMDIChildFrame* m_pFrame;
203 wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
205 wxDocChildFrame* m_pFrame;
206 wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
209 ProjectionFileCanvas *m_pCanvas;
214 int m_iDefaultFilter;
215 int m_iDefaultFilterMethod;
216 double m_dDefaultFilterParam;
217 int m_iDefaultFilterGeneration;
218 int m_iDefaultZeropad;
219 int m_iDefaultInterpolation;
220 int m_iDefaultInterpParam;
221 int m_iDefaultBackprojector;
224 int m_iDefaultPolarNX;
225 int m_iDefaultPolarNY;
226 int m_iDefaultPolarInterpolation;
227 int m_iDefaultPolarZeropad;
229 wxWindow* getFrameForChild()
231 { return theApp->getMainFrame(); }
237 ProjectionFileView();
238 virtual ~ProjectionFileView();
240 { m_pCanvas = NULL; m_pFrame = NULL; }
242 bool OnCreate(wxDocument *doc, long flags);
243 void OnDraw(wxDC* dc);
244 void OnUpdate(wxView *sender, wxObject *hint = NULL);
245 bool OnClose (bool deleteWindow = true);
246 void OnProperties (wxCommandEvent& event);
247 void OnReconstructFBP (wxCommandEvent& event);
248 void OnReconstructFBPRebin (wxCommandEvent& event);
249 void OnReconstructFourier (wxCommandEvent& event);
250 void OnConvertRectangular (wxCommandEvent& event);
251 void OnConvertPolar (wxCommandEvent& event);
252 void OnConvertFFTPolar (wxCommandEvent& event);
253 void OnPlotTThetaSampling (wxCommandEvent& event);
254 void OnPlotHistogram (wxCommandEvent& event);
255 void OnConvertParallel (wxCommandEvent& event);
256 void OnArtifactReduction (wxCommandEvent& event);
258 void doReconstructFBP (const Projections& rProj, bool bRebinToParallel);
261 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
263 wxDocChildFrame* getFrame() { return m_pFrame; }
265 ProjectionFileCanvas* getCanvas() { return m_pCanvas; }
266 void setInitialClientSize();
268 wxMenu* getFileMenu() { return m_pFileMenu; }
270 ProjectionFileDocument* GetDocument()
271 { return dynamic_cast<ProjectionFileDocument*>(wxView::GetDocument()); }
272 DECLARE_EVENT_TABLE()
275 class ProjectionFileCanvas: public wxScrolledWindow
278 ProjectionFileView* m_pView;
281 ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
282 virtual ~ProjectionFileCanvas() ;
284 virtual wxSize GetBestSize() const;
285 virtual void OnDraw(wxDC& dc);
286 void setView(ProjectionFileView* pView)
292 class PhantomFileView : public wxView
295 DECLARE_DYNAMIC_CLASS(PhantomFileView)
296 DECLARE_EVENT_TABLE()
298 PhantomCanvas *CreateCanvas (wxFrame* parent);
300 wxDocMDIChildFrame* m_pFrame;
301 wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
303 wxDocChildFrame* m_pFrame;
304 wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
307 PhantomCanvas *m_pCanvas;
312 int m_iDefaultOffsetView;
313 int m_iDefaultNSample;
314 int m_iDefaultGeometry;
316 double m_dDefaultRotation;
317 double m_dDefaultFocalLength;
318 double m_dDefaultCenterDetectorLength;
319 double m_dDefaultViewRatio;
320 double m_dDefaultScanRatio;
322 int m_iDefaultRasterNX;
323 int m_iDefaultRasterNY;
324 int m_iDefaultRasterNSamples;
325 double m_dDefaultRasterViewRatio;
327 wxWindow* getFrameForChild()
329 { return theApp->getMainFrame(); }
336 virtual ~PhantomFileView();
338 { m_pCanvas = NULL; m_pFrame = NULL; }
340 bool OnCreate(wxDocument *doc, long flags);
341 void OnUpdate(wxView *sender, wxObject *hint = NULL);
342 bool OnClose (bool deleteWindow = true);
343 void OnDraw(wxDC* dc);
344 void OnProperties (wxCommandEvent& event);
345 void OnRasterize (wxCommandEvent& event);
346 void OnProjections (wxCommandEvent& event);
348 PhantomFileDocument* GetDocument()
349 { return dynamic_cast<PhantomFileDocument*>(wxView::GetDocument()); }
351 wxMenu* getFileMenu() { return m_pFileMenu; }
353 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
355 wxDocChildFrame* getFrame() { return m_pFrame; }
359 class PhantomCanvas: public wxScrolledWindow
362 PhantomFileView* m_pView;
365 PhantomCanvas (PhantomFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
366 virtual ~PhantomCanvas();
368 virtual wxSize GetBestSize() const;
369 void setView(PhantomFileView* pView)
371 virtual void OnDraw(wxDC& dc);
374 class PlotFileCanvas;
375 class PlotFileView : public wxView
377 DECLARE_DYNAMIC_CLASS(PlotFileView)
381 wxDocMDIChildFrame* m_pFrame;
382 wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
384 wxDocChildFrame* m_pFrame;
385 wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
388 PlotFileCanvas *m_pCanvas;
392 bool m_bMinSpecified;
393 bool m_bMaxSpecified;
396 double m_dAutoScaleFactor;
398 PlotFileCanvas *CreateCanvas (wxFrame* parent);
399 wxWindow* getFrameForChild()
401 { return theApp->getMainFrame(); }
408 virtual ~PlotFileView();
410 { m_pCanvas = NULL; m_pFrame = NULL; }
412 bool OnCreate(wxDocument *doc, long flags);
413 void OnDraw(wxDC* dc);
414 void OnUpdate(wxView *sender, wxObject *hint = NULL);
415 bool OnClose (bool deleteWindow = true);
417 void OnProperties (wxCommandEvent& event);
418 void OnScaleMinMax (wxCommandEvent& event);
419 void OnScaleAuto (wxCommandEvent& event);
420 void OnScaleFull (wxCommandEvent& event);
423 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
425 wxDocChildFrame* getFrame() { return m_pFrame; }
428 void setInitialClientSize();
429 wxMenu* getFileMenu() { return m_pFileMenu; }
430 PlotFileDocument* GetDocument()
431 { return dynamic_cast<PlotFileDocument*>(wxView::GetDocument()); }
433 DECLARE_EVENT_TABLE()
436 class PlotFileCanvas: public wxScrolledWindow
439 PlotFileView* m_pView;
442 PlotFileCanvas (PlotFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
443 virtual ~PlotFileCanvas();
445 virtual void OnDraw(wxDC& dc);
446 virtual wxSize GetBestSize() const;
448 void setView (PlotFileView* pView)
453 class TextFileCanvas;
454 class TextFileView: public wxView
457 DECLARE_DYNAMIC_CLASS(TextFileView)
460 wxDocMDIChildFrame* m_pFrame;
461 wxDocMDIChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
463 wxDocChildFrame* m_pFrame;
464 wxDocChildFrame* CreateChildFrame(wxDocument *doc, wxView *view);
467 TextFileCanvas *m_pCanvas;
471 : wxView() , m_pFrame(0), m_pCanvas(0)
477 bool OnCreate (wxDocument *doc, long flags);
478 void OnDraw (wxDC *dc);
479 void OnUpdate (wxView *sender, wxObject *hint = (wxObject *) NULL);
480 bool OnClose (bool deleteWindow = TRUE);
482 TextFileDocument* GetDocument()
483 { return dynamic_cast<TextFileDocument*>(wxView::GetDocument()); }
485 TextFileCanvas* getTextCtrl() { return m_pCanvas; }
486 wxMenu* getFileMenu() { return m_pFileMenu; }
488 wxDocMDIChildFrame* getFrame() { return m_pFrame; }
490 wxDocChildFrame* getFrame() { return m_pFrame; }
494 class TextFileCanvas: public wxTextCtrl
496 TextFileView *m_pView;
499 TextFileCanvas (TextFileView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, long style);
501 virtual wxSize GetBestSize() const;