** 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.22 2001/01/02 13:16:43 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;
DECLARE_DYNAMIC_CLASS(ImageFileView)
wxMemoryDC m_memoryDC;
- wxBitmap* m_pBitmap;
+ wxBitmap m_bitmap;
private:
ImageFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
wxFrame *m_frame;
bool m_bMinSpecified;
bool m_bMaxSpecified;
- double m_minPixel;
- double m_maxPixel;
+ double m_dMinPixel;
+ double m_dMaxPixel;
+ double m_dAutoScaleFactor;
- static bool m_bPColoursInitialized;
- static wxColour* m_pColours[256];
+ int m_iDefaultExportFormatID;
public:
ImageFileView(void);
- ~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_FFTW
+ 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 OnPlotRow (wxCommandEvent& event);
+ void OnPlotCol (wxCommandEvent& event);
+ void OnHistogram (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;
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 MyTextWindow: public wxTextCtrl
+class ProjectionFileCanvas;
+class ProjectionFileView : public wxView
{
+ DECLARE_DYNAMIC_CLASS(ProjectionFileView)
+
+ 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;
+
public:
- wxView *m_pView;
+ 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 OnReconstruct (wxCommandEvent& event);
+
+ wxFrame* getFrame ()
+ { return m_frame; }
+
+ ProjectionFileDocument* GetDocument(void)
+ { return dynamic_cast<ProjectionFileDocument*>(wxView::GetDocument()); }
+ DECLARE_EVENT_TABLE()
+};
+
+class ProjectionFileCanvas: public wxScrolledWindow
+{
+public:
+ ProjectionFileView* m_pView;
- MyTextWindow(wxView *v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
+ 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:
+ 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) {}
-
+ 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 OnUpdate(wxView *sender, wxObject *hint = (wxObject *) NULL);
- bool OnClose(bool deleteWindow = TRUE);
+ 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)
+public:
+ PhantomView* m_pView;
+
+ PhantomCanvas (PhantomView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
+ virtual void OnDraw(wxDC& dc);
+};
- wxMemoryDC m_memoryDC;
- wxBitmap* m_pBitmap;
+class PlotFileCanvas;
+class PlotFileView : public wxView
+{
+ DECLARE_DYNAMIC_CLASS(PlotFileView)
private:
- ProjectionFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
+ PlotFileCanvas *CreateCanvas(wxView *view, wxFrame *parent);
wxFrame *CreateChildFrame(wxDocument *doc, wxView *view);
- ProjectionFileCanvas *m_canvas;
+ PlotFileCanvas *m_canvas;
wxFrame *m_frame;
+ EZPlot* m_pEZPlot;
- static bool m_bPColoursInitialized;
- static wxColour* m_pColours[256];
+ bool m_bMinSpecified;
+ bool m_bMaxSpecified;
+ double m_dMinPixel;
+ double m_dMaxPixel;
+ double m_dAutoScaleFactor;
public:
- ProjectionFileView(void);
- ~ProjectionFileView(void);
+ 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);
void OnProperties (wxCommandEvent& event);
- void OnReconstruct (wxCommandEvent& event);
+ void OnScaleAuto (wxCommandEvent& event);
+ void OnScaleMinMax (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;
+ PlotFileView* m_pView;
- ProjectionFileCanvas (ProjectionFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
+ PlotFileCanvas (PlotFileView* v, wxFrame *frame, const wxPoint& pos, const wxSize& size, const long style);
virtual void OnDraw(wxDC& dc);
};
#endif
+