r354: Added Projection Polar conversions
[ctsim.git] / src / views.h
index 4e833bbee920baf543be4dce5979c21038f15f4f..7ca2e62d739fe46d7b9f1c88582b1813ee2a1713 100644 (file)
@@ -9,7 +9,7 @@
 **  This is part of the CTSim program
 **  Copyright (C) 1983-2000 Kevin Rosenberg
 **
-**  $Id: views.h,v 1.1 2000/07/13 07:01:59 kevin Exp $
+**  $Id: views.h,v 1.25 2001/01/04 21:28:41 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
 #define __VIEWSH__
 
 #include "wx/wx.h"
+#include "docs.h"
 #include "imagefile.h"
 
 class ImageFileCanvas;
 class ImageFileView : public wxView
 {
-    DECLARE_DYNAMIC_CLASS(ImageFileView)
-
+  DECLARE_DYNAMIC_CLASS(ImageFileView)
+    
     wxMemoryDC m_memoryDC;
-    wxBitmap* m_pBitmap;
-
+  wxBitmap m_bitmap;
+  
 private:
-    ImageFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
-    wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
-
-    ImageFileCanvas *m_canvas;
-    wxFrame *m_frame;
-    bool m_bMinSpecified;
-    bool m_bMaxSpecified;
-    double m_minPixel;
-    double m_maxPixel;
-
-    static bool m_bPColoursInitialized;
-    static wxColour* m_pColours[256];
-
+  ImageFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
+  wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
+  
+  ImageFileCanvas *m_canvas;
+  wxFrame *m_frame;
+  bool m_bMinSpecified;
+  bool m_bMaxSpecified;
+  double m_dMinPixel;
+  double m_dMaxPixel;
+  double m_dAutoScaleFactor;
+  
+  int m_iDefaultExportFormatID;
+  
 public:
-    ImageFileView(void);
-    ~ImageFileView(void);
-
-    bool OnCreate(wxDocument *doc, long flags);
-    void OnDraw(wxDC* dc);
-    void OnUpdate(wxView *sender, wxObject *hint = NULL);
-    bool OnClose (bool deleteWindow = true);
-    void OnProperties (wxCommandEvent& event);
-
-    DECLARE_EVENT_TABLE()
+  ImageFileView(void);
+  virtual ~ImageFileView(void);
+  
+  bool OnCreate(wxDocument *doc, long flags);
+  void OnDraw(wxDC* dc);
+  void OnUpdate(wxView *sender, wxObject *hint = NULL);
+  bool OnClose (bool deleteWindow = true);
+  
+  void OnScaleSize (wxCommandEvent& event);
+  void OnExport (wxCommandEvent& event);
+  
+  void OnProperties (wxCommandEvent& event);
+  void OnCompare (wxCommandEvent& event);
+  
+  void OnInvertValues (wxCommandEvent& event);
+  void OnSquare (wxCommandEvent& event);
+  void OnSquareRoot (wxCommandEvent& event);
+  void OnLog (wxCommandEvent& event);
+  void OnExp (wxCommandEvent& event);
+  void OnAdd (wxCommandEvent& event);
+  void OnSubtract (wxCommandEvent& event);
+  void OnMultiply (wxCommandEvent& event);
+  void OnDivide (wxCommandEvent& event);
+  void OnFourier (wxCommandEvent& event);
+  void OnInverseFourier (wxCommandEvent& event);
+  void OnShuffleNaturalToFourierOrder (wxCommandEvent& event);
+  void OnShuffleFourierToNaturalOrder (wxCommandEvent& event);
+  
+#ifdef HAVE_FFT
+  void OnFFT (wxCommandEvent& event);
+  void OnIFFT (wxCommandEvent& event);
+#endif
+  
+  void OnMagnitude (wxCommandEvent& event);
+  void OnPhase (wxCommandEvent& event);
+  
+  void OnScaleAuto (wxCommandEvent& event);
+  void OnScaleMinMax (wxCommandEvent& event);
+  void OnScaleFull (wxCommandEvent& event);
+  void OnPlotRow (wxCommandEvent& event);
+  void OnPlotCol (wxCommandEvent& event);
+  void OnPlotHistogram (wxCommandEvent& event);
+  void OnCompareRow (wxCommandEvent& event);
+  void OnCompareCol (wxCommandEvent& event);
+  
+  wxFrame* getFrame()
+  { return m_frame; }
+  
+  ImageFileDocument* GetDocument(void) 
+  { return dynamic_cast<ImageFileDocument*>(wxView::GetDocument()); }
+  
+  DECLARE_EVENT_TABLE()
 };
 
 class ImageFileCanvas: public wxScrolledWindow
 {
+private:
+  
+  int m_xCursor;
+  int m_yCursor;
+  
 public:
-    ImageFileView* m_pView;
+  ImageFileView* m_pView;
+  
+  ImageFileCanvas (ImageFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
+  virtual void OnDraw(wxDC& dc);
+  void OnMouseEvent(wxMouseEvent& event);
+  void DrawRubberBandCursor (wxDC& dc, int x, int y);
+  bool GetCurrentCursor (int& x, int& y);
+  
+  DECLARE_EVENT_TABLE()
+};
+
+
+class ProjectionFileCanvas;
+class ProjectionFileView : public wxView
+{
+  DECLARE_DYNAMIC_CLASS(ProjectionFileView)
     
-    ImageFileCanvas (ImageFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
-    virtual void OnDraw(wxDC& dc);
-    void OnMouseEvent(wxMouseEvent& event);
+    wxMemoryDC m_memoryDC;
+  wxBitmap m_bitmap;
+  
+private:
+  ProjectionFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
+  wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
+  
+  ProjectionFileCanvas *m_canvas;
+  wxFrame *m_frame;
+  
+  int m_iDefaultNX;
+  int m_iDefaultNY;
+  int m_iDefaultFilter;
+  int m_iDefaultFilterMethod;
+  double m_dDefaultFilterParam;
+  int m_iDefaultFilterGeneration;
+  int m_iDefaultZeropad;
+  int m_iDefaultInterpolation;
+  int m_iDefaultInterpParam;
+  int m_iDefaultBackprojector;
+  int m_iDefaultTrace;
+  
+  int m_iDefaultPolarNX;
+  int m_iDefaultPolarNY;
+  int m_iDefaultPolarInterpolation;
+  int m_iDefaultPolarZeropad;
 
-    DECLARE_EVENT_TABLE()
+public:
+  ProjectionFileView(void);
+  virtual ~ProjectionFileView(void);
+  
+  bool OnCreate(wxDocument *doc, long flags);
+  void OnDraw(wxDC* dc);
+  void OnUpdate(wxView *sender, wxObject *hint = NULL);
+  bool OnClose (bool deleteWindow = true);
+  void OnProperties (wxCommandEvent& event);
+  void OnReconstructFBP (wxCommandEvent& event);
+  void OnReconstructFourier (wxCommandEvent& event);
+  void OnConvertPolar (wxCommandEvent& event);
+  void OnConvertFFTPolar (wxCommandEvent& event);
+  
+  wxFrame* getFrame ()
+  { return m_frame; }
+  
+  ProjectionFileDocument* GetDocument(void) 
+  { return dynamic_cast<ProjectionFileDocument*>(wxView::GetDocument()); }
+  DECLARE_EVENT_TABLE()
 };
 
-
-class MyTextWindow: public wxTextCtrl
+class ProjectionFileCanvas: public wxScrolledWindow
 {
 public:
-    wxView *m_pView;
-    
-    MyTextWindow(wxView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
+  ProjectionFileView* m_pView;
+  
+  ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
+  virtual void OnDraw(wxDC& dc);
 };
 
 
-class TextEditView: public wxView
+class PhantomCanvas;
+class PhantomView : public wxView
 {
-    DECLARE_DYNAMIC_CLASS(TextEditView)
+  DECLARE_DYNAMIC_CLASS(PhantomView)
+    
 private:
-    wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
-
+  PhantomCanvas *CreateCanvas(wxView *view, wxFrame *parent);
+  wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
+  
+  PhantomCanvas *m_canvas;
+  wxFrame *m_frame;
+  
+  int m_iDefaultNDet;
+  int m_iDefaultNView;
+  int m_iDefaultNSample;
+  int m_iDefaultGeometry;
+  int m_iDefaultTrace;
+  double m_dDefaultRotation;
+  double m_dDefaultFocalLength;
+  double m_dDefaultFieldOfView;
+  
 public:
-    wxFrame *frame;
-    MyTextWindow *textsw;
-    
-    TextEditView(): wxView() { frame = (wxFrame *) NULL; textsw = (MyTextWindow *) NULL; }
-    ~TextEditView(void) {}
-    
-    bool OnCreate(wxDocument *doc, long flags);
-    void OnDraw(wxDC* dc);
-    void OnUpdate(wxView *sender, wxObject *hint = (wxObject *) NULL);
-    bool OnClose(bool deleteWindow = TRUE);
+  PhantomView(void);
+  virtual ~PhantomView(void);
+  
+  bool OnCreate(wxDocument *doc, long flags);
+  void OnUpdate(wxView *sender, wxObject *hint = NULL);
+  bool OnClose (bool deleteWindow = true);
+  void OnDraw(wxDC* dc);
+  void OnProperties (wxCommandEvent& event);
+  void OnRasterize (wxCommandEvent& event);
+  void OnProjections (wxCommandEvent& event);
+  
+  PhantomDocument* GetDocument(void) 
+  { return dynamic_cast<PhantomDocument*>(wxView::GetDocument()); }
+  
+  DECLARE_EVENT_TABLE()
 };
 
-class ProjectionFileCanvas;
-class ProjectionFileView : public wxView
+class PhantomCanvas: public wxScrolledWindow
 {
-    DECLARE_DYNAMIC_CLASS(ProjectionFileView)
-
-    wxMemoryDC m_memoryDC;
-    wxBitmap* m_pBitmap;
+public:
+  PhantomView* m_pView;
+  
+  PhantomCanvas (PhantomView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
+  virtual void OnDraw(wxDC& dc);
+};
 
+class PlotFileCanvas;
+class PlotFileView : public wxView
+{
+  DECLARE_DYNAMIC_CLASS(PlotFileView)
+    
 private:
-    ProjectionFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
-    wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
-
-    ProjectionFileCanvas *m_canvas;
-    wxFrame *m_frame;
-
-    static bool m_bPColoursInitialized;
-    static wxColour* m_pColours[256];
-
+  PlotFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
+  wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
+  
+  PlotFileCanvas *m_canvas;
+  wxFrame *m_frame;
+  EZPlot* m_pEZPlot;
+  
+  bool m_bMinSpecified;
+  bool m_bMaxSpecified;
+  double m_dMinPixel;
+  double m_dMaxPixel;
+  double m_dAutoScaleFactor;
+  
 public:
-    ProjectionFileView(void);
-    ~ProjectionFileView(void);
-
-    bool OnCreate(wxDocument *doc, long flags);
-    void OnDraw(wxDC* dc);
-    void OnUpdate(wxView *sender, wxObject *hint = NULL);
-    bool OnClose (bool deleteWindow = true);
-    void OnProperties (wxCommandEvent& event);
-    void OnReconstruct (wxCommandEvent& event);
+  PlotFileView(void);
+  virtual ~PlotFileView(void);
+  
+  bool OnCreate(wxDocument *doc, long flags);
+  void OnDraw(wxDC* dc);
+  void OnUpdate(wxView *sender, wxObject *hint = NULL);
+  bool OnClose (bool deleteWindow = true);
 
-    DECLARE_EVENT_TABLE()
+  void OnProperties (wxCommandEvent& event);
+  void OnScaleMinMax (wxCommandEvent& event);
+  void OnScaleAuto (wxCommandEvent& event);
+  void OnScaleFull (wxCommandEvent& event);
+  
+  wxFrame* getFrame ()
+  { return m_frame; }
+  
+  PlotFileDocument* GetDocument(void) 
+  { return dynamic_cast<PlotFileDocument*>(wxView::GetDocument()); }
+  
+  DECLARE_EVENT_TABLE()
 };
 
-class ProjectionFileCanvas: public wxScrolledWindow
+class PlotFileCanvas: public wxScrolledWindow
 {
 public:
-    ProjectionFileView* m_pView;
-    
-    ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
-    virtual void OnDraw(wxDC& dc);
+  PlotFileView* m_pView;
+  
+  PlotFileCanvas (PlotFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
+  virtual void OnDraw(wxDC& dc);
 };
 
 
 #endif
+